linux添加nginx启动脚本_Linux Ubuntu 16.04 安装 Nginx 并配置开机启动脚本

在Ubuntu下安装Nginx有以下方法,但是如果想要安装最新版本的就必须下载源码进行编译安装,因为apt源安装的版本比较老。

APT 源安装

首先使用最简单的安装方式进行 nginx 的安装:

sudo apt-get install nginx

安装好的文件位置:

/usr/sbin/nginx:主程序

/etc/nginx:存放配置文件

/usr/share/nginx:存放静态文件

/var/log/nginx:存放日志

从上面的根目录文件夹可以知道,Linux 系统的配置文件一般放在 /etc,日志一般放在 /var/log,运行的程序一般放在 /usr/sbin 或者 /usr/bin。

如果你不清楚这些文件都放在哪里,可以直接访问 /etc/nginx/nginx.conf 配置文件,一般这些目录都会在配置文件中配置好的。

一般,apt 安装好 nginx 并启动后, nginx 会默认加载这个配置文件,如果有多份配置文件,而你不确定是加载哪个的话,可以使用命令 sudo nginx -t 或者 ps -ef | grep nginx 查看输出的日志,它会清楚的告诉你使用了哪个 conf 配置文件。

然后通过这种方式安装的,会自动创建服务,会自动在 /etc/init.d/nginx 新建服务脚本,然后就可以使用 sudo service nginx {start|stop|restart|reload|force-reload|status|configtest|rotate|upgrade} 的命令启动。

但是,如果你使用 systemctl 管理服务的话,比如要查看 nginx 服务状态, 可以执行命令 systemctl status nginx.service 来查看。

源码包编译安装

这种方式可以自定安装指定的模块和各种配置路径,方式更灵活。并且可以选择最新的版本来安装。

准备依赖环境

安装 gcc g++ 的依赖库

sudo apt-get install build-essential

sudo apt-get install libtool

sudo apt-get update

sudo apt-get install libpcre3 libpcre3-dev

sudo apt-get install zlib1g-dev

安装 SSL 依赖库(16.04默认已经安装了)

sudo apt-get install openssl

安装 Nginx

# 下载最新稳定版本:

wget http://nginx.org/download/nginx-1.14.0.tar.gz

# 解压:

tar -zxvf nginx-1.14.0.tar.gz

# 进入解压目录:

cd nginx-1.14.0

# 配置,这样最后nginx的全部安装文件,包括配置文件,会安装到/usr/local/nginx目录中:

./configure --prefix=/usr/local/nginx

# 编译:

make

# 安装:

sudo make install

# 启动:

sudo /usr/local/nginx/sbin/nginx -c /usr/local/nginx/conf/nginx.conf

# 注意:-c 指定配置文件的路径,不加的话,nginx会自动加载默认路径的配置文件,可以通过-h查看帮助命令。

# 查看进程:

ps -ef | grep nginx

为了可以在终端中直接使用 nginx 命令,需要建立软链接:

sudo ln -s /usr/local/nginx/sbin/nginx /usr/bin/nginx

现在就可以不用路径直接使用 nginx 启动。

配置开机启动服务

目前 linux 中管理服务有 service 和 systemctl 两种方式, service 是比较老牌和流行的管理方式,不过目前各大 linux 发行版最新版本基本都切换到 systemd(systemctl) 了,这里我提供两种方式供大家选择使用。

service 脚本

在 /etc/init.d/ 下创建 nginx 文件,sudo vim /etc/init.d/nginx,内容如下:

#!/bin/sh

### BEGIN INIT INFO

# Provides: nginx

# Required-Start: $local_fs $remote_fs $network $syslog $named

# Required-Stop: $local_fs $remote_fs $network $syslog $named

# Default-Start: 2 3 4 5

# Default-Stop: 0 1 6

# Short-Description: starts the nginx web server

# Description: starts nginx using start-stop-daemon

### END INIT INFO

PATH=/usr/local/sbin:/usr/local/bin:/sbin:/bin:/usr/sbin:/usr/bin

DAEMON=/usr/local/nginx/sbin/nginx

NAME=nginx

DESC=nginx

# Include nginx defaults if available

if [ -r /etc/default/nginx ]; then

. /etc/default/nginx

fi

STOP_SCHEDULE="${STOP_SCHEDULE:-QUIT/5/TERM/5/KILL/5}"

test -x $DAEMON || exit 0

. /lib/init/vars.sh

. /lib/lsb/init-functions

# Try to extract nginx pidfile

PID=$(cat /usr/local/nginx/conf/nginx.conf | grep -Ev '^\s*#' | awk 'BEGIN { RS="[;{}]" } { if ($1 == "pid") print $2 }' | head -n1)

if [ -z "$PID" ]; then

PID=/run/nginx.pid

fi

if [ -n "$ULIMIT" ]; then

# Set ulimit if it is set in /etc/default/nginx

ulimit $ULIMIT

fi

start_nginx() {

# Start the daemon/service

#

# Returns:

# 0 if daemon has been started

# 1 if daemon was already running

# 2 if daemon could not be started

start-stop-daemon --start --quiet --pidfile $PID --exec $DAEMON --test > /dev/null \

|| return 1

start-stop-daemon --start --quiet --pidfile $PID --exec $DAEMON -- \

$DAEMON_OPTS 2>/dev/null \

|| return 2

}

test_config() {

# Test the nginx configuration

$DAEMON -t $DAEMON_OPTS >/dev/null 2>&1

}

stop_nginx() {

# Stops the daemon/service

#

# Return

# 0 if daemon has been stopped

# 1 if daemon was already stopped

# 2 if daemon could not be stopped

# other if a failure occurred

start-stop-daemon --stop --quiet --retry=$STOP_SCHEDULE --pidfile $PID --name $NAME

RETVAL="$?"

sleep 1

return "$RETVAL"

}

reload_nginx() {

# Function that sends a SIGHUP to the daemon/service

start-stop-daemon --stop --signal HUP --quiet --pidfile $PID --name $NAME

return 0

}

rotate_logs() {

# Rotate log files

start-stop-daemon --stop --signal USR1 --quiet --pidfile $PID --name $NAME

return 0

}

upgrade_nginx() {

# Online upgrade nginx executable

# http://nginx.org/en/docs/control.html

#

# Return

# 0 if nginx has been successfully upgraded

# 1 if nginx is not running

# 2 if the pid files were not created on time

# 3 if the old master could not be killed

if start-stop-daemon --stop --signal USR2 --quiet --pidfile $PID --name $NAME; then

# Wait for both old and new master to write their pid file

while [ ! -s "${PID}.oldbin" ] || [ ! -s "${PID}" ]; do

cnt=`expr $cnt + 1`

if [ $cnt -gt 10 ]; then

return 2

fi

sleep 1

done

# Everything is ready, gracefully stop the old master

if start-stop-daemon --stop --signal QUIT --quiet --pidfile "${PID}.oldbin" --name $NAME; then

return 0

else

return 3

fi

else

return 1

fi

}

case "$1" in

start)

log_daemon_msg "Starting $DESC" "$NAME"

start_nginx

case "$?" in

0|1) log_end_msg 0 ;;

2) log_end_msg 1 ;;

esac

;;

stop)

log_daemon_msg "Stopping $DESC" "$NAME"

stop_nginx

case "$?" in

0|1) log_end_msg 0 ;;

2) log_end_msg 1 ;;

esac

;;

restart)

log_daemon_msg "Restarting $DESC" "$NAME"

# Check configuration before stopping nginx

if ! test_config; then

log_end_msg 1 # Configuration error

exit $?

fi

stop_nginx

case "$?" in

0|1)

start_nginx

case "$?" in

0) log_end_msg 0 ;;

1) log_end_msg 1 ;; # Old process is still running

*) log_end_msg 1 ;; # Failed to start

esac

;;

*)

# Failed to stop

log_end_msg 1

;;

esac

;;

reload|force-reload)

log_daemon_msg "Reloading $DESC configuration" "$NAME"

# Check configuration before stopping nginx

#

# This is not entirely correct since the on-disk nginx binary

# may differ from the in-memory one, but that's not common.

# We prefer to check the configuration and return an error

# to the administrator.

if ! test_config; then

log_end_msg 1 # Configuration error

exit $?

fi

reload_nginx

log_end_msg $?

;;

configtest|testconfig)

log_daemon_msg "Testing $DESC configuration"

test_config

log_end_msg $?

;;

status)

status_of_proc -p $PID "$DAEMON" "$NAME" && exit 0 || exit $?

;;

upgrade)

log_daemon_msg "Upgrading binary" "$NAME"

upgrade_nginx

log_end_msg $?

;;

rotate)

log_daemon_msg "Re-opening $DESC log files" "$NAME"

rotate_logs

log_end_msg $?

;;

*)

echo "Usage: $NAME {start|stop|restart|reload|force-reload|status|configtest|rotate|upgrade}" >&2

exit 3

;;

esac

注意其中的 /usr/local/nginx 路径修改为你在编译时候 configure --prefix 中提供的安装目录。

#设置服务脚本有执行权限

sudo chmod +x /etc/init.d/nginx

#注册服务

cd /etc/init.d/

sudo update-rc.d nginx defaults

不出意外的话,现在基本上就可以开机启动了,常用的命令如下:

sudo service nginx {start|stop|restart|reload|force-reload|status|configtest|rotate|upgrade}

systemctl 脚本

如果你的服务器使用 systemctl 管理,或者你不确定,并且如上脚本不能正常使用,报错信息里有提到 systemctl 等信息,那么或许你需要创建 systemd 脚本来管理。

在 /lib/systemd/system 下创建 nginx.service 文件,sudo vim /lib/systemd/system/nginx.service,内容如下:

[Unit]

Description=nginx stable last

After=syslog.target network.target remote-fs.target nss-lookup.target

[Service]

Type=forking

ExecStart=/usr/local/nginx/sbin/nginx -c /usr/local/nginx/conf/nginx.conf

ExecStop=/usr/local/nginx/sbin/nginx -s stop

ExecReload=/usr/local/nginx/sbin/nginx -s reload

ExecQuit=/usr/local/nginx/sbin/nginx -s quit

PrivateTmp=true

[Install]

WantedBy=multi-user.target

cd 到 /lib/systemd/system/ 目录,使用 systemctl enable nginx.service 启动脚本,这样就可以使用了,可用的命令包括:

systemctl {start|stop|reload|quit} nginx.service

小结

本文主要讲使用两种方式来安装配置 nginx,使用 apt 源来安装的话简单稳定,nginx 相对版本要旧一点,不过也没关系;使用源码编译安装需要一点耐心和技能,因为你不一定会很顺利的安装完,不过好处是可以定制环境,并且可以使用任意版本的 nginx。然后本文还提供了两种服务脚本。

希望对大家有所帮助。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值