Ubuntu源码安装NGINX

卸载apt-get安装的NGINX

  1. 查看nginx是否启动
stephen@stephen-OptiPlex-390:~$ ps -ef |grep nginx
root      7875  2317  0 15:02 ?        00:00:00 nginx: master process /usr/sbin/nginx
www-data  7876  7875  0 15:02 ?        00:00:00 nginx: worker process
www-data  7877  7875  0 15:02 ?        00:00:00 nginx: worker process
stephen   8321  3510  0 15:20 pts/0    00:00:00 grep --color=auto nginx
  1. 关闭nginx进程
sudo nginx -s quit
# 或kill命令: sudo kill  -9  7875 7876 7877
  1. 罗列出与nginx相关的软件
$ dpkg --get-selections | grep nginx
nginx                       install
nginx-common                    install
nginx-core                  install
  1. 删除
# purge删除配置文件
sudo apt-get purge nginx
sudo apt-get purge nginx-common
sudo apt-get purge nginx-core
# 移除全部不使用的依赖包
sudo apt-get autoremove
$ dpkg --get-selections | grep nginx
  1. 全局查找与nginx相关的文件
sudo  find  /  -name  nginx*
  1. 删除查找到的关于nginx的文件
sudo rm -rf file

安装依赖

安装Nginx依赖库,gzip模块需要 zlib 库,rewrite模块需要 pcre 库,ssl 功能需要openssl库。

  1. 安装gcc g++的依赖库
    Linux系统下的Gcc(GNU C Compiler)是GNU推出的功能强大、性能优越的多平台编译器
apt-get install build-essential
apt-get install libtool
  1. 安装 pcre依赖库
sudo apt-get update
sudo apt-get install libpcre3 libpcre3-dev
  1. 安装 zlib依赖库
apt-get install zlib1g-dev
  1. 安装 ssl依赖库
apt-get install openssl

安装nginx

NGINX官方下载页

$ cd /usr/local/
$ wget http://nginx.org/download/nginx-1.20.0.tar.gz
$ tar -zxvf nginx-1.20.0.tar.gz
$ cd nginx-1.20.0
$ # --prefix安装路径
$ ./configure --prefix=/usr/local/nginx
...
checking for PCRE library ... found
checking for PCRE JIT support ... found
checking for zlib library ... found
creating objs/Makefile

Configuration summary
  + using system PCRE library
  + OpenSSL library is not used
  + using system zlib library

  nginx path prefix: "/usr/local/nginx"
  nginx binary file: "/usr/local/nginx/sbin/nginx"
  nginx modules path: "/usr/local/nginx/modules"
  nginx configuration prefix: "/usr/local/nginx/conf"
  nginx configuration file: "/usr/local/nginx/conf/nginx.conf"
  nginx pid file: "/usr/local/nginx/logs/nginx.pid"
  nginx error log file: "/usr/local/nginx/logs/error.log"
  nginx http access log file: "/usr/local/nginx/logs/access.log"
  nginx http client request body temporary files: "client_body_temp"
  nginx http proxy temporary files: "proxy_temp"
  nginx http fastcgi temporary files: "fastcgi_temp"
  nginx http uwsgi temporary files: "uwsgi_temp"
  nginx http scgi temporary files: "scgi_temp"
$ #这里经常出现这样的提示  make[1]:leaving directory不用理睬就可以
$ make
...
	objs/src/http/modules/ngx_http_upstream_least_conn_module.o \
	objs/src/http/modules/ngx_http_upstream_random_module.o \
	objs/src/http/modules/ngx_http_upstream_keepalive_module.o \
	objs/src/http/modules/ngx_http_upstream_zone_module.o \
	objs/ngx_modules.o \
	-ldl -lpthread -lcrypt -lpcre -lz \
	-Wl,-E
sed -e "s|%%PREFIX%%|/usr/local/nginx|" \
		-e "s|%%PID_PATH%%|/usr/local/nginx/logs/nginx.pid|" \
		-e "s|%%CONF_PATH%%|/usr/local/nginx/conf/nginx.conf|" \
		-e "s|%%ERROR_LOG_PATH%%|/usr/local/nginx/logs/error.log|" \
		< man/nginx.8 > objs/nginx.8
make[1]: Leaving directory `/primerbean/nginx_conf/nginx-1.20.0'
$ make install
make -f objs/Makefile install
make[1]: Entering directory `/primerbean/nginx_conf/nginx-1.20.0'
test -d '/usr/local/nginx' || mkdir -p '/usr/local/nginx'
test -d '/usr/local/nginx/sbin' \
		|| mkdir -p '/usr/local/nginx/sbin'
test ! -f '/usr/local/nginx/sbin/nginx' \
		|| mv '/usr/local/nginx/sbin/nginx' \
			'/usr/local/nginx/sbin/nginx.old'
cp objs/nginx '/usr/local/nginx/sbin/nginx'
test -d '/usr/local/nginx/conf' \
		|| mkdir -p '/usr/local/nginx/conf'
cp conf/koi-win '/usr/local/nginx/conf'
cp conf/koi-utf '/usr/local/nginx/conf'
cp conf/win-utf '/usr/local/nginx/conf'
test -f '/usr/local/nginx/conf/mime.types' \
		|| cp conf/mime.types '/usr/local/nginx/conf'
cp conf/mime.types '/usr/local/nginx/conf/mime.types.default'
test -f '/usr/local/nginx/conf/fastcgi_params' \
		|| cp conf/fastcgi_params '/usr/local/nginx/conf'
cp conf/fastcgi_params \
		'/usr/local/nginx/conf/fastcgi_params.default'
test -f '/usr/local/nginx/conf/fastcgi.conf' \
		|| cp conf/fastcgi.conf '/usr/local/nginx/conf'
cp conf/fastcgi.conf '/usr/local/nginx/conf/fastcgi.conf.default'
test -f '/usr/local/nginx/conf/uwsgi_params' \
		|| cp conf/uwsgi_params '/usr/local/nginx/conf'
cp conf/uwsgi_params \
		'/usr/local/nginx/conf/uwsgi_params.default'
test -f '/usr/local/nginx/conf/scgi_params' \
		|| cp conf/scgi_params '/usr/local/nginx/conf'
cp conf/scgi_params \
		'/usr/local/nginx/conf/scgi_params.default'
test -f '/usr/local/nginx/conf/nginx.conf' \
		|| cp conf/nginx.conf '/usr/local/nginx/conf/nginx.conf'
cp conf/nginx.conf '/usr/local/nginx/conf/nginx.conf.default'
test -d '/usr/local/nginx/logs' \
		|| mkdir -p '/usr/local/nginx/logs'
test -d '/usr/local/nginx/logs' \
		|| mkdir -p '/usr/local/nginx/logs'
test -d '/usr/local/nginx/html' \
		|| cp -R html '/usr/local/nginx'
test -d '/usr/local/nginx/logs' \
		|| mkdir -p '/usr/local/nginx/logs'
make[1]: Leaving directory `/primerbean/nginx_conf/nginx-1.20.0'

nginx常用命令

启动 Nginx
$ /usr/local/nginx/sbin/nginx
# 指定配置文件
$ ./sbin/nginx -c /usr/local/nginx/conf/nginx.conf
停止 Nginx
$ ./sbin/nginx -s stop

$ ./sbin/nginx -s quit
Nginx重新加载配置
$ ./sbin/nginx -s reload
查看 Nginx 版本
$ ./sbin/nginx -v
$ #查看详细版本信息
$ ./sbin/nginx -V

NGINX加入service

configure命令参数

在Linux上编译安装软件时,经常遇到./configure –prefix=usr这个命令。./configure –prefix 是什么意思呢?下面简单介绍一下./configure –prefix 的用法。
源码的安装一般由有这三个步骤:配置(configure)、编译(make)、安装(make install)。
Configure是一个可执行脚本,它有很多选项,在待安装的源码路径下使用命令./configure –help输出详细的选项列表。
其中–prefix选项就是配置安装的路径,如果不配置该选项,安装后可执行文件默认放在/usr /local/bin,库文件默认放在/usr/local/lib,配置文件默认放在/usr/local/etc,其它的资源文件放在/usr /local/share,比较分散。
为了便于集中管理某个软件的各种文件,可以配置–prefix,如:
./configure –prefix=/usr/local
可以把所有资源文件放在/usr/local的路径中,就不会分散了。
用了—prefix选项的另一个好处是卸载软件或移植软件。当某个安装的软件不再需要时,只须简单地删除该安装目录,就可以把软件卸载得干干净净;移植软件只需拷贝整个目录到另外一个机器即可(相同的操作系统)。
当然要卸载程序,也可以在原来的make目录下用一次make uninstall,但前提是make文件指定过uninstall。

  • --prefix=/usr/local/nginx 安装部署后的根目录,默认为/usr/local/nginx
  • --sbin-path 指向(执行)程序文件(nginx)
  • --conf-path=/etc/nginx/nginx/nginx.conf 配置文件的放置路径,默认/conf/nginx.conf
  • --user=nginx 指定worker进程运行时所属的用户,指定程序运行时的非特权用户。
  • --group=nginx 指定worker进程运行是所属的组,指定程序运行时的非特权用户组。
  • --error-log-path=/var/log/nginx/errpr.log error日志放置位置
  • --http-log-path=/var/log/nginx/access.log 日志放置的位置
  • --pid-path=/var/run/nginx/nginx.pid pid文件的存放路径;默认/logs/nginx.pid
  • --lock-path=/var/lock/nginx.lock lock文件的放置路径;默认/logs/nginx.lock。(安装文件锁定,防止安装文件被别人利用,或自己误操作。)
  • --builddir=... 指向编译目录
  • --with-http_ssl_module 提供HTTPS服务;该模块的安装依赖于OpenSSL开源软件
  • --with-http_stub_status_module 能够获取Nginx自上次启动以来的工作状态
  • --with-http_gzip_static_module 如果采用gzip 模块把一些文档进行gzip 格式压缩后再返回给客户端,那么对同一个文件每次都会重新压缩,这是比较消耗服务器CPU 资源的. gzip static 模块可以在做gzip 压缩前,先查看相同位置是否有已经做过gzip 压缩的.gz 文件,如果有,就直接返回。这样就可以预先在服务器上做好文档的压缩,给CPU 减负
  • --wiht-http_flv_modle 可以在向客户端返回响应肘,对FLV 格式的视频文件在header 头做一些处理,使得客户端可以观看、拖动FLV 视频
  • --with-http_mp4_module 使客户端可以观看、拖动MP4 视频
  • --http-client-body-temp-path=/var/tmp/nginx/client set path to store http client request body temporary files
  • --http-proxy-temp-path=/var/tmp/nginx/proxy Nginx 作为HTTP 反向代理服务器时,上游服务器产生的HTTP 包体在需要临时存放到磁盘文件时,这样的临时文件将放到该路径下;默认/proxy _temp
  • --http-fastcgi-temp-path=/var/tmp/nginx/fastcgi Fastcgi 所使用临时文件的放置目;默认/fastcgi_temp
  • --with-rtsig_module 启用rtsig模块支持(实时信号)
  • --with-select_module 启用select模块支持(一种轮询模式,不推荐在高载环境下使用)禁用:–without-select_module
  • --with-poll_module 启用poll模块支持(功能与select相同,与select特性相同,为一种轮询模式,不推荐在高载环境下使用)
  • --with-file-aio 启用file aio支持(一种APL文件传输格式)
  • --with-ipv6 启用ipv6支持
  • --with-http_realip_module 启用ngx_http_realip_module支持(这个模块允许从请求标头更改客户端的IP地址值,默认为关)
  • --with-http_addition_module 启用ngx_http_addition_module支持(作为一个输出过滤器,支持不完全缓冲,分部分响应请求)
  • --with-http_xslt_module 启用ngx_http_xslt_module支持(过滤转换XML请求)
  • --with-http_image_filter_module 启用ngx_http_image_filter_module支持(传输JPEG/GIF/PNG 图片的一个过滤器)(默认为不启用。gd库要用到)
  • --with-http_geoip_module 启用ngx_http_geoip_module支持(该模块创建基于与MaxMind GeoIP二进制文件相配的客户端IP地址的ngx_http_geoip_module变量)
  • --with-http_sub_module 启用ngx_http_sub_module支持(允许用一些其他文本替换nginx响应中的一些文本)
  • --with-http_dav_module 启用ngx_http_dav_module支持(增加PUT,DELETE,MKCOL:创建集合,COPY和MOVE方法)默认情况下为关闭,需编译开启
  • --with-http_flv_module 启用ngx_http_flv_module支持(提供寻求内存使用基于时间的偏移量文件)
  • --with-http_gzip_static_module 启用ngx_http_gzip_static_module支持(在线实时压缩输出数据流)
  • --with-http_random_index_module 启用ngx_http_random_index_module支持(从目录中随机挑选一个目录索引)
  • --with-http_secure_link_module 启用ngx_http_secure_link_module支持(计算和检查要求所需的安全链接网址)
  • --with-http_degradation_module 启用ngx_http_degradation_module支持(允许在内存不足的情况下返回204或444码)
  • --with-http_stub_status_module 启用ngx_http_stub_status_module支持(获取nginx自上次启动以来的工作状态)
  • --without-http_charset_module 禁用ngx_http_charset_module支持(重新编码web页面,但只能是一个方向–服务器端到客户端,并且只有一个字节的编码可以被重新编码)
  • --without-http_gzip_module 禁用ngx_http_gzip_module支持(该模块同-with-http_gzip_static_module功能一样)
  • --without-http_ssi_module 禁用ngx_http_ssi_module支持(该模块提供了一个在输入端处理处理服务器包含文件(SSI)的过滤器,目前支持SSI命令的列表是不完整的)
  • --without-http_userid_module 禁用ngx_http_userid_module支持(该模块用来处理用来确定客户端后续请求的cookies)
  • --without-http_access_module 禁用ngx_http_access_module支持(该模块提供了一个简单的基于主机的访问控制。允许/拒绝基于ip地址)
  • --without-http_auth_basic_module 禁用ngx_http_auth_basic_module(该模块是可以使用用户名和密码基于http基本认证方法来保护你的站点或其部分内容)
  • --without-http_autoindex_module 禁用disable ngx_http_autoindex_module支持(该模块用于自动生成目录列表,只在ngx_http_index_module模块未找到索引文件时发出请求。)
  • --without-http_geo_module 禁用ngx_http_geo_module支持(创建一些变量,其值依赖于客户端的IP地址)
  • --without-http_map_module 禁用ngx_http_map_module支持(使用任意的键/值对设置配置变量)
  • --without-http_split_clients_module 禁用ngx_http_split_clients_module支持(该模块用来基于某些条件划分用户。条件如:ip地址、报头、cookies等等)
  • --without-http_referer_module 禁用disable ngx_http_referer_module支持(该模块用来过滤请求,拒绝报头中Referer值不正确的请求)
  • --without-http_rewrite_module 禁用ngx_http_rewrite_module支持(该模块允许使用正则表达式改变URI,并且根据变量来转向以及选择配置。如果在server级别设置该选项,那么他们将在 location之前生效。如果在location还有更进一步的重写规则,location部分的规则依然会被执行。如果这个URI重写是因为location部分的规则造成的,那么 location部分会再次被执行作为新的URI。 这个循环会执行10次,然后Nginx会返回一个500错误。)
  • --without-http_proxy_module 禁用ngx_http_proxy_module支持(有关代理服务器)
  • --without-http_fastcgi_module 禁用ngx_http_fastcgi_module支持(该模块允许Nginx 与FastCGI 进程交互,并通过传递参数来控制FastCGI 进程工作。 )FastCGI一个常驻型的公共网关接口。
  • --without-http_uwsgi_module 禁用ngx_http_uwsgi_module支持(该模块用来医用uwsgi协议,uWSGI服务器相关)
  • --without-http_scgi_module 禁用ngx_http_scgi_module支持(该模块用来启用SCGI协议支持,SCGI协议是CGI协议的替代。它是一种应用程序与HTTP服务接口标准。它有些像FastCGI但他的设计 更容易实现。)
  • --without-http_memcached_module 禁用ngx_http_memcached_module支持(该模块用来提供简单的缓存,以提高系统效率)
  • -without-http_limit_zone_module 禁用ngx_http_limit_zone_module支持(该模块可以针对条件,进行会话的并发连接数控制)
  • --without-http_limit_req_module 禁用ngx_http_limit_req_module支持(该模块允许你对于一个地址进行请求数量的限制用一个给定的session或一个特定的事件)
  • --without-http_empty_gif_module 禁用ngx_http_empty_gif_module支持(该模块在内存中常驻了一个1*1的透明GIF图像,可以被非常快速的调用)
  • --without-http_browser_module 禁用ngx_http_browser_module支持(该模块用来创建依赖于请求报头的值。如果浏览器为modern ,则$modern_browser等于modern_browser_value指令分配的值;如 果浏览器为old,则$ancient_browser等于 ancient_browser_value指令分配的值;如果浏览器为 MSIE中的任意版本,则 $msie等于1)
  • --without-http_upstream_ip_hash_module 禁用ngx_http_upstream_ip_hash_module支持(该模块用于简单的负载均衡)
  • --with-http_perl_module 启用ngx_http_perl_module支持(该模块使nginx可以直接使用perl或通过ssi调用perl)
  • --with-perl_modules_path= 设定perl模块路径
  • --with-perl= 设定perl库文件路径
  • --http-log-path= 设定access log路径
  • --http-client-body-temp-path= 设定http客户端请求临时文件路径
  • --http-proxy-temp-path= 设定http代理临时文件路径
  • --http-fastcgi-temp-path= 设定http fastcgi临时文件路径
  • --http-uwsgi-temp-path= 设定http uwsgi临时文件路径
  • --http-scgi-temp-path= 设定http scgi临时文件路径
  • -without-http 禁用http server功能
  • --without-http-cache 禁用http cache功能
  • --with-mail 启用POP3/IMAP4/SMTP代理模块支持
  • --with-mail_ssl_module 启用ngx_mail_ssl_module支持
  • --without-mail_pop3_module 禁用pop3协议(POP3即邮局协议的第3个版本,它是规定个人计算机如何连接到互联网上的邮件服务器进行收发邮件的协议。是因特网电子邮件的第一个离线协议标 准,POP3协议允许用户从服务器上把邮件存储到本地主机上,同时根据客户端的操作删除或保存在邮件服务器上的邮件。POP3协议是TCP/IP协议族中的一员,主要用于 支持使用客户端远程管理在服务器上的电子邮件)
  • --without-mail_imap_module 禁用imap协议(一种邮件获取协议。它的主要作用是邮件客户端可以通过这种协议从邮件服务器上获取邮件的信息,下载邮件等。IMAP协议运行在TCP/IP协议之上, 使用的端口是143。它与POP3协议的主要区别是用户可以不用把所有的邮件全部下载,可以通过客户端直接对服务器上的邮件进行操作。)
  • --without-mail_smtp_module 禁用smtp协议(SMTP即简单邮件传输协议,它是一组用于由源地址到目的地址传送邮件的规则,由它来控制信件的中转方式。SMTP协议属于TCP/IP协议族,它帮助每台计算机在发送或中转信件时找到下一个目的地。)
  • --with-google_perftools_module 启用ngx_google_perftools_module支持(调试用,剖析程序性能瓶颈)
  • --with-cpp_test_module 启用ngx_cpp_test_module支持
  • --add-module= 启用外部模块支持
  • --with-cc= 指向C编译器路径
  • --with-cpp= 指向C预处理路径
  • --with-cc-opt= 设置C编译器参数(PCRE库,需要指定–with-cc-opt=”-I /usr/local/include”,如果使用select()函数则需要同时增加文件描述符数量,可以通过–with-cc- opt=”-D FD_SETSIZE=2048”指定。)
  • --with-ld-opt= 设置连接文件参数。(PCRE库,需要指定–with-ld-opt=”-L /usr/local/lib”。)
  • --with-cpu-opt= 指定编译的CPU,可用的值为: pentium, pentiumpro, pentium3, pentium4, athlon, opteron, amd64, sparc32, sparc64, ppc64
  • --without-pcre 禁用pcre库
  • --with-pcre 启用pcre库
  • --with-pcre= 指向pcre库文件目录
  • --with-pcre-opt= 在编译时为pcre库设置附加参数
  • --with-md5= 指向md5库文件目录(消息摘要算法第五版,用以提供消息的完整性保护)
  • --with-md5-opt= 在编译时为md5库设置附加参数
  • --with-md5-asm 使用md5汇编源
  • --with-sha1= 指向sha1库目录(数字签名算法,主要用于数字签名)
  • --with-sha1-opt= 在编译时为sha1库设置附加参数
  • --with-sha1-asm 使用sha1汇编源
  • --with-zlib=指向zlib库目录
  • --with-zlib-opt= 在编译时为zlib设置附加参数
  • --with-zlib-asm= 为指定的CPU使用zlib汇编源进行优化,CPU类型为pentium, pentiumpro
  • --with-libatomic 为原子内存的更新操作的实现提供一个架构
  • --with-libatomic= 指向libatomic_ops安装目录
  • --with-openssl= 指向openssl安装目录
  • --with-openssl-opt 在编译时为openssl设置附加参数
  • --with-debug 启用debug日志

关闭iptables
service iptables stop
chkconfig iptables stop

关闭selinux
setenforce 0
修改/etc/selinux/config 文件
将SELINUX=enforcing改为SELINUX=disabled

  • 5
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值