linux 下编译安装 nginx

大憨熊 提交于 2019-12-07 10:05:58

1.环境说明

ubuntu 12.04
源码存储路径 /home/wzw/workstation/src
安装路径 /home/wzw/workstation/env
切换到工作目录 cd /home/wzw/workstation/src/

2.zlib

wget http://zlib.net/zlib-1.2.8.tar.gz 

tar -zxvf zlib-1.2.8.tar.gz  

sudo mv zlib-1.2.8 ../env/
注意:只解压不安装

3.openssl

wget http://www.openssl.org/source/openssl-1.0.1e.tar.gz 

tar -zxvf openssl-1.0.1e.tar.gz 

sudo mv openssl-1.0.1e ../env/
注意:只解压不安装

4.pcre

wget http://nchc.dl.sourceforge.net/project/pcre/pcre/8.21/pcre-8.21.tar.gz 

tar -zxvf pcre-8.21.tar.gz  

sudo mv pcre-8.21 ../env/
注意:只解压不安装

5.nginx

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

tar -zxvf nginx-1.4.2.tar.gz 

mkdir -p /home/wzw/workstation/env/nginx 

cd nginx-1.4.2/ 

sudo ./configure --prefix=/home/wzw/workstation/env/nginx --sbin-path=/home/wzw/workstation/env/nginx/sbin/nginx --conf-path=/home/wzw/workstation/env/nginx/conf/nginx.conf --pid-path=/home/wzw/workstation/env/nginx/logs/nginx.pid --error-log-path=/home/wzw/workstation/env/nginx/logs/error.log --http-log-path=/home/wzw/workstation/env/nginx/logs/access.log --with-http_ssl_module --with-pcre=/home/wzw/workstation/env/pcre-8.21 --with-zlib=/home/wzw/workstation/env/zlib-1.2.8 --with-openssl=/home/wzw/workstation/env/openssl-1.0.1e 
#注意:--with-openssl --with-zlib --with-pcre 的路径都是以上2、3、4中解压源代码的路径,否则在下一步会出错! 

sudo make 

sudo make install

nginx的configure脚本支持以下选项:

--prefix=<PATH> #Nginx安装路径。如果没有指定,默认为 /usr/local/nginx

--sbin-path=<PATH> #Nginx可执行文件安装路径。只能安装时指定,如果没有指定,默认为<prefix>/sbin/nginx

--conf-path=<PATH> #在没有给定-c选项下默认的nginx.conf的路径。如果没有指定,默认为<prefix>/conf/nginx.conf

--pid-path=<PATH> #在nginx.conf中没有指定pid指令的情况下,默认的nginx.pid的路径。如果没有指定,默认为 <prefix>/logs/nginx.pid

--lock-path=<PATH> #nginx.lock文件的路径

--error-log-path=<PATH> #在nginx.conf中没有指定error_log指令的情况下,默认的错误日志的路径。如果没有指定,默认为 <prefix>/logs/error.log

--http-log-path=<PATH> #在nginx.conf中没有指定access_log指令的情况下,默认的访问日志的路径。如果没有指定,默认为 <prefix>/logs/access.log。

--user=<USER> #在nginx.conf中没有指定user指令的情况下,默认的nginx使用的用户。如果没有指定,默认为 nobody

--group=<GROUP> #在nginx.conf中没有指定user指令的情况下,默认的nginx使用的组。如果没有指定,默认为 nobody

--builddir=DIR #指定编译的目录

--with-rtsig_module #启用 rtsig 模块

--with-select_module(--without-select_module) #允许或不允许开启SELECT模式,如果configure没有找到合适的模式,比如,kqueue(sun os)、epoll(linux kenel 2.6+)、rtsig(实时信号)或/dev/poll(一种类似select的模式,底层实现与SELECT基本相同,都是采用轮询的方法),SELECT模式将是默认安装模式

--with-poll_module(--without-poll_module) #允许或不允许开启POLL模式,如果没有合适的模式,比如:kqueue(sun os)、epoll(liunx kernel 2.6+),则开启该模式

--with-http_ssl_module #开启HTTP SSL模块,使NGINX可以支持HTTPS请求。这个模块需要已经安装了OPENSSL,在DEBIAN上是libssl

--with-http_realip_module #启用 ngx_http_realip_module

--with-http_addition_module #启用 ngx_http_addition_module

--with-http_sub_module #启用 ngx_http_sub_module

--with-http_dav_module #启用 ngx_http_dav_module

--with-http_flv_module #启用 ngx_http_flv_module

--with-http_stub_status_module #启用 "server status" 页

--without-http_charset_module #禁用 ngx_http_charset_module

--without-http_gzip_module #禁用 ngx_http_gzip_module. 如果启用,需要 zlib 。

--without-http_ssi_module #禁用 ngx_http_ssi_module

--without-http_userid_module #禁用 ngx_http_userid_module

--without-http_access_module #禁用 ngx_http_access_module

--without-http_auth_basic_module #禁用 ngx_http_auth_basic_module

--without-http_autoindex_module #禁用 ngx_http_autoindex_module

--without-http_geo_module #禁用 ngx_http_geo_module

--without-http_map_module #禁用 ngx_http_map_module

--without-http_referer_module #禁用 ngx_http_referer_module

--without-http_rewrite_module #禁用 ngx_http_rewrite_module. 如果启用需要 PCRE 。

--without-http_proxy_module #禁用 ngx_http_proxy_module

--without-http_fastcgi_module #禁用 ngx_http_fastcgi_module

--without-http_memcached_module #禁用 ngx_http_memcached_module

--without-http_limit_zone_module #禁用 ngx_http_limit_zone_module

--without-http_empty_gif_module #禁用 ngx_http_empty_gif_module

--without-http_browser_module #禁用 ngx_http_browser_module

--without-http_upstream_ip_hash_module #禁用 ngx_http_upstream_ip_hash_module

--with-http_perl_module #启用 ngx_http_perl_module

--with-perl_modules_path=PATH #指定 perl 模块的路径

--with-perl=PATH #指定 perl 执行文件的路径

--http-log-path=PATH #指定http默认访问日志的路径

--http-client-body-temp-path=PATH #指定http客户端请求缓存文件存放目录的路径

--http-proxy-temp-path=PATH #指定http反向代理缓存文件存放目录的路径

--http-fastcgi-temp-path=PATH #指定http FastCGI缓存文件存放目录的路径

--without-http #禁用 HTTP server

--with-mail #启用 IMAP4/POP3/SMTP 代理模块

--with-mail_ssl_module #启用 ngx_mail_ssl_module

--with-cc=PATH #指定 C 编译器的路径

--with-cpp=PATH #指定 C 预处理器的路径

--with-cc-opt=OPTIONS #设置C编译器的额外选项

--with-ld-opt=OPTIONS #设置链接的额外选项

--with-cpu-opt=CPU #为特定的 CPU 编译,有效的值包括:pentium, pentiumpro, pentium3, pentium4, athlon, opteron, amd64, sparc32, sparc64, ppc64

--without-pcre #禁止 PCRE 库的使用。同时也会禁止 HTTP rewrite 模块。在 "location" 配置指令中的正则表达式也需要 PCRE

--with-pcre=DIR #指定 PCRE 库的源代码的路径

--with-pcre-opt=OPTIONS #设置PCRE的额外编译选项

--with-md5=DIR #使用MD5汇编源码

--with-md5-opt=OPTIONS #设置MD5库的额外编译选项

--with-md5-asm #使用MD5汇编源码

--with-sha1=DIR #设置sha1库的源代码路径

--with-sha1-opt=OPTIONS #设置sha1库的额外编译选项

--with-sha1-asm #使用sha1汇编源码

--with-zlib=DIR #设置zlib库的源代码路径

--with-zlib-opt=OPTIONS #设置zlib库的额外编译选项

--with-zlib-asm=CPU #zlib针对CPU的优化,合法的值是: pentium, pentiumpro

--with-openssl=DIR #设置OpenSSL库的源代码路径

--with-openssl-opt=OPTIONS #设置OpenSSL库的额外编译选项

--with-debug #启用调试日志

--add-module=PATH #添加一个在指定路径中能够找到的第三方模块

在不同版本间,选项可能会有些许变化,请总是使用./configure –help命令来检查当前的选项列表。

6.启动nginx

到这里nginx安装完成,启动命令如下:
cd /home/wzw/workstation/env/nginx/sbin/ 

sudo ./nginx -c /home/wzw/workstation/env/nginx/conf/nginx.conf
打开浏览器输入localhost,看到下图说明nginx安装成功并正常运行。

7.Linux环境下查看nginx进程

用户可以通过执行ps/top命令来启动并查看nginx进程:

ps -ef|grep nginx # 查看 

root     20236     1  0 01:17 ?        00:00:00 nginx: master process ./nginx -c /home/wzw/workstation/env/nginx/conf/nginx.conf 
nobody   20237 20236  0 01:17 ?        00:00:00 nginx: worker process

同上,如果nginx没有启动或者没有得到预期展示页面,可以查看error.log文件或调试来查看失败原因。

易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!