CentOS6.5下安装Nginx-1.8.0并设置开机启动

来源:csdn博客 分类: 文章浏览史 发布时间:2020-07-16 14:55:42 最后更新:2020-07-16 浏览:146
转载声明:
本文为摘录自“csdn博客”,版权归原作者所有。
温馨提示:
为了更好的体验,请点击原文链接进行浏览
摘录时间:
2020-07-16 14:55:42

一.需要的安装环境

注:通过yum安装时如果总是404,需要先清下缓存在update一下

yum clean all
yum update

1、需要安装gcc的环境。

yum install gcc-c++

2、第三方的开发包。
    PCRE
    PCRE(Perl Compatible Regular Expressions)是一个Perl库,包括 perl 兼容的正则表达式库。nginx的http模块使用pcre来解析正则表达式,所以需要在linux上安装pcre库。

yum install -y pcre pcre-devel

注:pcre-devel是使用pcre开发的一个二次开发库。nginx也需要此库。
    zlib
    zlib库提供了很多种压缩和解压缩的方式,nginx使用zlib对http包的内容进行gzip,所以需要在linux上安装zlib库。

yum install -y zlib zlib-devel

    openssl
    OpenSSL 是一个强大的安全套接字层密码库,囊括主要的密码算法、常用的密钥和证书封装管理功能及SSL协议,并提供丰富的应用程序供测试或其它目的使用。
    nginx不仅支持http协议,还支持https(即在ssl协议上传输http),所以需要在linux安装openssl库。

yum install -y openssl openssl-devel

二.安装步骤

1.上传nginx1.8到linux

2.解压到/usr/local

tar -xvf nginx-1.8.0.tar.gz -C /usr/local

3.进入/usr/local/nginx-1.8.0/目录使用configure生成Makefile文件

cd /usr/local/nginx-1.8.0/
./configure \
--prefix=/usr/local/nginx \
--pid-path=/var/run/nginx/nginx.pid \
--lock-path=/var/lock/nginx.lock \
--error-log-path=/var/log/nginx/error.log \
--http-log-path=/var/log/nginx/access.log \
--with-http_gzip_static_module \
--http-client-body-temp-path=/var/temp/nginx/client \
--http-proxy-temp-path=/var/temp/nginx/proxy \
--http-fastcgi-temp-path=/var/temp/nginx/fastcgi \
--http-uwsgi-temp-path=/var/temp/nginx/uwsgi \
--http-scgi-temp-path=/var/temp/nginx/scgi

4.由于上面将临时文件目录指向了 /var/temp/nginx ,所以这里要创建一个这样的文件夹

mkdir /var/temp/nginx -p

5.执行make编译和make install安装

make
make install

6.进入/usr/local/nginx/sbin目录,启动nginx

./nginx

7.查看启动状态

ps aux|grep nginx

8.关闭nginx

./nginx -s quit

9.重启nginx 先关闭后启动,刷新配置文件

./nginx -s reload

三.nginx的开机启动

1.在/etc/init.d/目录下创建nginx文件

vim /etc/init.d/nginx

2.编写以下脚本文件,注意修改一下nginx的执行文件路径以及配置文件路径

#!/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执行文件路径
nginx="/usr/local/nginx/sbin/nginx"
prog=$(basename $nginx)
#指定nginx配置文件路径
NGINX_CONF_FILE="/usr/local/nginx/conf/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:" | sed 's/[^*]*--user=\([^ ]*\).*/\1/g' -`
   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
}
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

3.wq保存脚本文件后设置文件的执行权限

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

4.可以通过该脚本文件对nginx服务进行管理了

/etc/init.d/nginx start
/etc/init.d/nginx stop

5.将nginx服务加入chkconfig管理列表

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

6.加入后,就可以使用以下命令管理nginx了

service nginx start
service nginx stop

7.设置终端模式开机启动

chkconfig nginx on

8.重启linux后测试nginx是否开机启动

ps aux|grep nginx

四.Nginx反向代理、负载均衡

测试:先修改本机host  C:\Windows\System32\Drivers\etc\hosts

1.通过端口区分不同的虚拟主机

2.通过域名区分不同的虚拟主机

3.实现反向代理(通过nginx代理访问不同服务器)

4.实现负载均衡

php技术微信