Probleme bei VBscript Verzeichnis erstellen, Kopieren, Prozesse beenden
Hallo zusammen,
erstmal was das Script machen soll. Es soll als erstes einen definierten Ordner erstellen. Danach sollen aus einem Verzeichniss vordefinierte Log Dateieen in das grade erstellte Verzeichniss kopiert werden. Danach geht es weiter mit dem beenden verschiedener Prozesse. Und einer abschließenenden Message Box. Alle einzelnen Teile des Scripts hab ich schon getestet und bastel es jetzt zusammen.
Hier erstmal das Script:
Und nun mein Problem:
Das erstellen des Verzeichnisses ist kein Problem das funktioniert. Nur bei Zeile 50 Zeichen 1 gibts einen Fehler "Erlaubnis verweigert". Ich habe auf dem Rechner volle Administrator Rechte.
Das ist der Bereich ab der ersten Programm Zeile:
Weiß da jemand einen Rat?
Gruß
Christian
erstmal was das Script machen soll. Es soll als erstes einen definierten Ordner erstellen. Danach sollen aus einem Verzeichniss vordefinierte Log Dateieen in das grade erstellte Verzeichniss kopiert werden. Danach geht es weiter mit dem beenden verschiedener Prozesse. Und einer abschließenenden Message Box. Alle einzelnen Teile des Scripts hab ich schon getestet und bastel es jetzt zusammen.
Hier erstmal das Script:
'**************************************************************************
' File: Final_Script.vbs
'
' Autor: Christian Jerusalem
'
' Company: XX GmbH
'
' Comments: Final_Script XXl.
' Anlegen eines Backup Ordners, Transfer bzw. kopieren
' der Log Dateien in diesen Ordner.
' Ausgabe der Aufforderung Dienste zu beenden.
'**************************************************************************
'Ordner erstellen
dim objFSO
'File kopieren
Dim objFSO1
dim objFile
'zu erstellender Ordner
strFldr="C:\Dokumente und Einstellungen\je\Desktop\Backup Logs"
set objFSO=CreateObject("Scripting.FileSystemObject")
objFSO.CreateFolder(strFldr)
set objFSO=Nothing
Dim runtime
runtime = "C:\Dokumente und Einstellungen\je\Desktop\BoFiT\BoFiT-Server\pm"
'Dateien die kopiert werden soll
strFile1= runtime + "\log\ENW.log"
strFile2= runtime + "\log\PMBeenden.log"
strFile3= runtime + "\log\PMSystem.log"
strFile4= runtime + "\log\PMServerService_app.log"
strFile5= runtime + "\log\PMServerService.log"
strFile6= runtime + "\shark\logs\*.*"
strFile7= runtime + "\export\log\*.*"
strFile8= runtime + "\import\log\*.*"
'Ordner in dem die Datei kopiert werden soll
strDest="C:\Dokumente und Einstellungen\je\Desktop\Backup Logs"
set objFSO1=CreateObject("Scripting.FileSystemObject")
'Setzen des Parameters auf TRUE wenn eine
'existierende Datei überschrieben werden soll.
objFSO1.CopyFile strFile1,strDest,TRUE
objFSO1.CopyFile strFile2,strDest,TRUE
objFSO1.CopyFile strFile3,strDest,TRUE
objFSO1.CopyFile strFile4,strDest,TRUE
objFSO1.CopyFile strFile5,strDest,TRUE
objFSO1.CopyFile strFile6,strDest,TRUE
objFSO1.CopyFile strFile7,strDest,TRUE
objFSO1.CopyFile strFile8,strDest,TRUE
'Beenden der Prozesse
pc = "localhost"
programm = "'assembly_manager.exe'"
Set wmi = GetObject("winmgmts:" _
& "{impersonationLevel=impersonate}!\\" _
& pc & "\root\cimv2")
Set col = wmi.ExecQuery _
("Select * from Win32_Process Where Name = " & programm )
For Each obj in col
obj.Terminate()
Next
pc = "localhost"
programm = "'CIAO-Deamon.exe'"
Set wmi = GetObject("winmgmts:" _
& "{impersonationLevel=impersonate}!\\" _
& pc & "\root\cimv2")
Set col = wmi.ExecQuery _
("Select * from Win32_Process Where Name = " & programm )
For Each obj in col
obj.Terminate()
Next
pc = "localhost"
programm = "'Java.exe'"
Set wmi = GetObject("winmgmts:" _
& "{impersonationLevel=impersonate}!\\" _
& pc & "\root\cimv2")
Set col = wmi.ExecQuery _
("Select * from Win32_Process Where Name = " & programm )
For Each obj in col
obj.Terminate()
Next
pc = "localhost"
programm = "'Naming_Service.exe'"
Set wmi = GetObject("winmgmts:" _
& "{impersonationLevel=impersonate}!\\" _
& pc & "\root\cimv2")
Set col = wmi.ExecQuery _
("Select * from Win32_Process Where Name = " & programm )
For Each obj in col
obj.Terminate()
Next
pc = "localhost"
programm = "'PMServerService.exe'"
Set wmi = GetObject("winmgmts:" _
& "{impersonationLevel=impersonate}!\\" _
& pc & "\root\cimv2")
Set col = wmi.ExecQuery _
("Select * from Win32_Process Where Name = " & programm )
For Each obj in col
obj.Terminate()
Next
pc = "localhost"
programm = "'RTComponentServer.exe'"
Set wmi = GetObject("winmgmts:" _
& "{impersonationLevel=impersonate}!\\" _
& pc & "\root\cimv2")
Set col = wmi.ExecQuery _
("Select * from Win32_Process Where Name = " & programm )
For Each obj in col
obj.Terminate()
Next
Msgbox("BoFiT Prozesse beendet!")
'Ausgabe der Aufforderung die Dienste neu zu starten
MsgBox "Bitte starten Sie den BoFiT-PM-Server neu!"
'Ausgabe der Aufforderung die Dienste neu zu starten genauer Weg
MsgBox "Rufen Sie dafür in der Systemsteuerung die Cluster-Verwaltung auf und beenden Sie dort den BoFiT Server Dienst!"
Und nun mein Problem:
Das erstellen des Verzeichnisses ist kein Problem das funktioniert. Nur bei Zeile 50 Zeichen 1 gibts einen Fehler "Erlaubnis verweigert". Ich habe auf dem Rechner volle Administrator Rechte.
Das ist der Bereich ab der ersten Programm Zeile:
'Setzen des Parameters auf TRUE wenn eine
'existierende Datei überschrieben werden soll.
objFSO1.CopyFile strFile1,strDest,TRUE
objFSO1.CopyFile strFile2,strDest,TRUE
objFSO1.CopyFile strFile3,strDest,TRUE
objFSO1.CopyFile strFile4,strDest,TRUE
objFSO1.CopyFile strFile5,strDest,TRUE
objFSO1.CopyFile strFile6,strDest,TRUE
objFSO1.CopyFile strFile7,strDest,TRUE
objFSO1.CopyFile strFile8,strDest,TRUE
Weiß da jemand einen Rat?
Gruß
Christian
Bitte markiere auch die Kommentare, die zur Lösung des Beitrags beigetragen haben
Content-ID: 94326
Url: https://administrator.de/contentid/94326
Ausgedruckt am: 22.11.2024 um 21:11 Uhr
2 Kommentare
Neuester Kommentar
Hallo chris-jerusalem!
Wenn Du bei der Zielangabe "strDest" (entweder in Zeile 44 oder mit
jeweils bei den "CopyFile"-Anweisungen) an das Ende noch einen "\" setzt, sollte es gehen, da in diesem Fall das Ziel richtig als Ordner interpretiert wird - ohne "\" sieht VBS es als Dateipfad an und kann dann natürlich den Ordner nicht durch eine Datei ersetzen.
Grüße
bastla
Wenn Du bei der Zielangabe "strDest" (entweder in Zeile 44 oder mit
objFSO1.CopyFile strFile1,strDest & "\",TRUE
Grüße
bastla