Add nginx.exe as Windows system service (like Apache)?

WindowsServiceWindows ServicesNginx

Windows Problem Overview


I set up NGINX as a front end server for static content and I use Apache as a back-end server for other thing.

The thing is I can't find a logical answer that allows me to make nginx.exe a Windows system service (like my Apache).

Any come across an answer to this?

Windows Solutions


Solution 1 - Windows

How to do it with Windows Service Wrapper

(Note: There are easier alternatives by now - see also solutions described here below using chocolatey package manager by suneg and using NSSM directly from Adamy)

  1. Download the latest version of Windows Service Wrapper via github or nuget.
  • Current version as of this writing is v2.2.0
  • Since v2.x executables for .NET2.0 and .NET4.0 are available - others only on demand.
  1. Rename winsw-*.exe to something like nginxservice.exe.
  • This is the name that will show up for the process that owns your nginx process.
  1. Place an XML file next to the exe with the same base name, e.g. nginxservice.xml. The contents should be like below (verify your nginx location).

     <service>
       <id>nginx</id>
       <name>nginx</name>
       <description>nginx</description>
       <executable>c:\nginx\nginx.exe</executable>
       <logpath>c:\nginx\</logpath>
       <logmode>roll</logmode>
       <depend></depend>
       <startargument>-p</startargument>
       <startargument>c:\nginx</startargument>
       <stopexecutable>c:\nginx\nginx.exe</stopexecutable>
       <stopargument>-p</stopargument>
       <stopargument>c:\nginx</stopargument>
       <stopargument>-s</stopargument>
       <stopargument>stop</stopargument>
     </service>
    
  1. Run the command nginxservice.exe install as administrator.

You will now have an nginx service in your Services! (It is set to start automatically on boot; if you want to start your server, you must manually start the service (net start nginx).)


Detailed description of correctly setting up nginx as a Windows Service: http://web.archive.org/web/20150819035021/http://misterdai.yougeezer.co.uk/posts/2009/10/16/nginx-windows-service/

Additional info not contained in above blog post:

You can find the latest version of the Windows Service Wrapper also via this Maven Repository: http://repo.jenkins-ci.org

Examples for Maven + Gradle:

<dependency>
    <groupId>com.sun.winsw</groupId>
    <artifactId>winsw</artifactId>
    <version>2.2.0</version>
    <classifier>bin</classifier>
    <packaging>exe</packaging>
</dependency>

<repository>
    <id>jenkinsci</id>
    <name>jenkinsci-releases</name>
    <url>http://repo.jenkins-ci.org/releases</url>
</repository>

compile "com.sun.winsw:winsw:2.2.0"

repositories {
    mavenCentral()
    maven { url http://repo.jenkins-ci.org/releases }
}

Solution 2 - Windows

Download NSSM form http://nssm.cc/download . "Run %NSSM_HOME%\nssm.exe install “Nginx”"

Select the Nginx executable in the NSSM dialog, then OK. Go to Services and start the new created service "Nginx", done.

Solution 3 - Windows

> You can using start.bat and stop.bat to realize the same effect.

start.bat

@ECHO OFF
REM Start Nginx
tasklist /FI "IMAGENAME eq nginx.exe" 2>NUL | find /I /N "nginx.exe">NUL
IF NOT "%ERRORLEVEL%"=="0" (
   REM Nginx is NOT running, so start it
   c:
   cd \nginx
   start nginx.exe
   ECHO Nginx started.
) else (
   ECHO Nginx is already running.
)

stop.bat

@ECHO OFF
REM Stop Nginx
tasklist /FI "IMAGENAME eq nginx.exe" 2>NUL | find /I /N "nginx.exe">NUL
IF "%ERRORLEVEL%"=="0" (
   REM Nginx is currently running, so quit it
   c:
   cd \nginx
   nginx.exe -s quit
   ECHO Nginx quit issued.
) else (
   ECHO Nginx is not currently running.
)

Solution 4 - Windows

SC.EXE will only work for executables that already support the Windows Services API and can respond properly to start and stop requests from the Services Control Manager (SCM). Other regular applications, not specifically written as a service, will simply fail to start (usually with error 1053)...

For those exe's, you need a "service wrapper" -- a small utility that can accept the start/stop commands from the SCM and run/terminate your application accordingly. Microsoft provides Srvany (which is free yet very basic), but there are several other free and commercial alternatives.

BTW, you should check out this guide showing how to run Nginix as a service, especially step 7 which discusses how to stop Nginix properly. Not every wrapper will support that functionality (Srvany doesn't)...

Solution 5 - Windows

The easiest way I've found, was using the Chocolatey package manager.

Once Chocolatey is installed, you open an administrative prompt and type:

choco install nginx

You now have a Windows service named 'nginx' running.

Solution 6 - Windows

NSSM is the best tool to run Nginx as a service.
If you do not want to use any external 3rd party software then you can implement any of these two methods.

  • Windows Task Scheduler
  • Windows startup shortcut

Windows Task Scheduler

  • As mentioned in this answer prepare one start.bat file.
  • Put this file where nginx.exe is present.
  • Open windows task scheduler and set up the task as described in this answer to run it indefinitely.
  • Do not forget to run this task as the highest privilege with the system account, more details can be found here.
  • Make the task to start daily at a certain time, through the bat file it will check whether the service is already running to avoid creating multiple nginx.exe instances.
  • If due to some reason Nginx shuts down, within 5 minutes it will start.

Windows Startup shortcut

  • Create one shortcut of nginx.exe and put it in the startup folder of Windows.

  • Follow this answer to find your startup location.

  • Nginx will run automatically whenever you log in to the system.

  • This one is the easiest. However, it is dependent on user profile i.e. if you are running Nginx on a server, it will run only for your user account, when you log off it stops.

  • This is ideal for dev environment.

Solution 7 - Windows

Official nginx wiki referes on winginx for this purpose. It builds exe-installer in linux environment. Process looks like this:

sudo apt-get install nsis make
wget https://github.com/InvGate/winginx/archive/master.zip
unzip master.zip
cd winginx-master/
make
ls -lh ./build/nginx-service.exe

To get actual versions you should specify them in Makefile.

Solution 8 - Windows

Download zip file from here.

Extract nginx-service.exe from winginx\build and run it.

Solution 9 - Windows

Rather than turning nginx into a service, or using CMD to start a process, which really doesn't seem to work. I found that Powershell makes it easy to startup nginx as a detached process. I've combined starting nginx with PHP. Below is the script, named "start-nginx.ps1"

$fcgiPort = "127.0.0.1:9000"
$PHPini = "c:\php\php.ini"

$ErrorActionPreference = "SilentlyContinue"

function restart { 
Push-Location /nginx
Stop-Process -Force -Name nginx 
Start-Process ./nginx.exe   -WindowStyle Hidden 

Stop-Process -Force -Name php-cgi
Start-Process  "c:\php\php-cgi.exe" -ArgumentList ("-b" + $fcgiPort  +  " -c "  +  $PHPini)   -WindowStyle Hidden 
Pop-Location
}

restart

This script can be executed from any directory, but needs to be customized for where your nginx installation is located.

This script includes a silent attempt to kill nginx and PHP before launching both.

Windows systems are supposed to recognize ".ps1" files as powershell, even in the CMD prompt.

I created another small script to kill the running processes, which simply removes the "start-process" lines from this file.

To run at startup, I used the win-R command to navigate to the directory shell:startup

Placing a shortcut to the startup script in this directory, nginx starts at boot!

Powershell also includes a much more sophisticated ability to schedule tasks, and it is possible to schedule this script to run at startup. See This Link

From the article:

 >powershell

 $trigger = New-JobTrigger -AtStartup -RandomDelay 00:00:30
 Register-ScheduledJob -Trigger $trigger -FilePath $HOME/start-nginx.ps1 -Name startNginx

Combined, I think this approach gets you everything you'd need from an nginx windows service and doesn't require any third-party applications.

Attributions

All content for this solution is sourced from the original question on Stackoverflow.

The content on this page is licensed under the Attribution-ShareAlike 4.0 International (CC BY-SA 4.0) license.

Content TypeOriginal AuthorOriginal Content on Stackoverflow
Questionuser1305810View Question on Stackoverflow
Solution 1 - WindowsJörgView Answer on Stackoverflow
Solution 2 - WindowsAdamyView Answer on Stackoverflow
Solution 3 - WindowsxgqfrmsView Answer on Stackoverflow
Solution 4 - WindowsCoreTechView Answer on Stackoverflow
Solution 5 - WindowssunegView Answer on Stackoverflow
Solution 6 - WindowsSoumendraView Answer on Stackoverflow
Solution 7 - Windowsuser3132194View Answer on Stackoverflow
Solution 8 - WindowsDileepaView Answer on Stackoverflow
Solution 9 - WindowssdwView Answer on Stackoverflow