Centos 7 安装Nginx
1. 安装所需环境
1.1 gcc 安装
安装 nginx 需要先将官网下载的源码进行编译,编译依赖 gcc 环境,如果没有 gcc 环境,则需要
安装:
yum install gcc-c++ -y
1.2 PCRE pcre-devel 安装
PCRE(Perl Compatible Regular Expressions) 是一个 Perl 库,包括 perl 兼容的正则表达式库。nginx
的 http 模块使用 pcre 来解析正则表达式,所以需要在 linux 上安装 pcre 库,pcre-devel 是使用
pcre 开发的一个二次开发库。nginx 也需要此库。
命令:
yum install -y pcre pcre-devel
1.3zlib 安装
zlib 库提供了很多种压缩和解压缩的方式, nginx 使用 zlib 对 http 包的内容进行 gzip ,所以需要在 Centos 上安装 zlib 库。
yum install -y zlib zlib-devel
1.4OpenSSL 安装
OpenSSL 是一个强大的安全套接字层密码库,囊括主要的密码算法、常用的密钥和证书封装管理功能及 SSL 协议,并提供丰富的应用程序供测试或其它目的使用。
nginx 不仅支持 http 协议,还支持 https(即在 ssl 协议上传输 http),所以需要在 Centos 安装OpenSSL 库。
yum install -y openssl openssl-devel
2.下载安装
2.1 nginx官网下载
官网地址:http://nginx.org/en/download.html
直接下载 .tar.gz 安装包,地址:
2.1.1 淘宝网 nginx
也可以尝试使用 淘宝版本的 nginx ,Tengine 是淘宝在 nginx 基础上二次开发的产品,对于我们平时使用区别不大
地址:https://tengine.taobao.org/download_cn.html
2.2使 用 命令下载(推荐)
# 版本按需求选择,复制安装包地址后直接下载即可
wget -c https://nginx.org/download/nginx-1.10.1.tar.gz
2.3解压
tar -zxvf nginx-1.10.1.tar.gz
cd nginx-1.10.1
# nginx 解压后各文件目录作用
[root@master ~]# cd nginx-1.20.2
[root@master nginx-1.20.2]# ll
总用量 792
drwxr-xr-x 6 1001 1001 326 6月 5 22:19 auto # 检测系统模块依赖信息
-rw-r--r-- 1 1001 1001 312251 11月 16 2021 CHANGES # 存放nginx的变化记录日志
-rw-r--r-- 1 1001 1001 476577 11月 16 2021 CHANGES.ru
drwxr-xr-x 2 1001 1001 168 6月 5 22:19 conf # nginx 主配置文件目录
-rwxr-xr-x 1 1001 1001 2590 11月 16 2021 configure # 可执行脚本,用于释放编译文件的定制脚本
drwxr-xr-x 4 1001 1001 72 6月 5 22:19 contrib # 提供vim等插件,让配置文件颜色区分,更友好
drwxr-xr-x 2 1001 1001 40 6月 5 22:19 html # 存放了标准的HTML页面文件
-rw-r--r-- 1 1001 1001 1397 11月 16 2021 LICENSE
-rw-r--r-- 1 root root 438 6月 5 22:22 Makefile
drwxr-xr-x 2 1001 1001 21 6月 5 22:19 man
drwxr-xr-x 3 root root 174 6月 5 22:23 objs
-rw-r--r-- 1 1001 1001 49 11月 16 2021 README
drwxr-xr-x 9 1001 1001 91 6月 5 22:19 src # 存放了 nginx 源代码的目录
2.4配置
2.4.1使用默认配置
./configure
2.4.2自定义配置
如果需要自定义配置信息,可以使用
./configure --help
查看各参数含义
# 参考(根据自己需求配置)
./configure \
--prefix= /usr/local/nginx \ # 指定安装目录
--conf-path=/usr/local/nginx/conf/nginx.conf \
--pid-path=/usr/local/nginx/conf/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 \ # 开启 gzip 功能模块
--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
# 注:将临时文件目录指定为/var/temp/nginx,需要在/var 下创建 temp 及 nginx 目录
[root@master nginx-1.20.2]# ./configure --help
--help print this message
--prefix=PATH set installation prefix
--sbin-path=PATH set nginx binary pathname
--modules-path=PATH set modules path
--conf-path=PATH set nginx.conf pathname
--error-log-path=PATH set error log pathname
--pid-path=PATH set nginx.pid pathname
--lock-path=PATH set nginx.lock pathname
--user=USER set non-privileged user for
worker processes
--group=GROUP set non-privileged group for
worker processes
--build=NAME set build name
--builddir=DIR set build directory
--with-select_module enable select module
--without-select_module disable select module
--with-poll_module enable poll module
--without-poll_module disable poll module
--with-threads enable thread pool support
--with-file-aio enable file AIO support
--with-http_ssl_module enable ngx_http_ssl_module
--with-http_v2_module enable ngx_http_v2_module
--with-http_realip_module enable ngx_http_realip_module
--with-http_addition_module enable ngx_http_addition_module
--with-http_xslt_module enable ngx_http_xslt_module
--with-http_xslt_module=dynamic enable dynamic ngx_http_xslt_module
--with-http_image_filter_module enable ngx_http_image_filter_module
--with-http_image_filter_module=dynamic
enable dynamic ngx_http_image_filter_module
--with-http_geoip_module enable ngx_http_geoip_module
--with-http_geoip_module=dynamic enable dynamic ngx_http_geoip_module
--with-http_sub_module enable ngx_http_sub_module
--with-http_dav_module enable ngx_http_dav_module
--with-http_flv_module enable ngx_http_flv_module
--with-http_mp4_module enable ngx_http_mp4_module
--with-http_gunzip_module enable ngx_http_gunzip_module
--with-http_gzip_static_module enable ngx_http_gzip_static_module
--with-http_auth_request_module enable ngx_http_auth_request_module
--with-http_random_index_module enable ngx_http_random_index_module
--with-http_secure_link_module enable ngx_http_secure_link_module
--with-http_degradation_module enable ngx_http_degradation_module
--with-http_slice_module enable ngx_http_slice_module
--with-http_stub_status_module enable ngx_http_stub_status_module
--without-http_charset_module disable ngx_http_charset_module
--without-http_gzip_module disable ngx_http_gzip_module
--without-http_ssi_module disable ngx_http_ssi_module
--without-http_userid_module disable ngx_http_userid_module
--without-http_access_module disable ngx_http_access_module
--without-http_auth_basic_module disable ngx_http_auth_basic_module
--without-http_mirror_module disable ngx_http_mirror_module
--without-http_autoindex_module disable ngx_http_autoindex_module
--without-http_geo_module disable ngx_http_geo_module
--without-http_map_module disable ngx_http_map_module
--without-http_split_clients_module disable ngx_http_split_clients_module
--without-http_referer_module disable ngx_http_referer_module
--without-http_rewrite_module disable ngx_http_rewrite_module
--without-http_proxy_module disable ngx_http_proxy_module
--without-http_fastcgi_module disable ngx_http_fastcgi_module
--without-http_uwsgi_module disable ngx_http_uwsgi_module
--without-http_scgi_module disable ngx_http_scgi_module
--without-http_grpc_module disable ngx_http_grpc_module
--without-http_memcached_module disable ngx_http_memcached_module
--without-http_limit_conn_module disable ngx_http_limit_conn_module
--without-http_limit_req_module disable ngx_http_limit_req_module
--without-http_empty_gif_module disable ngx_http_empty_gif_module
--without-http_browser_module disable ngx_http_browser_module
--without-http_upstream_hash_module
disable ngx_http_upstream_hash_module
--without-http_upstream_ip_hash_module
disable ngx_http_upstream_ip_hash_module
--without-http_upstream_least_conn_module
disable ngx_http_upstream_least_conn_module
--without-http_upstream_random_module
disable ngx_http_upstream_random_module
--without-http_upstream_keepalive_module
disable ngx_http_upstream_keepalive_module
--without-http_upstream_zone_module
disable ngx_http_upstream_zone_module
--with-http_perl_module enable ngx_http_perl_module
--with-http_perl_module=dynamic enable dynamic ngx_http_perl_module
--with-perl_modules_path=PATH set Perl modules path
--with-perl=PATH set perl binary pathname
--http-log-path=PATH set http access log pathname
--http-client-body-temp-path=PATH set path to store
http client request body temporary files
--http-proxy-temp-path=PATH set path to store
http proxy temporary files
--http-fastcgi-temp-path=PATH set path to store
http fastcgi temporary files
--http-uwsgi-temp-path=PATH set path to store
http uwsgi temporary files
--http-scgi-temp-path=PATH set path to store
http scgi temporary files
--without-http disable HTTP server
--without-http-cache disable HTTP cache
--with-mail enable POP3/IMAP4/SMTP proxy module
--with-mail=dynamic enable dynamic POP3/IMAP4/SMTP proxy module
--with-mail_ssl_module enable ngx_mail_ssl_module
--without-mail_pop3_module disable ngx_mail_pop3_module
--without-mail_imap_module disable ngx_mail_imap_module
--without-mail_smtp_module disable ngx_mail_smtp_module
--with-stream enable TCP/UDP proxy module
--with-stream=dynamic enable dynamic TCP/UDP proxy module
--with-stream_ssl_module enable ngx_stream_ssl_module
--with-stream_realip_module enable ngx_stream_realip_module
--with-stream_geoip_module enable ngx_stream_geoip_module
--with-stream_geoip_module=dynamic enable dynamic ngx_stream_geoip_module
--with-stream_ssl_preread_module enable ngx_stream_ssl_preread_module
--without-stream_limit_conn_module disable ngx_stream_limit_conn_module
--without-stream_access_module disable ngx_stream_access_module
--without-stream_geo_module disable ngx_stream_geo_module
--without-stream_map_module disable ngx_stream_map_module
--without-stream_split_clients_module
disable ngx_stream_split_clients_module
--without-stream_return_module disable ngx_stream_return_module
--without-stream_set_module disable ngx_stream_set_module
--without-stream_upstream_hash_module
disable ngx_stream_upstream_hash_module
--without-stream_upstream_least_conn_module
disable ngx_stream_upstream_least_conn_module
--without-stream_upstream_random_module
disable ngx_stream_upstream_random_module
--without-stream_upstream_zone_module
disable ngx_stream_upstream_zone_module
--with-google_perftools_module enable ngx_google_perftools_module
--with-cpp_test_module enable ngx_cpp_test_module
--add-module=PATH enable external module
--add-dynamic-module=PATH enable dynamic external module
--with-compat dynamic modules compatibility
--with-cc=PATH set C compiler pathname
--with-cpp=PATH set C preprocessor pathname
--with-cc-opt=OPTIONS set additional C compiler options
--with-ld-opt=OPTIONS set additional linker options
--with-cpu-opt=CPU build for the specified CPU, valid values:
pentium, pentiumpro, pentium3, pentium4,
athlon, opteron, sparc32, sparc64, ppc64
--without-pcre disable PCRE library usage
--with-pcre force PCRE library usage
--with-pcre=DIR set path to PCRE library sources
--with-pcre-opt=OPTIONS set additional build options for PCRE
--with-pcre-jit build PCRE with JIT compilation support
--with-zlib=DIR set path to zlib library sources
--with-zlib-opt=OPTIONS set additional build options for zlib
--with-zlib-asm=CPU use zlib assembler sources optimized
for the specified CPU, valid values:
pentium, pentiumpro
--with-libatomic force libatomic_ops library usage
--with-libatomic=DIR set path to libatomic_ops library sources
--with-openssl=DIR set path to OpenSSL library sources
--with-openssl-opt=OPTIONS set additional build options for OpenSSL
--with-debug enable debug logging
2.4.3编译安装
make
make install
2.4.4查找安装路径
whereis nginx
2.5启动停止 Nginx
cd /usr/local/nginx/sbin/
./nginx
./nginx -s stop
./nginx -s quit
./nginx -s reload
# 注: ./nginx -s quit :此方式停止步骤是待 nginx 进程处理任务完毕进行停止。
# ./nginx -s stop :此方式相当于先查出 nginx 进程 id 再使用 kill 命令强制杀掉进程。
2.5.1查询 nginx 进程:
ps aux| grep nginx
2.5.2重启 nginx
先停止再启动(推荐) :
对 nginx 进行重启相当于先停止再启动,即先执行停止命令再执行启动命令。如下:
./nginx -s quit
./nginx
2.5.3重新加载配置文件:
#当 ngin x 的配置文件 nginx.conf 修改后,要想让配置生效需要重启 nginx,使用 -s reload 不用先停止 ngin x 再启动 nginx 即可将配置信息在 nginx 中生效
如下:
./nginx -s reload
2.5.4 配置环境变量
# 配置环境变量
vim /etc/profile
export PATH=$PATH:/usr/local/nginx/sbin/
# 或者在 /etc/profile.d 目录下增加 nginx.sh 文件
vim /etc/profile.d/nginx.sh
# 同样将环境变量加入进去
export PATH=$PATH:/usr/local/nginx/sbin/
# 使配置文件生效
source /etc/profile
# 这样就可以直接使用命令 nginx启动
# 启动nginx
nginx
# 关闭nginx
nginx -s stop
# 使用systemctl管理nginx,vim /usr/lib/systemd/system/nginx.service
[Unit]
Description=nginx
After=network.target
[Service]
Type=forking
ExecStart=/usr/local/nginx/sbin/nginx
[Install]
WantedBy=multi-user.target
# 重载systemd配置文件
systemctl daemon-reload
2.5.5 开机自启动
# 即在 rc.local 增加启动代码就可以了。
vi /etc/rc.local
# 增加一行
/usr/local/nginx/sbin/nginx
# 设置执行权限:
chmod 755 rc.local
END