Changes between Initial Version and Version 1 of Windows_startstop_Service

01/27/12 09:33:16 (10 years ago)



  • Windows_startstop_Service

    v1 v1  
     2Earthworm Windows Service 
     4(last revised 11 September, 2009) 
     5Readme for startstop_service 
     8Service functionality added by: 
     9Mark Morrison 
     10USGS - Golden, CO 
     12(Some additional edits or comments in these docs by Stefan Lisowski) 
     14Setup of startstop_service (Follow these instructions carefully.) 
     17startstop_service is identical to the old startstop_nt, except that it runs as a Windows service. This means that the parameters are all the same - read from startstop_nt.d - but that startstop isn't just executed from a command window or via the scheduler. Note that this version is taken from startstop_nt, so I haven't compiled or tested any of this under Solaris or other systems. I believe it's generally felt, however, that these modifications don't apply to Solaris. 
     19To install startstop_service as a service, do the following: 
     21- Open a command window. Switch to the directory containing the startstop executable (if it's not already in the Windows path). 
     23- Type: startstop_service -install 
     24This will install the service. You should get a message saying that installation was successful. 
     26- Open the Services Control Panel. (It's under Control Panel->Administrative Tools->Services.) You should see something listed as "Earthworm start-stop". Verify that this service is set to run in Automatic mode (meaning it automatically starts after a reboot, without waiting for user intervention.) 
     28- By default, startstop is set to run as the "Local Service" account. We need to change this to run as the Administrator, or else any Earthworm rings won't be accessible to other users, and typing "status" won't work. To change the user the service runs under, Select the Properties of the startstop service (double-clicking or selecting Properties from the toolbar). Select the Log On tab, select This account, and select Browse. For Win2000 machines, select the Administrator account from the list, then click OK. Type in the password twice, and click OK again. For WinXP machines, select Advanced, then click Find Now. The listbox at the bottom should show all the users locally set up on that computer. Select the Administrator, then click OK twice. Now type in the Administrator password twice, then click OK again. 
     30NOTE: This whole rigamarole means that whenever the Administrator password is changed on a machine running startstop, the password must be changed again from the Services control panel. 
     32- There's no way I've been able to find that allows environment variables to be loaded via ew_nt.cmd (or a similar file) before startstop runs. So, any environment variables required for Earthworm functionality have to be loaded systemwide before starting the startstop service. To set environment variables, select the System control panel, select the Advanced tab, and select Environment Variables. Under the "System variables" window (NOT the "user variables for XXX User" window), make sure that any environment variables you'll need are defined here. A typical subset may include: 
     33- EW_HOME 
     35- EW_LOG 
     36- EW_PARAMS 
     37- SYS_NAME 
     38- TZ 
     39In addition, make sure \earthworm\bin directory (or whichever directory contains your earthworm binaries) is included somewhere in the "Path" variable. Once these are set, click OK, and reboot the machine. 
     41(Note that setting the Timezone Here to UTC may affect how other non-earthworm applications on your machine keep track of and display time.) 
     43- If you didn't have to change any environment variables and reboot, you can now start the startstop service by clicking Start from the Services Control Panel (the triangle "Play" button). If you reboot, the service will start automatically. 
     45Notes on running startstop_service 
     48Apart from running as a Windows service, startstop_service behaves just as startstop_nt. One interesting note is that if you select startstop_service in the Services control panel and click Stop or Restart, then startstop will attempt to shut down all applications attached to its ring via an Earthworm TERMINATE message. 
     50If you want to look at the Status of Earthworm, or if you want to Restart an Earthworm module or Reconfigure Earthworm's modules and rings, and you aren't logged in as Administrator, you can either use StartstopConsole, or you can do the following if you know the Administrator password: (Instructions for Windows XP, but may work on other versions of Windows. See below for Vista.): 
     51- Go to the Windows Start menu, and choose "Run" 
     52- Type the following: 
     54runas /user:YOUR_MACHINE_NAME_HERE\administrator cmd 
     56- This will open up a command window which should be able to connect to the running Earthworm, and thus allow you to type "restart", "reconfigure", "status", "pidpau" or "pau" here. 
     58- To view what's going on in Vista or Windows Server 2008 
     60StartstopConsole won't work in Vista, nor will "runas" give you access to the session zero. 
     61- Beforehand, add 'cmd' as a line in your startstop_nt.d with a NewConsole, and reboot so the service starts this up. 
     62- if you're not at the machine, make a remote desktop connection as whatever user you like 
     63- open a command prompt 
     64- if you're not running as administrator, in the command prompt type: 
     65          runas /user:YOUR_MACHINE_NAME_HERE\administrator cmd 
     66              enter the admin password 
     67- in the new administrator command prompt that comes up type: 
     68          sc config ui0detect start= auto 
     69          sc start ui0detect 
     70(if you get a Interactive Services Detection dialog, you can choose "Ask me later) 
     72Once you've done all of the above, you can access session zero. The machine could be rebooted, different users couldlog in, etc. For any user to access startstop_service's session zero: 
     74- in a command prompt window now you can type: 
     75          rundll32 winsta.dll,WinStationSwitchToServicesSession 
     76This will switch you to console 0. If you added a cmd prompt to startstop_nt.d, you should see it here now, and can type "status" or whatever. 
     78That's a bit of a handful to type. Since your earthworm bin directory is already in your Windows path, you can cd to that bin directory and do something like: 
     79          echo rundll32 winsta.dll,WinStationSwitchToServicesSession > session0.bat 
     80So now you can just type "session0" at a command prompt to get to the startstop session. 
     82Note that this means that ANY user of the system will be able to get a prompt with administrator privileges. I this essentially the same power one has with startstopconsole which has been part of Earthworm for a while. 
     84(This was all tested with Vista. It _should_ work with Windows Server 2008 too, but hasn't been tested there yet. If you do it successfully or unsuccessfully please let us know.) 
     86With 2003 Server 
     88How to Connect to the Console Session 
     92When you connect to the console session of a Windows Server 2003-based server, no other user has to be already logged on to the console session. Even if no one is logged on to the console, you are logged on just as if you were sitting at the physical console. 
     94To connect from the remote Windows Server 2003-based computer, open a command prompt, and then type the following command: 
     96mstsc -v:servername /F -console 
     98where mstsc is the Remote Desktop connection executable file, -v indicates a server to connect to, /F indicates full screen mode, and -console is the instruction to connect to the console session. 
     100Removing startstop_service 
     103If you ever need to remove startstop_service from your machine, first stop the service (as above), then open a command window and type: startstop_service -uninstall 
     104You should also perform this step if you ever need to move the startstop binary to another directory on your hard drive; otherwise, Windows will not know where to find the executable.