Hilfe bei VBScript Kopieren etc.

chrisxjr

Lieutenant
Registriert
Okt. 2006
Beiträge
696
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:
Code:
'**************************************************************************
'	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:
Code:
'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
 
Ist klar, CopyFile erwartet zwei Dateinamen, und nicht den Quell-Dateinamen und das Zielverzeichnis.
Es versucht eine Datei zu erstellen, die genauso heißt, wie das Verzeichnis, in das du kopieren willst...
Du brauchst also auch für die Ziele 8 Variablen nach diesem Schema

Code:
strFile1= runtime + "\log\ENW.log"
strDest1= strDest + "\ENW.log"

Zumindest vermute ich das mal ;-)
Wie es bei den "*.*"-Dateien ist weiß ich nicht... (edit: da braucht man es nicht ^^)

Edit:
Also so sollte es gehen (mit Datum/Zeit-abhängigen Ordnern
Code:
'**************************************************************************
'	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
wDateTime = Year(Now) & Right("00" & Month(Now), 2) & Right("00" & Day(Now), 2) + "_" + Right("00" & Hour(Now), 2) & Right("00" & Minute(Now), 2)
strFldr="C:\Dokumente und Einstellungen\je\Desktop\Backup Logs " + wDateTime

set objFSO=CreateObject("Scripting.FileSystemObject")

if Not objFSO.FolderExists(strFldr) Then 
  objFSO.CreateFolder(strFldr)
end if

set objFSO=Nothing

Dim runtime
runtime = "C:\Dokumente und Einstellungen\je\Desktop\BoFiT\BoFiT-Server\pm"

strDest=strFldr

'Dateien die kopiert werden soll
strFile1= runtime + "\log\ENW.log"
strDest1= strDest + "\ENW.log"
strFile2= runtime + "\log\PMBeenden.log"
strDest2= strDest + "\PMBeenden.log"
strFile3= runtime + "\log\PMSystem.log"
strDest3= strDest + "\PMSystem.log"
strFile4= runtime + "\log\PMServerService_app.log"
strDest4= strDest + "\PMServerService_app.log"
strFile5= runtime + "\log\PMServerService.log"
strDest5= runtime + "\PMServerService.log"
strFile6= runtime + "\shark\logs\*.*"
strFile7= runtime + "\export\log\*.*"
strFile8= runtime + "\import\log\*.*"

'Ordner in dem die Datei kopiert werden soll

set objFSO1=CreateObject("Scripting.FileSystemObject")

'Setzen des Parameters auf TRUE wenn eine 
'existierende Datei überschrieben werden soll.
objFSO1.CopyFile strFile1,strDest1,TRUE
objFSO1.CopyFile strFile2,strDest2,TRUE
objFSO1.CopyFile strFile3,strDest3,TRUE
objFSO1.CopyFile strFile4,strDest4,TRUE
objFSO1.CopyFile strFile5,strDest5,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!"
 
Zuletzt bearbeitet:
Hi,

ich bin dir zu 1000000000 fachem dank verpflichtet. Dank dem das du noch eingebaut hast das Datum und Uhrzeit im angelegeten Verzeichnis zu erkennen sind. Ist das Script perfekt!

Vielen Dank!:):)
 
Zurück
Oben