Можно установить репликацию с помощью кода, это было сделано как часть проекта, на котором я был несколько лет назад, таким образом, я не могу помнить деталь. Но basicly, мы устанавливаем издателя и подписчика, использующего код от C#, я думаю по большей части, что он называл SP в сервере, чтобы сделать это.
Так безотносительно кода Вы используете для установки базы данных, необходимо затем смочь добавить в коде после этого для установки репликации. Но это должно будет быть сделано путем создания собственных хранимых процедур к стежку basicly вместе, что необходимо сделать.
Я встретился с этим прежде и в то время как я знаю, как сделать это через PowerShell, Вы могли бы хотеть попробовать это если Ваш поиск VBS.
Взятый из http://www.wisesoft.co.uk/scripts/vbscript_rename_domain_computers_from_csv_file.aspx
OPTION EXPLICIT
CONST adOpenStatic = 3
CONST adLockOptimistic = 3
CONST adCmdText = &H0001
CONST intWindowStyle = 7
CONST blnWait = TRUE
DIM strCSVFolder,strCSVFile,strNetDomParams
DIM objShell,cn,rs
' ************** Setup **************
' Folder where CSV File is located
' CSV file should have 1st field = oldname, 2nd field = newname with no header row
strCSVFolder = "C:\Temp\"
' CSV filename
strCSVFile = "test.csv"
' Additional parameters to pass to NetDom command
strNetDomParams = " /userd:DOMAIN\ADMINISTRATOR /passwordd:PASSWORD /usero:DOMAIN\ADMINISTRATOR /passwordo:PASSWORD /force "
'************************************
SET objShell = wscript.CREATEOBJECT("wscript.shell")
' Setup ADO Connection to CSV file
SET cn = CREATEOBJECT("ADODB.Connection")
SET rs = CREATEOBJECT("ADODB.Recordset")
cn.Open "Provider=Microsoft.Jet.OLEDB.4.0;" & _
"Data Source=" & strCSVFolder & ";" & _
"Extended Properties=""text;HDR=NO;FMT=Delimited"""
rs.Open "SELECT * FROM [" & strCSVFile & "]", _
cn, adOpenStatic, adLockOptimistic, adCmdText
DO until rs.eof
DIM strOldName, strNewName, strCmd,intReturn
strOldName = rs(0)
strNewName = rs(1)
strCmd = "cmd.exe /C netdom renamecomputer " & strOldName & " /newname:" & strNewName & strNetDomParams
intReturn = objShell.Run(strCmd,intWindowStyle,blnWait)
IF intReturn = 0 THEN
wscript.echo "Renamed '" & strOldName & "' to '" & strNewName & "'"
ELSE
wscript.echo "Error renaming '" & strOldName & "' to '" & strNewName & "'"
END IF
rs.movenext
LOOP
Выход из оболочки к cmd строке всегда является болью (плюс Вы, должен удостовериться, что netdom там), имея дело с кавычками в VB и что нет.
Вероятно, легче просто пойти собственный компонент и использовать WMI, и в качестве награды должен работать больше всего где угодно. Это присоединится к домену также (можно удалить ту часть), но Вы могли просто оставить переименовать часть и часть перезагрузки, и необходимо быть хорошими.
Это не тестируется код, который я снял с другого сайта.
Const JOIN_DOMAIN = 1
Const ACCT_CREATE = 2
Dim sCmpName
Dim sUser, sPassword, sDomain, sOU
sUser = "<domainuserid>"
sPassword = "<domainpassword>"
sDomain = "<mydomain>"
sOU = "<ou=myou,dc=mydomain,dc=com>"
sCmpName = InputBox("Enter the new computer name:", "Computer Name")
If sCmpName = "" Then
Wscript.Echo "Exiting script."
Wscript.Quit
End If
Dim oWMI, oCmp, oOS, sReturn
Set oWMI = GetObject("winmgmts:\\.\root\cimv2")
For Each oCmp in oWMI.InstancesOf("Win32_ComputerSystem")
sReturn = oCmp.Rename(sCmpName)
If sReturn <> 0 Then
Wscript.Echo "Rename failed. Error = " & Err.Number & _
vbcrlf & "Exiting script."
Else
Wscript.Echo "Rename successful."
sReturn = oCmp.JoinDomainOrWorkgroup(sDomain, sPassword, _
sDomain & "\" & sUser, sOU, JOIN_DOMAIN+ACCT_CREATE)
If sReturn <> 0 Then
Wscript.Echo "Join domain failed. Error = " & Err.Number & _
vbcrlf & "Exiting script."
Else
Wscript.Echo "Join domain successful."
End If
Wscript.Echo "Rebooting computer..."
For Each oOS in oWMI.InstancesOf("Win32_OperatingSystem")
sReturn = oOS.Reboot
Next
End If
Next