Lmn 7.1: Probleme mit Regpatches für Windows

Hallo Thomas,

ich bin durch.
Die letzten zwei Einträge haben geklappt: die ersten drei nicht.
Es ist also so, dass wenn CurrentControlSet drin ist, dann geht es nicht.

Jetzt versuche ich noch die letzten beiden zusammen.

Nochmal zusammen:
diese drei gehen nicht (einzeln getestet)

"
Windows Registry Editor Version 5.00

; setzt den Computernamen richtig
[HKEY_LOCAL_MACHINE\System\CurrentControlSet\Control\ComputerName\ActiveComputerName]
„ComputerName“=„{$HostName$}“

; setzt den Computernamen richtig
[HKEY_LOCAL_MACHINE\System\CurrentControlSet\Control\ComputerName\ComputerName]
„ComputerName“=„{$HostName$}“

; setzt den Computernamen richtig
[HKEY_LOCAL_MACHINE\System\CurrentControlSet\services\Tcpip\Parameters]
„Hostname“=„{$HostName$}“
„NV Hostname“=„{$HostName$}“

Diese beiden gehen (bisher einzeln getestet):

; setzt den Domainnamen richtig
[HKEY_LOCAL_MACHINE\Software\Microsoft\Windows\CurrentVersion\Policies\System]
„DefaultLogonDomain“=„LINUXMUSTER“

; setzt den Computernamen und Domainnamenrichtig
[HKEY_LOCAL_MACHINE\SYSTEM\ControlSet001\Services\Tcpip\Parameters]
„Domain“=„LINUXMUSTER“
„NV Hostname“=„{$HostName$}“
„Hostname“=„{$HostName$}“
„NV Domain“=„LINUXMUSTER“
"

LG

Holger

Hallo,

ich hab jetzt noch einen weiteren Test gemacht: und zwar mit dem
regpatch, der die beiden funktionierenden Einträge hat.
Der Test wqurde absichtlich auf dem Client durchgeführt, auf dem das
Image nicht erstellt wurde: damit ich sehen kann, was in der registry
ankommt: und genau da wird es spannend…
Und ich hab den Test gemacht, weil ich wissen wollte, ob der Domainlogin
funktioniert.

  1. Domainlogin funktioniert, obwohl der Rechner falsch heißt (wenn ich
    .\ bei Benutzernamen eingebe, dann wird der Rechnername des Rechners
    angezeigt, auf dem ich das Image erstellt habe). Netzlaufwerke sind da.

  2. Regeinträge:
    wie zu erwarten, sind folgende Einträge korrekt gesetzt (ich hab mit
    regedit.exe in der Registry an der entsprechenden Stelle jeweils den
    Eintrag kontrolliert):

; setzt den Domainnamen richtig

[HKEY_LOCAL_MACHINE\Software\Microsoft\Windows\CurrentVersion\Policies\System]

„DefaultLogonDomain“=„LINUXMUSTER“

; setzt den Computernamen und Domainnamenrichtig
[HKEY_LOCAL_MACHINE\SYSTEM\ControlSet001\Services\Tcpip\Parameters]
„Domain“=„LINUXMUSTER“
„NV Hostname“="{$HostName$}"
„Hostname“="{$HostName$}"
„NV Domain“=„LINUXMUSTER“

Diese Einträge sind falsch (es steht der Rechnernamen drin, der dem
Imageerstellrechner gehörte):

; setzt den Computernamen richtig

[HKEY_LOCAL_MACHINE\System\CurrentControlSet\Control\ComputerName\ActiveComputerName]

„ComputerName“="{$HostName$}"

; setzt den Computernamen richtig

[HKEY_LOCAL_MACHINE\System\CurrentControlSet\Control\ComputerName\ComputerName]

„ComputerName“="{$HostName$}"

Und jetzt wird es seltsam.
Diese Einträge zeigen den richtigen Rechnernamen, obwohl die im Rechner
von dem das Image stammte, definitiv auf „dessen Namen“ lauteten (ich
hab den „Orginalrechner“ angeworfen und geschaut).

; setzt den Computernamen richtig

[HKEY_LOCAL_MACHINE\System\CurrentControlSet\services\Tcpip\Parameters]

„Hostname“="{$HostName$}"
„NV Hostname“="{$HostName$}"

Irgendwoher holt der sich da den richtigen Rechnernamen … aus
ControlSet001 ???
Ich weiß es nicht…

Ich klon den Client jetzt wieder kaputt, weil ich einen der drei
problematischen Zeilen wieder rein nehme… :slight_smile:

LG

Holger

Hallo Holger,

Windows wählt beim Booten aus, was das CurrentControlSet wird: Unterschiede zwischen ControlSet001, 002 und 003 in der Registry - Tipps & Tricks
Wenn ich den Artikel richtig verstehe, will man in seinem Registry-Patch eigentlich immer ControlSet001 patchen. Und im Umkehrschluss CurrentControlSet zu patchen, wäre vergebens, weil es im Bootvorgang mit dem Inhalt von ControlSet### überschrieben wird.

MfG Buster

Hallo Buster,

Windows wählt beim Booten aus, was das CurrentControlSet wird:
Unterschiede zwischen ControlSet001, 002 und 003 in der Registry - Tipps
& Tricks
https://www.wintotal.de/tipp/unterschiede-zwischen-controlset001-002-und-003-in-der-registry/
Wenn ich den Artikel richtig verstehe, will man in seinem Registry-Patch
eigentlich immer ControlSet001 patchen. Und im Umkehrschluss
CurrentControlSet zu patchen, wäre vergebens, weil es im Bootvorgang mit
dem Inhalt von ControlSet### überschrieben wird.

das hab ich ja auch vermutet.
Wenn dem so wäre, dann wäre das ja wunderbar: dann könnten die
CurrentControlSet Patches raus: und das sind genau die, die den Client
schreddern.
Aber diese beiden Stellen werden eben nicht übernommen:

; setzt den Computernamen richtig
[HKEY_LOCAL_MACHINE\System\CurrentControlSet\Control\ComputerName\ActiveComputerName]
„ComputerName“=„{$HostName$}“

; setzt den Computernamen richtig
[HKEY_LOCAL_MACHINE\System\CurrentControlSet\Control\ComputerName\ComputerName]
„ComputerName“=„{$HostName$}“

Die Frage ist: können wir damit leben?

LG

Holger

Hallo,

… ich denke, ich hab jetzt gute Nachrichten.
Angeregt durch Buster hab ich geschaut: dashier wird korrekt von
ControlSet001 in CurrentControlSet übernommen:

[HKEY_LOCAL_MACHINE\SYSTEM\ControlSet001\Services\Tcpip\Parameters]
„NV Hostname“="{$HostName$}"
„Hostname“="{$HostName$}"

Diese beiden Patches fehlen noch:
[HKEY_LOCAL_MACHINE\System\CurrentControlSet\Control\ComputerName\ActiveComputerName]
„ComputerName“="{$HostName$}"

; setzt den Computernamen richtig
[HKEY_LOCAL_MACHINE\System\CurrentControlSet\Control\ComputerName\ComputerName]
„ComputerName“="{$HostName$}"

Also hab ich die beiden einfach geändert in:

[HKEY_LOCAL_MACHINE\System\ControlSet001\Control\ComputerName\ActiveComputerName]
„ComputerName“="{$HostName$}"

; setzt den Computernamen richtig
[HKEY_LOCAL_MACHINE\System\ControlSet001\Control\ComputerName\ComputerName]
„ComputerName“="{$HostName$}"

Dann hab ich den Rechner mit diesem regpatch geklont (wie immer:
partitioniert, regpatch auf Client geprüft, gesynct).

Effekt: Durchschlagend!
Der Rechner bootet, es steht der richtige Rechnernamen in der
Anmeldemaske, in der Registry ist der „Vorlagenrechnername“ nicht mehr
zu finden und vor allem:
an den beiden Stellen steht der richtige Namen:

[HKEY_LOCAL_MACHINE\System\CurrentControlSet\Control\ComputerName\ComputerName]
[HKEY_LOCAL_MACHINE\System\CurrentControlSet\Control\ComputerName\ActiveComputerName]

Das würde bedeuten, dass ich mit dem neuen Patcher leben könnte: man
muss nur den Regpatch selbst anpassen.
„verlieren“ tut man dabei wohl nichts …

LG

Holger

1 „Gefällt mir“

Hallo,

ich habe auch nochmal nach den verschiedenen Bedeutungen der Registry-Keys gesucht und bin auf das hier gestoßen (Hervorhebung von mir):

HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Control\ComputerName\ActiveComputerName\ComputerName is the current NetBIOS computer name.

HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Control\ComputerName\ComputerName\ComputerName is the NetBIOS computer name that will be used when the computer is restarted.

HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Services\Tcpip\Parameters\Hostname is the host name of the computer.

HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Services\Tcpip\Parameters\NV Hostname is the host name that the computer will take when it is restarted.

HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Services\Tcpip\Parameters\Domain is the current DNS domain name. Domain may be empty or not present. The full computer name is the values of Hostname + Domain.

HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Services\Tcpip\Parameters\NV Domain is the DNS domain name that the computer will use when it is restarted. The full computer name after a restart is the values of NV Hostname + NV Domain.

Demnach sollten diese Einträge reichen:

  • HKEY_LOCAL_MACHINE\SYSTEM\CurrentControl001\Control\ComputerName\ActiveComputerName\ComputerName für NetBIOS
  • HKEY_LOCAL_MACHINE\SYSTEM\CurrentControl001\Services\Tcpip\Parameters\Hostname für Netzwerk/DNS
  • HKEY_LOCAL_MACHINE\SYSTEM\CurrentControl001\Services\Tcpip\Parameters\Domain wobei ich da noch gelesen habe, dass es nicht die Kurzform sein sollte. Das deckte sich auch mit meiner Erfahrung, dass der Login am Windows gegen meinen externen Domänencontroller erst funktionierte, als ich den FQDN abzüglich Hostnamen verwendet habe.

Die Werte für „nach dem Reboot“ benötigen wir ja nicht. Die sollten nicht existieren und wenn doch, dann aber identisch sein.

Quellen:

MfG Buster

1 „Gefällt mir“

Okay, danke! :+1:

Die Problematischen betreffen also alle den System-Hive.
Es ist ja so, dass reged die Patches einzeln serviert kriegt und anwendet und bei jedem einzelnen gibt es eine Erfolgsmeldung. Wenn man nachher unter Linbo mit reged interaktiv den Hive durchsieht, sind auch alle Werte und Schlüssel vorhanden.
Ich schau mir das heute Nachmittag mal an. Evtl. hat es mit der Schreibweise zu tun (groß/klein).

VG, Thomas

@Buster @baumhof

Bitte nochmal klare Ansage: Wie lauten jetzt die korrekten Pfade im Regpatch?

  • \CurrentControl001\ oder
  • \ControlSet001\ oder
  • \CurrentControlSet\

Am besten wäre eine Beispieldatei, die ich ins Paket übernehmen kann, hier angehängt: #50.

VG, Thomas

Also, wenn der Regpatcher in allen Pfaden \CurrentControlSet\ durch \ControlSet001\ ersetzt, funktioniert das bei mir. Wäre das also die Lösung?

Zusätzlich muss bei allen Keys mit NV die DNS-Domäne verwendet werden. Richtig?

VG, Thomas

Hallo Thomas,

Also, wenn der Regpatcher in allen Pfaden \CurrentControlSet\ durch
\ControlSet001\ ersetzt, funktioniert das bei mir. Wäre das also die Lösung?

… den einen kannst du rauslöschen: der steht schon mit
CurrentControlSet und ControlSet001 drin: nur einer ist nötig.

In meiner vbox Umgebung war das die Lösung: ich schau mal, dass ich das
Montag in der Schule ausrolle.
Kann ich aber noch nciht versprechen.

Zusätzlich muss bei allen Keys mit NV die DNS-Domäne verwendet werden.
Richtig?

… bei mir steht bei denen wo NV mit drin steht manchmal der Hostname
und manchmal die Domain…
Von meiner Warte aus ist deine Aussage also nciht richtig.

Mein Patch sieht jetzt so aus:

Windows Registry Editor Version 5.00

; setzt den Computernamen richtig
[HKEY_LOCAL_MACHINE\System\ControlSet001\Control\ComputerName\ActiveComputerName]
„ComputerName“="{$HostName$}"

; setzt den Computernamen richtig
[HKEY_LOCAL_MACHINE\System\ControlSet001\Control\ComputerName\ComputerName]
„ComputerName“="{$HostName$}"

; setzt den Domainnamen richtig
[HKEY_LOCAL_MACHINE\Software\Microsoft\Windows\CurrentVersion\Policies\System]
„DefaultLogonDomain“=„LINUXMUSTER“

; setzt den Computernamen und Domainnamenrichtig
[HKEY_LOCAL_MACHINE\SYSTEM\ControlSet001\Services\Tcpip\Parameters]
„Domain“=„LINUXMUSTER“
„NV Hostname“="{$HostName$}"
„Hostname“="{$HostName$}"
„NV Domain“=„LINUXMUSTER“

Es gibt, so hab ich das interpretiert , noch die Diskussion, dass bei
den beiden Domaineinträgen nicht die Kurzform rein sollte, sondern die
langform: also nicht LINUXMUSTER sondern LINUXMUSTER.LAN

Ich sage dazu: beides scheint zu gehen: in der Schule hab ich die FQDN
und in der vbox Umgebung nur die DOMAIN.

VIele Grüße

Holger

Hallo,

die NV-Werte („next value“ hostname und domain) braucht es nicht, wenn sichergestellt ist, dass die gleichnamigen Keys vorher nicht existierten. Wenn die Keys existieren und man überschreibt sie nicht, läuft man Gefahr, dass nach einem normalen Start (grün) der Rechner wie der Muster-Rechner heißt.

Kann reged Keys löschen? Das Dateiformat bietet die Option ja mit einem Minus vor dem Abschnitt/Key. Ich habe leider gerade keine Testumgebung zur Hand.

MfG Buster

Hallo,

die NV-Werte („next value“ hostname und domain) braucht es nicht, wenn
sichergestellt ist, dass die gleichnamigen Keys vorher nicht
existierten. Wenn die Keys existieren und man überschreibt sie nicht,
läuft man Gefahr, dass nach einem normalen Start (grün) der Rechner wie
der Muster-Rechner heißt.

genau davor hab ich auch angst: das sollten wir nicht machen.

Ich habe nun also in meiner VM getestet (wie immer: regpatch auf server
hin, client partitioniert+gesynct: immer der Client von dem das Image
nicht stammt, damit ich sehen kann, wo es möglicherweise nicht geändert
wurde).

Ich habe nacheinander diese beiden Regpatches getestet.
Der erste ist der aktuelle aus /srv/linbo/examples/

Windows Registry Editor Version 5.00

; linuxmuster.net 7

; patches hostname, to be applied after every image sync

[HKEY_LOCAL_MACHINE\System\CurrentControlSet\Control\ComputerName\ActiveComputerName\]
"ComputerName"="{$HostName$}"

[HKEY_LOCAL_MACHINE\System\CurrentControlSet\Control\ComputerName\ComputerName\]
"ComputerName"="{$HostName$}"

[HKEY_LOCAL_MACHINE\System\CurrentControlSet\services\Tcpip\Parameters\]
"Hostname"="{$HostName$}"
"NV Hostname"="{$HostName$}"
; add your custom registry patches below

er enthält keinerlei ControlSet001

Effekt ist, dass alle Einträge, die oben in der Datei sind: aber an den
Stellen ControlSet001/Services/Tcpip/Parameters
und
CurrentControlSet/Services/Tcpip/Parameters
in den Werten: Hostname und NV Hostname steht der Namen des Vorlagenrechners.
Domainlogin geht, Netzlaufwerke da.

Dann habe ich „den alten“ Regpatch getestet:

Windows Registry Editor Version 5.00

; setzt den Computernamen richtig
[HKEY_LOCAL_MACHINE\System\CurrentControlSet\Control\ComputerName\ActiveComputerName\]
"ComputerName"="{$HostName$}"

; setzt den Computernamen richtig
[HKEY_LOCAL_MACHINE\System\CurrentControlSet\Control\ComputerName\ComputerName\]
"ComputerName"="{$HostName$}"

; setzt den Computernamen richtig
[HKEY_LOCAL_MACHINE\System\CurrentControlSet\services\Tcpip\Parameters\]
"Hostname"="{$HostName$}"
"NV Hostname"="{$HostName$}"

; setzt den Domainnamen richtig
[HKEY_LOCAL_MACHINE\Software\Microsoft\Windows\CurrentVersion\Policies\System\]
"DefaultLogonDomain"="LINUXMUSTER"

; setzt den Computernamen und Domainnamenrichtig
[HKEY_LOCAL_MACHINE\SYSTEM\ControlSet001\Services\Tcpip\Parameters]
"Domain"="LINUXMUSTER"
"NV Hostname"="{$HostName$}"
"Hostname"="{$HostName$}"
"NV Domain"="LINUXMUSTER"

Damit stehen an beiden Stellen CurrentControlSet und ControlSet001 die
richtigen Werte.

Also: linbo 4.0.15 patched die Reg mit dem alten Patch korrekt und der
Client wird nicht beschädigt.
Domainlogin geht und Netzlaufwerke sind da.

Es sollte der Vorlagenpatch geändert werden, weil er die ControlSet001
Werte vermissen läßt.

Wenn ich Morgen Nacht Zeit habe spiele ich das in meiner Schule ein und
verteile das Image am Montag Morgen

Viele Grüße

Holger

2 „Gefällt mir“

Auch hier: hoffe, ihr kommt mit der Aufteilung zurecht, wenn das noch so Usus ist.
Ich komme nämlich mit der Verfolgung des update-threads nicht zu recht, wenn das alles da rein soll.

Vg, Tobias

2 „Gefällt mir“

Ja, aber ist nicht dringend. Der Regpatcher repariert das ja. Spricht was dagegen, den Milestone jetzt nach stable zu schieben?

VG, Thomas

Hallo Thomas,

Es sollte der Vorlagenpatch geändert werden, weil er die ControlSet001
Werte vermissen läßt.

Ja, aber ist nicht dringend. Der Regpatcher repariert das ja. Spricht
was dagegen, den Milestone jetzt nach stable zu schieben?

leider ja: siehe mein anderen Post.
Ausrollen in der Schule ist gescheitert :frowning:

LG

Holger

Hallo zusammen,

noch eine Ergänzung aus Versuchen heute bei mir mit einem frisch aktualisierten LMN7.1-Server. Bei mir sieht die Datei /srv/linbo/examples/win10.image.reg so aus:

Windows Registry Editor Version 5.00

; linuxmuster.net 7

; patches hostname, to be applied after every image sync

[HKEY_LOCAL_MACHINE\System\ControlSet001\Control\ComputerName\ActiveComputerName\]
"ComputerName"="{$HostName$}"

[HKEY_LOCAL_MACHINE\System\ControlSet001\Control\ComputerName\ComputerName\]
"ComputerName"="{$HostName$}"

[HKEY_LOCAL_MACHINE\System\ControlSet001\Services\Tcpip\Parameters\]
"Hostname"="{$HostName$}"
"NV Hostname"="{$HostName$}"

; add your custom registry patches below

Die funktionierte (ergänzt um die Zeilen

:setzt den Domänennamen richtig
[HKEY_LOCAL_MACHINE\System\ControlSet001\Services\Tcpip\Parameters]
"Domain"="<SAMBADOMAIN>"
[HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Windows\CurrentVersion\Policies\System]
"DefaultLogonDomain"="<SAMBADOMAIN>"

aus der Anleitung) nicht: der Hostname wurde nicht gesetzt. M.E. sind die ersten drei Einträge minimal falsch: der Backslash vor der schließenden Klammer ist zu viel.

Bei mir funktioniert es jetzt mit diesen drei Zeilen:

Windows Registry Editor Version 5.00

; linuxmuster.net 7

; patches hostname, to be applied after every image sync

[HKEY_LOCAL_MACHINE\System\ControlSet001\Control\ComputerName\ActiveComputerName]
"ComputerName"="{$HostName$}"

[HKEY_LOCAL_MACHINE\System\ControlSet001\Control\ComputerName\ComputerName]
"ComputerName"="{$HostName$}"

[HKEY_LOCAL_MACHINE\System\ControlSet001\Services\Tcpip\Parameters]
"Hostname"="{$HostName$}"
"NV Hostname"="{$HostName$}"

Installierte LMN-Paketversionen:

linuxmuster-base7/unbekannt,now 7.1.20-0 all  [installiert]
linuxmuster-linbo-gui7/unbekannt,now 7.0.6 all  [Installiert,automatisch]
linuxmuster-linbo7/unbekannt,now 4.0.38-0 all  [Installiert,automatisch]
linuxmuster-prepare/unbekannt,now 7.1.9-0 all  [installiert]
linuxmuster-webui7/unbekannt,now 7.1.38 all  [Installiert,automatisch]

Vielleicht was fürs nächste Update (oder habe ich irgendwo einen Fehler gemacht)?

Schönen Abend!
Jens

Hallo Jens,

mein aktueller Regpatch in der Schule sieht so aus:

Windows Registry Editor Version 5.00

; linuxmuster.net 7

; patches hostname, to be applied after every image sync

[HKEY_LOCAL_MACHINE\System\CurrentControlSet\Control\ComputerName\ActiveComputerName\]
"ComputerName"="{$HostName$}"

[HKEY_LOCAL_MACHINE\System\CurrentControlSet\Control\ComputerName\ComputerName\]
"ComputerName"="{$HostName$}"

[HKEY_LOCAL_MACHINE\System\CurrentControlSet\Services\Tcpip\Parameters\]
"Hostname"="{$HostName$}"
"NV Hostname"="{$HostName$}"

; add your custom registry patches below

und der funktioniert bei mir mit linbo 4.0.37

Welche Win10 Version hast du den im Image?
(meine ist schon ein paar Jahre alt …)

LG

Holger

Hallo Holger,

komisch. Ich hab das jetzt nochmal ausprobiert:

  • win10.reg auf dem Server zurück geändert (auf die Version mit „]“ am Ende der ersten drei Schlüssel)
  • SSD neu partitioniert und formatiert (damit sicher nichts „übrig geblieben“ ist)
  • Image synchronisiert und dann gestartet

Jetzt funktioniert, was gestern beim ersten Startup nicht funktioniert hat (und ich dem vermeintlichen Fehler „gefixt“ hatte). Kannst Du Dir das erklären?

Ich verwende gerade zum Ausprobieren Windows 10 Pro Version 21H2 (Build 19044.2075).

Schönen Tag!
Jens

Hallo Jens,

Jetzt funktioniert, was gestern beim ersten Startup nicht funktioniert
hat (und ich dem vermeintlichen Fehler „gefixt“ hatte). Kannst Du Dir
das erklären?

… leider nein: ich kann das nciht erklären: bin aber froh, dass es nun
so funktioniert.

Ich verwende gerade zum Ausprobieren Windows 10 Pro Version 21H2 (Build
19044.2075).

ich hatte ja gedacht, dass es an der viel neueren Win10 Version liegen
könnte: ist aber wohl auch nicht der Fall.
Alles in allem sehr seltsam, aber ich sehe das so: einmal ist keinmal,
zweimal ist Zufall und wenn es dreimal passiert, dann ist da was im Argen.

Dein Fall war jetzt der erste.

Viele Grüße

Holger

Hallo zusammen,

heute bin ich in LMN 7.2 auch über das von Jens in Post Lmn 7.1: Probleme mit Regpatches für Windows - #22 von Jens und dem Phänomen mit dem abschließenden \ vor ] gestossen. Trotz formatieren wurden die Windows 10 PC alle nicht umbenannt. Leider habe ich die Versionsnummer nicht zur Hand.

Wäre interessant, ob man diesen \ generell weglassen könnte und ob das dann bei anderen Windows Versionen trotzdem funktioniert.

Viele Grüße
Klaus