当前位置: 澳门新濠3559 > 服务器运维 > 正文

最后将nginx添加到系统服务,下面记录了我的安装

时间:2019-10-20 09:52来源:服务器运维
三、Java运行环境之 cent os6.8 64位安装nginx,os6.8nginx 文章转载: 根据工作需要,现在需要安装nginx服务器,本来可以直接安装别人制作好的rpm包的,但是本着爱折腾和时刻尝鲜的精神,我

三、Java运行环境之 cent os6.8 64位安装nginx,os6.8nginx

文章转载:

根据工作需要,现在需要安装nginx服务器,本来可以直接安装别人制作好的rpm包的,但是本着爱折腾和时刻尝鲜的精神,我决定从官网下载最新的nginx源码来安装,下面记录了我的安装过程。

下面的安装假定是以root用户登录并执行
1.安装依赖库
这些依赖库主要有g 、gcc、openssl-devel、pcre-devel和zlib-devel 
yum -y install make gcc gcc-c glibc glibc-devel lsof   
yum -y install pcre pcre-devel  
yum -y install zlib zlib-devel  
yum -y install openssl openssl--devel 

2.下载源码包
cd /usr/local/src
wget -d ""
tar zxvf nginx-1.8.0.tar.gz
cd nginx-1.8.0
./configure --prefix=/usr/local/nginx --with-http_stub_status_module --with-http_realip_module --with-http_ssl_module 
make -j 4
make install

3.验证性启动nginx
注意,在没有设置nginx为系统服务之前,这里仅是验证性的启动测试。使用下面的命令查看nginx可执行程序的路径
whereis nginx
一般默认在/usr/local/nginx目录下面
ulimit -SHn 65535
/usr/local/nginx/sbin/nginx

4.添加nginx为系统服务
添加如下文件

vim /etc/init.d/nginx

[html] view plain copy

  1. #!/bin/sh  
  2. #  
  3. # nginx - this script starts and stops the nginx daemon  
  4. #  
  5. # chkconfig:   - 85 15  
  6. # description: Nginx is an HTTP(S) server, HTTP(S) reverse   
  7. #               proxy and IMAP/POP3 proxy server  
  8. # processname: nginx  
  9. # config:      /etc/nginx/nginx.conf  
  10. # config:      /etc/sysconfig/nginx  
  11. # pidfile:     /var/run/nginx.pid  
  12. # Source function library.  
  13. . /etc/rc.d/init.d/functions  
  14. # Source networking configuration.  
  15. . /etc/sysconfig/network  
  16. # Check that networking is up.  
  17. [ "$NETWORKING" = "no" ] && exit 0  
  18. nginx="/usr/local/nginx/sbin/nginx"  
  19. prog=$(basename $nginx)  
  20. NGINX_CONF_FILE="/usr/local/nginx/conf/nginx.conf"  
  21. [ -f /etc/sysconfig/nginx ] && . /etc/sysconfig/nginx  
  22. lockfile=/var/lock/subsys/nginx  
  23. start() {  
  24.     [ -x $nginx ] || exit 5  
  25.     [ -f $NGINX_CONF_FILE ] || exit 6  
  26.     echo -n $"Starting $prog: "  
  27.     daemon $nginx -c $NGINX_CONF_FILE  
  28.     retval=$?  
  29.     echo  
  30.     [ $retval -eq 0 ] && touch $lockfile  
  31.     return $retval  
  32. }  
  33. stop() {  
  34.     echo -n $"Stopping $prog: "  
  35.     killproc $prog -QUIT  
  36.     retval=$?  
  37.     echo  
  38.     [ $retval -eq 0 ] && rm -f $lockfile  
  39.     return $retval  
  40. killall -9 nginx  
  41. }  
  42. restart() {  
  43.     configtest || return $?  
  44.     stop  
  45.     sleep 1  
  46.     start  
  47. }  
  48. reload() {  
  49.     configtest || return $?  
  50.     echo -n $"Reloading $prog: "  
  51.     killproc $nginx -HUP  
  52. RETVAL=$?  
  53.     echo  
  54. }  
  55. force_reload() {  
  56.     restart  
  57. }  
  58. configtest() {  
  59. $nginx -t -c $NGINX_CONF_FILE  
  60. }  
  61. rh_status() {  
  62.     status $prog  
  63. }  
  64. rh_status_q() {  
  65.     rh_status >/dev/null 2>&1  
  66. }  
  67. case "$1" in  
  68.     start)  
  69.         rh_status_q && exit 0  
  70.     $1  
  71.         ;;  
  72.     stop)  
  73.         rh_status_q || exit 0  
  74.         $1  
  75.         ;;  
  76.     restart|configtest)  
  77.         $1  
  78.         ;;  
  79.     reload)  
  80.         rh_status_q || exit 7  
  81.         $1  
  82.         ;;  
  83.     force-reload)  
  84.         force_reload  
  85.         ;;  
  86.     status)  
  87.         rh_status  
  88.         ;;  
  89.     condrestart|try-restart)  
  90.         rh_status_q || exit 0  
  91.             ;;  
  92. 最后将nginx添加到系统服务,下面记录了我的安装过程。    *)      
  93.       echo $"Usage: $0 {start|stop|status|restart|condrestart|try-restart|reload|force-reload|configtest}"  
  94.         exit 2  
  95. esac  

chmod x /etc/init.d/nginx
注册 nginx 服务
chkconfig --add nginx
chkconfig --list nginx
假如查看到nginx服务在各种级别下,都没有打开,可以再次使用下面的命令明确指出在不同级别下打开:
chkconfig --level 2345 nginx on
再次采用
chkconfig --list nginx
查看,是否在上述各级别下已经打开。这里之所以要如此强调,是希望在断电后nginx服务能自动重启。

4.修改配置文件nginx.conf

主要是根据业务逻辑来配置nginx.conf,这里忽略具体内容

配置完成后,重新测试并加载nginx.conf
service nginx configtest
service nginx reload
让nginx在新的配置下运行就可以了

5.安装中出现的问题和错误
因为nginx.conf中出现问题,显示错误如下:
nginx: [emerg] unknown directive "lua_shared_dict" in /usr/local/nginx/conf/nginx.conf:11

nginx: [emerg] unknown directive "rewrite_by_lua_file" in /usr/local/nginx/conf/nginx.conf:136

解决方法

这两个报错,是因为nginx.conf中添加了这两个指令,将对应配置及逻辑删除就可以了。

参考链接

我暂时将它们注释掉    


0


0

查看评论

cent os6.8 64位安装nginx,os6.8nginx 文章转载: 根据工作需要,现在需要安装nginx服...

3、nginx启动、停止、无间断服务重启
[root@www.linuxidc.com ~]# service nginx start
[root@www.linuxidc.com ~]# service nginx stop
[root@www.linuxidc.com ~]# service nginx reload

force_reload() {

澳门新濠3559 1

  1. #!/bin/sh  
  2. #  
  3. # nginx - this script starts and stops the nginx daemon  
  4. #  
  5. # chkconfig: - 85 15  
  6. # description: Nginx is an HTTP(S) server, HTTP(S) reverse  
  7. # proxy and IMAP/POP3 proxy server  
  8. # processname: nginx  
  9. # config: /etc/nginx/nginx.conf  
  10. # config: /etc/sysconfig/nginx  
  11. # pidfile: /var/run/nginx.pid  
  12.   
  13. # Source function library.  
  14. 澳门新濠3559,. /etc/rc.d/init.d/functions  
  15.   
  16. # Source networking configuration.  
  17. . /etc/sysconfig/network  
  18.   
  19. # Check that networking is up.  
  20. [ "$NETWORKING" = "no" ] && exit 0  
  21.   
  22. nginx="/usr/local/nginx/sbin/nginx"  
  23. prog=$(basename $nginx)  
  24.   
  25. NGINX_CONF_FILE="/usr/local/nginx/conf/nginx.conf"  
  26.   
  27. [ -f /etc/sysconfig/nginx ] && . /etc/sysconfig/nginx  
  28.   
  29. lockfile=/var/lock/subsys/nginx  
  30.   
  31. start() {  
  32. [ -x $nginx ] || exit 5  
  33. [ -f $NGINX_CONF_FILE ] || exit 6  
  34. echo -n {1}quot;Starting $prog: "  
  35. daemon $nginx -c $NGINX_CONF_FILE  
  36. retval=$?  
  37. echo  
  38. [ $retval -eq 0 ] && touch $lockfile  
  39. return $retval  
  40. }  
  41.   
  42. stop() {  
  43. echo -n {1}quot;Stopping $prog: "  
  44. killproc $prog -QUIT  
  45. retval=$?  
  46. echo  
  47. [ $retval -eq 0 ] && rm -f $lockfile  
  48. return $retval  
  49. killall -9 nginx  
  50. }  
  51.   
  52. restart() {  
  53. configtest || return $?  
  54. stop  
  55. sleep 1  
  56. start  
  57. }  
  58.   
  59. reload() {  
  60. configtest || return $?  
  61. echo -n {1}quot;Reloading $prog: "  
  62. killproc $nginx -HUP  
  63. RETVAL=$?  
  64. echo  
  65. }  
  66.   
  67. force_reload() {  
  68. restart  
  69. }  
  70.   
  71. configtest() {  
  72. $nginx -t -c $NGINX_CONF_FILE  
  73. }  
  74.   
  75. rh_status() {  
  76. status $prog  
  77. }  
  78.   
  79. rh_status_q() {  
  80. rh_status >/dev/null 2>&1  
  81. }  
  82.   
  83. case "$1" in  
  84. start)  
  85. rh_status_q && exit 0  
  86. $1  
  87. ;;  
  88. stop)  
  89. rh_status_q || exit 0  
  90. $1  
  91. ;;  
  92. restart|configtest)  
  93. $1  
  94. ;;  
  95. reload)  
  96. rh_status_q || exit 7  
  97. $1  
  98. ;;  
  99. force-reload)  
  100. force_reload  
  101. ;;  
  102. status)  
  103. rh_status  
  104. ;;  
  105. condrestart|try-restart)  
  106. rh_status_q || exit 0  
  107. ;;  
  108. *)  
  109. echo {1}quot;Usage: $0 {start|stop|status|restart|condrestart|try-restart|reload|force-reload|configtest}"  
  110. exit 2  
  111. esac   

$ /etc/init.d/nginx stop

#!/bin/sh
#
# nginx - this script starts and stops the nginx daemon
#
# chkconfig:  - 85 15
# description:  NGINX is an HTTP(S) server, HTTP(S) reverse
#              proxy and IMAP/POP3 proxy server
# processname: nginx
# config:      /etc/nginx/nginx.conf
# config:      /etc/sysconfig/nginx
# pidfile:    /var/run/nginx.pid
 
# Source function library.
. /etc/rc.d/init.d/functions
 
# Source networking configuration.
. /etc/sysconfig/network
 
# Check that networking is up.
[ "$NETWORKING" = "no" ] && exit 0
 
nginx="/usr/sbin/nginx"
prog=$(basename $nginx)
 
NGINX_CONF_FILE="/etc/nginx/nginx.conf"
 
[ -f /etc/sysconfig/nginx ] && . /etc/sysconfig/nginx
 
lockfile=/var/lock/subsys/nginx
 
make_dirs() {
  # make required directories
  user=`$nginx -V 2>&1 | grep "configure arguments:.*--user=" | sed 's/[^*]*--user=([^ ]*).*/1/g' -`
  if [ -n "$user" ]; then
      if [ -z "`grep $user /etc/passwd`" ]; then
        useradd -M -s /bin/nologin $user
      fi
      options=`$nginx -V 2>&1 | grep 'configure arguments:'`
      for opt in $options; do
          if [ `echo $opt | grep '.*-temp-path'` ]; then
              value=`echo $opt | cut -d "=" -f 2`
              if [ ! -d "$value" ]; then
                  # echo "creating" $value
                  mkdir -p $value && chown -R $user $value
              fi
          fi
      done
    fi
}
 
start() {
    [ -x $nginx ] || exit 5
    [ -f $NGINX_CONF_FILE ] || exit 6
    make_dirs
    echo -n $"Starting $prog: "
    daemon $nginx -c $NGINX_CONF_FILE
    retval=$?
    echo
    [ $retval -eq 0 ] && touch $lockfile
    return $retval
}
 
stop() {
    echo -n $"Stopping $prog: "
    killproc $prog -QUIT
    retval=$?
    echo
    [ $retval -eq 0 ] && rm -f $lockfile
    return $retval
}
 
restart() {
    configtest || return $?
    stop
    sleep 1
    start
}
 
reload() {
    configtest || return $?
    echo -n $"Reloading $prog: "
    killproc $nginx -HUP
    RETVAL=$?
    echo
}
 
force_reload() {
    restart
}
 
configtest() {
  $nginx -t -c $NGINX_CONF_FILE
}
 
rh_status() {
    status $prog
}
 
rh_status_q() {
    rh_status >/dev/null 2>&1
}
 
case "$1" in
    start)
        rh_status_q && exit 0
        $1
        ;;
    stop)
        rh_status_q || exit 0
        $1
        ;;
    restart|configtest)
        $1
        ;;
    reload)
        rh_status_q || exit 7
        $1
        ;;
    force-reload)
        force_reload
        ;;
    status)
        rh_status
        ;;
    condrestart|try-restart)
        rh_status_q || exit 0
            ;;
    *)
        echo $"Usage: $0 {start|stop|status|restart|condrestart|try-restart|reload|force-reload|configtest}"
        exit 2
esac

2、加入chkconfig
[root@www.linuxidc.com ~]# cp nginx /etc/init.d/
[root@www.linuxidc.com ~]# chmod 755 /etc/init.d/nginx
[root@www.linuxidc.com ~]# chkconfig --add nginx

*)

本文永久更新链接地址

1、编写脚本,名为nginx

prog=$(basename $nginx)

Nginx安装脚本(install-nginx.sh):

澳门新濠3559 2

stop)

在CentOS6系列的操作系统上,通过脚本自动化下载Nginx源码,并配置安装Nginx服务,最后将nginx添加到系统服务,可通过“service nginx start”等命令操作nginx服务器。

# make required directories

#!/bin/bash
 
# installation configuration
NGINX_VERSION=1.12.2
NGINX_SRC_PATH=/root
NGINX_BIN_PATH=/usr/local/nginx
 
# disable firewall
service iptables stop
setenforce 0
 
# installation dependence
yum install -y pcre-devel zlib-devel openssl-devel
 
# download nginx source package
cd ${NGINX_SRC_PATH}
wget
 
# unzip source package
tar -xzvf nginx-${NGINX_VERSION}.tar.gz
cd ./nginx-${NGINX_VERSION}
 
# install nginx
./configure --prefix=${NGINX_BIN_PATH} --with-http_ssl_module
make & make install
 
# add nginx to system service
ln -s ${NGINX_BIN_PATH}/sbin/nginx /usr/sbin/nginx
cd ${NGINX_BIN_PATH}
wget #如果这个文件无法下载,请下文的service-nginx.sh文件代替
mv service-nginx /etc/init.d/nginx
cd /etc/init.d/
chmod 755 nginx
 
# test nginx service
service nginx restart

useradd -M -s /bin/nologin $user

将Nginx添加到系统服务(service-nginx.sh):

status $prog

status)

在安装完nginx后,重新启动需要“killall nginx进程编号”来进行重新加载,显然十分不方便。如果能像apache一样,直接通过脚本进行管理就方便多了。

start() {

$ service nginx reload

}

exit 2

killproc $nginx -HUP

$ chkconfig --level 3 nginx on

# config:      /etc/sysconfig/nginx

RETVAL=$?

;;

# Check that networking is up.

sleep 1

fi

设置终端模式开机启动:

...

$1

user=`$nginx -V 2>&1 | grep "configure arguments:" | sed 's/[^*]*--user=([^ ]*).*/1/g' -`

rh_status_q || exit 0

# echo "creating" $value

make_dirs() {

rh_status >/dev/null 2>&1

$ service nginx start

# description:  Nginx is an HTTP(S) server, HTTP(S) reverse

# nginx - this script starts and stops the nginx daemon

if [ ! -d "$value" ]; then

daemon $nginx -c $NGINX_CONF_FILE

echo $"Usage: $0 {start|stop|status|restart|condrestart|try-restart|reload|force-reload|configtest}"

# config:      /etc/nginx/nginx.conf

value=`echo $opt | cut -d "=" -f 2`

#

#

retval=$?

configtest || return $?

[ $retval -eq 0 ] && touch $lockfile

}

上面的方法完成了用脚本管理nginx服务的功能,但是还是不太方便,比如要设置nginx开机启动等。这时可以使用chkconfig来设置。

restart

原博客地址:centos下nginx启动脚本和chkconfig管理

return $retval

. /etc/rc.d/init.d/functions

...

# pidfile:     /var/run/nginx.pid

}

$1

rh_status() {

$ /etc/init.d/nginx reload

先将nginx服务加入chkconfig管理列表:

echo

保存后,就可以通过该脚本对nginx服务进行管理了:

condrestart|try-restart)

mkdir -p $value && chown -R $user $value

# Source function library.

force-reload)

rh_status_q && exit 0

rh_status_q() {

esac

;;

return $retval

NGINX_CONF_FILE="/usr/local/nginx/conf/nginx.conf"

[ -f $NGINX_CONF_FILE ] || exit 6

fi

echo -n $"Starting $prog: "

make_dirs

configtest() {

# Source networking configuration.

;;

echo

chkconfig --add /etc/init.d/nginx

加完这个之后,就可以使用service对nginx进行启动,重启等操作了。

. /etc/sysconfig/network

;;

使用chkconfig进行管理

# processname: nginx

;;

start)

start

echo -n $"Stopping $prog: "

$ /etc/init.d/nginx start

restart|configtest)

force_reload

for opt in $options; do

reload)

fi

echo -n $"Reloading $prog: "

;;

case "$1" in

# chkconfig:   - 85 15

retval=$?

nginx="/usr/local/nginx/sbin/nginx"

rh_status_q || exit 0

configtest || return $?

[ -f /etc/sysconfig/nginx ] && . /etc/sysconfig/nginx

}

nginx=”/usr/local/nginx/sbin/nginx” 修改成自己安装nginx路径下面nginx执行程序的路径。

$ service nginx stop

;;

stop

lockfile=/var/lock/subsys/nginx

echo

$nginx -t -c $NGINX_CONF_FILE

killproc $prog -QUIT

reload() {

done

nginx官方早就想好了,也提供了这个脚本,地址:

$1

[ -x $nginx ] || exit 5

#!/bin/sh

}

rh_status_q || exit 7

}

}

[ "$NETWORKING" = "no" ] && exit 0

options=`$nginx -V 2>&1 | grep 'configure arguments:'`

if [ -z "`grep $user /etc/passwd`" ]; then

NGINX_CONF_FILE=”/usr/local/nginx/conf/nginx.conf” 修改成自己安装nginx路径下面配置文件的路径。

[ $retval -eq 0 ] && rm -f $lockfile

$1

}

if [ `echo $opt | grep '.*-temp-path'` ]; then

#               proxy and IMAP/POP3 proxy server

rh_status

将以上脚本保存到/etc/init.d/nginx文件,将其文件权限改为755 并修改两个地方:

restart() {

}

stop() {

编辑:服务器运维 本文来源:最后将nginx添加到系统服务,下面记录了我的安装

关键词: 澳门新濠3559