Hi Igor Neyman, Yeah - I agree with you. That needs to be changed.
But, I see scope of the improvement in the script, you shared. That is - what if the service never started, then it will never return from the script. We will do the required changes, Thanks for your inputs. -- Thanks & Regards, Ashesh Vashi EnterpriseDB INDIA: Enterprise Postgres Company<http://www.enterprisedb.com> *http://www.linkedin.com/in/asheshvashi*<http://www.linkedin.com/in/asheshvashi> On Tue, Oct 12, 2010 at 11:56 PM, Igor Neyman <iney...@perceptron.com>wrote: > This message is CCed to Dave Page, because his name is found in > startserver.vbs script discussed later. > > I think there is a (minor?) problem with 8.4.5 Windows installer from > EnterpriseDB (probably othere releases as well - didn't check). > > Here is an abstract from the "tail" of my installation log file: > > /*********************************************************/ > Starting the database server... > Executing cscript //NoLogo "C:\VectorDB\installer\server\startserver.vbs" > PostgreSQL > Script exit code: 0 > > Script output: > Starting PostgreSQL > Service PostgreSQL started successfully > startserver.vbs ran to completion > > Script stderr: > > > Loading additional SQL modules... > Executing cscript //NoLogo "C:\VectorDB\installer\server\loadmodules.vbs" > "postgres" "****" "C:\VectorDB" "C:\VectorDB\data" 5432 "1" > Script exit code: 2 > > Script output: > Installing pl/pgsql in the template1 databases... > Start DoCmd("C:\VectorDB\bin\psql.exe" -p 5432 -U postgres -c "CREATE > LANGUAGE plpgsql;" template1)... > Executing 'C:\Users\vmwin7\AppData\Local\Temp\rad87CE4.bat'... > psql: FATAL: the database system is starting up > > End DoCmd() > Failed to install pl/pgsql in the 'template1' database > Installing the adminpack module in the postgres database... > Start DoCmd("C:\VectorDB\bin\psql.exe" -p 5432 -U postgres -f > "C:\VectorDB\share\contrib\adminpack.sql" postgres)... > Executing 'C:\Users\vmwin7\AppData\Local\Temp\rad87CE4.bat'... > psql: FATAL: the database system is starting up > > End DoCmd() > Failed to install the 'adminpack' module in the 'postgres' database > loadmodules.vbs ran to completion > > Script stderr: > Program ended with an error exit code > /*********************************************************/ > > > According to this code in startserver.vbs: > > /**********************/ > ' Find the service > Set objService = objWMIService.Get("Win32_Service.Name='" & strServiceName > & "'") > > ' Start it (them) > If objService.State <> "Running" Then > WScript.Echo "Starting " & objService.Name > iRetval = objService.StartService() > If iRetval = 0 Then > WScript.Echo "Service " & objService.Name & " started successfully" > Else > WScript.Echo "Failed to start the database server (" & iRetVal & > ")" > WScript.Quit 1 > End If > Else > WScript.Echo "Service " & objService.Name & " is already running" > End If > /**********************/ > > here is what happened on my system: > 1. startserver.vbs sends a signal to Postgresql service to start: "iRetval > = objService.StartService()" > 2. Postgres accepted the signal and set iRetval = 0, but didn't start yet > (admittedely machine was busy doing something else at the same time) > 3. VB script assumes that service is started (without actually checking > it's status) and proceeds trying to connect to PG (while running next > installation VB script - loadmodules.vbs, according to installation log). > > I realize it's a rare situation when machine will be busy with something > else while installing Postgres. > But, it still can happen, and "stricter" code could avoid this problem:6 > > > /**********************/ > ' Find the service > Set objService = objWMIService.Get("Win32_Service.Name='" & strServiceName > & "'") > > ' Start it (them) > If objService.State <> "Running" Then > WScript.Echo "Starting " & objService.Name > iRetval = objService.StartService() > If iRetval = 0 Then > Do Until objService.State = "Running" > WScript.Sleep(5000) > Loop > WScript.Echo "Service " & objService.Name & " started successfully" > Else > WScript.Echo "Failed to start the database server (" & iRetVal & > ")" > WScript.Quit 1 > End If > Else > WScript.Echo "Service " & objService.Name & " is already running" > End If > /**********************/ > > If it really waits for service to start, checking it's status in a loop. > Same status check probably needed earlier in the script, where it's trying > to start dependencies services. > > > oh, and I have to admit that I have zero VB scripting experience, so please > correct me if my code modification is wrong. > > Regards, > Igor Neyman > > >