Nginx编译安装
Linux系统下Nginx的源码编译安装模块依赖性,需要依赖下面3个安装包(下面的演示版本不是最新版本,你也可以下载最新的版本,只要把版本号修改一下即可):
一般yum安装以下几个插件:
yum -y install pcre-devel zlib-devel openssl openssl-devel
但这里我们选择编译安装:
1:ssl 功能需要 openssl 库 ( 下载:http://www.openssl.org/source)
wget http://www.openssl.org/source/openssl-fips-1.0.2l.tar.gz
2:gzip 模块需要 zlib 库 ( 下载:http://www.zlib.net/)
wget http://zlib.net/zlib-1.2.11.tar.gz
3:rewrite 模块需要 pcre 库 ( 下载:http://www.pcre.org/ )
wget ftp://ftp.csx.cam.ac.uk/pub/software/programming/pcre/pcre-8.41.tar.gz
############## 一、安装OpenSSL ######################
下载地址 https://www.openssl.org/source/
wget https://www.openssl.org/source/openssl-1.0.2l.tar.gz tar zxvf openssl-1.0.2l.tar.gz cd openssl-1.0.2l/ ./config --prefix=/usr/ --openssldir=/usr/ shared; make && sudo make install
################ 二、安装PCRE ########################
下载地址 ftp://ftp.csx.cam.ac.uk/pub/software/programming/pcre/
wget ftp://ftp.csx.cam.ac.uk/pub/software/programming/pcre/pcre-8.41.tar.gz tar zxvfpcre-8.41.tar.gz ./configure --prefix=/opt/pcre-8.41 ; make && sudo make install
################ 三、安装ZLIB ########################
tar -zxvf zlib-1.2.11.tar.gz cd zlib-1.2.11 ./configure make make install
################ 三、安装Nginx ########################
下载Nginx源码包(stable version)
wget http://nginx.org/download/nginx-1.12.2.tar.gz
创建用户与组:
groupadd nginx useradd -s /sbin/nologin -g nginx -M nginx
解压
tar -zxvf nginx-1.12.2.tar.gz cd nginx-1.12.2/
配置编译环境(--with-pcre、--with-openssl的路径是源码路径,pcre、openssl的安装路径在/opt,但这里只需要源码路径)
./configure \ --prefix=/opt/nginx \ --user=nginx \ --group=nginx \ --error-log-path=/opt/nginx/logs/nginx/error.log \ --http-log-path=/opt/nginx/logs/nginx/access.log \ --pid-path=/opt/nginx/run/nginx/nginx.pid \ --lock-path=/opt/nginx/var/lock/nginx.lock \ --with-http_ssl_module \ --with-http_flv_module \ --with-http_stub_status_module \ --with-http_gzip_static_module \ --with-pcre=../pcre-8.41 \(默认路径就--with-pcre即可) --with-http_realip_module \(更方便的获取真实客户端IP,可以使用nginx http_realip_module模块解决) --with-openssl (#编译路径指定--with-openssl=/opt/openssl-1.0.21)
#以上编译安装nginx后,--http-client-body-temp-path、--http-proxy-temp-path、--http-fastcgi-temp-path、--http-uwsgi-temp-path、--http-scgi-temp-path默认的路径就在/usr/local/nginx下,分别是client_body_temp、proxy_temp、fastcgi_temp、scgi_temp、uwsgi_temp
rhel7.4中nginx编译安装: ./configure \ --prefix=/web/nginxserver/nginx \ --user=nginx \ --group=nginx \ --sbin-path=/usr/local/sbin/nginx \ 生成可执行文件 --error-log-path=/web/nginxserver/nginx/logs/nginx/error.log \ --http-log-path=/web/nginxserver/nginx/logs/nginx/access.log \ --pid-path=/web/nginxserver/nginx/run/nginx/nginx.pid \ --lock-path=/web/nginxserver/nginx/var/lock/nginx.lock \ --with-http_ssl_module \ --with-http_flv_module \ --with-http_stub_status_module \ --with-http_gzip_static_module \ --with-pcre \ --with-http_realip_module
make && make install 如果编译的时候没有指定“--sbin-path=path”sbin路径,会在你指定的安装路径生成sbin目录 自己添加一个nginx主程序的符号链接ln -s /web/nginx/sbin/nginx /usr/local/sbin/ /bin 存放所有用户皆可用的系统程序,系统启动或者系统修复时可用(在没有挂载 /usr 目录时就可以使用) /sbin 存放超级用户才能使用的系统程序 /usr/bin 存放所有用户都可用的应用程序(都是系统预装的可执行程序,会随着系统升级而改变) /usr/sbin 存放超级用户才能使用的应用程序 /usr/local/bin 存放所有用户都可用的与本地机器无关的程序(目录是给用户放置自己的可执行程序的地方, 推荐放在这里,不会被系统升级而覆盖同名文件) /usr/local/sbin 存放超级用户才能使用的与本地机器无关的程序
配置参数描述:
--with-xxx 代表默认没有打开的功能
--without-xxx 代表默认打开的功能
--prefix=path 代表安装路径
--sbin-path=path sbin路径
--conf-path 配置文件
--pid-path 代表进程号保存文件
--error-log-path错误日志
--lock-path 锁文件
--user ps看到的启动进程用户
--group ps看到的启动进程用户所在组
--with-http_ssl_module
--with-http_flv_module
将nginx加入service来管理启动与停止:
vi /etc/init.d/nginx #!/bin/bash # nginx Startup script for the Nginx HTTP Server # it is v.0.0.2 version. # chkconfig: - 85 15 # description: Nginx is a high-performance web and proxy server. # It has a lot of features, but it's not for everyone. # processname: nginx # pidfile: /var/run/nginx.pid # config: /opt/nginx/conf/nginx.conf nginxd=/opt/nginx/sbin/nginx nginx_config=/opt/nginx/conf/nginx.conf nginx_pid=/opt/nginx/run/nginx/nginx.pid RETVAL=0 prog="nginx" # Source function library. . /etc/rc.d/init.d/functions # Source networking configuration. . /etc/sysconfig/network # Check that networking is up. [ ${NETWORKING} = "no" ] && exit 0 [ -x $nginxd ] || exit 0 # Start nginx daemons functions. start() { if [ -e $nginx_pid ];then echo "nginx already running...." exit 1 fi echo -n $"Starting $prog: " daemon $nginxd -c ${nginx_config} RETVAL=$? echo [ $RETVAL = 0 ] && touch /var/lock/subsys/nginx return $RETVAL } # Stop nginx daemons functions. stop() { echo -n $"Stopping $prog: " killproc $nginxd RETVAL=$? echo [ $RETVAL = 0 ] && rm -f /var/lock/subsys/nginx /opt/nginx/run/nginx/nginx.pid #这里也要注意修改你的nginx的pid路径 } # reload nginx service functions. reload() { echo -n $"Reloading $prog: " killproc $nginxd -HUP RETVAL=$? echo } # See how we were called. case "$1" in start) start ;; stop) stop ;; reload) reload ;; restart) stop start ;; status) status $prog RETVAL=$? ;; *) echo $"Usage: $prog {start|stop|restart|reload|status|help}" exit 1 esac exit $RETVAL
chmod +x /etc/init.d/nginx chkconfig --add nginx chkconfig nginx on chkconfig --list nginx nginx 0:关闭 1:关闭 2:启用 3:启用 4:启用 5:启用 6:关闭