正文
nginx 编译安装以及简单配置
小程序:扫一扫查出行
【扫一扫了解最新限行尾号】
复制小程序
【扫一扫了解最新限行尾号】
复制小程序
一、说明
操作系统:centos 7.6(全新机器)
安装nginx版本:nginx 1.15.2
二、准备工作2.1、安装一系列需要用到的工具
yum groupinstall "Development Tools" -y
yum install expat-devel openssl-devel pcre-devel -y
yum groupinstall "Development Tools" -y
yum install expat-devel openssl-devel pcre-devel -y
2.2、下载所需要的依赖:apr、apr-util、pcre、zlib、openssl
apr的下载地址:http://mirrors.hust.edu.cn/apache/apr/,选择最新的版本下载即可
cd /usr/local/src
wget http://mirrors.hust.edu.cn/apache/apr/apr-1.6.5.tar.gz
tar -zxf apr-1.6.5.tar.gz
cd apr-1.6.5
./configure --prefix=/usr/local/apr
make
make install
apr-util的下载地址:http://mirrors.hust.edu.cn/apache/apr/,选择最新的版本下载即可
cd /usr/local/src
wget http://mirrors.hust.edu.cn/apache/apr/apr-util-1.6.1.tar.gz
tar -zxf apr-util-1.6.1.tar.gz
cd apr-util-1.6.1
./configure --with-apr=/usr/local/apr --prefix=/usr/local/apr-util
make
make install
pcre的下载地址:https://ftp.pcre.org/pub/pcre/,建议下载1.x版本,pcre2可能在编译nginx时出现问题
cd /usr/local/src
wget https://ftp.pcre.org/pub/pcre/pcre-8.42.tar.gz
tar -zxf pcre-8.42.tar.gz
cd pcre-8.42
./configure --prefix=/usr/local/pcre
make
make install
zlib的下载地址:https://www.zlib.net/,下载tar.gz压缩格式即可
cd /usr/local/src
wget https://www.zlib.net/zlib-1.2.11.tar.gz
tar -zxf zlib-1.2.11.tar.gz
cd zlib-1.2.11
./configure --prefix=/usr/local/zlib
make
make install
openssl的下载地址:https://www.openssl.org/source/,下载1.x版本,2.x版本可能在安装中出现确实头文件。
cd /usr/local/src
wget https://www.openssl.org/source/openssl-1.1.1d.tar.gz
tar -zxf openssl-1.1.1d.tar.gz
cd openssl-1.1.1d
./config --prefix=/usr/local/openssl
make
make install
三、下载Nginx、安装
在将工具和依赖的软件都安装后,就可以开始安装nginx了。
nginx的下载地址:http://nginx.org/download/,我这里选择1.15.2版本
cd /usr/local/src
wget http://nginx.org/download/nginx-1.15.2.tar.gz
tar -zxf nginx-1.15.2.tar.gz
cd nginx-1.15.2# 注意下面的--with-pcre、--with-zlib、--wite-openssl都是源码路径
./configure --prefix=/usr/local/nginx \
--with-http_ssl_module \
--with-pcre=/usr/local/src/pcre-8.42 \
--with-zlib=/usr/local/src/zlib-1.2.11 \
--with-openssl=/usr/local/src/openssl-1.1.1dmake
make install
注意,--with-pcre、--with-openssl、--with-zlib所指定的路径都是对应软件源码解压之后的目录,并不是安装目录。
执行完毕后,如果没有出现错误,nginx就安装好了。
四、查看nginx文件目录
前面在安装nginx时,我是将nginx的安装目录指定为/usr/local/nginx
[root@centos /usr/local/nginx]# ls
conf html logs sbin
conf目录存放nginx的相关配置文件;
html目录存放网站的源码文件;
logs存放日志文件;
sbin包含nginx可执行脚本,用于启动nginx。
五、修改nginx配置
nginx的配置文件为conf/nginx.conf。
先创建www用户和www组,只创建www用户即可(会自动创建一个www组)
useradd www
修改/usr/local/nginx/conf/nginx.conf文件,修改user为www,然后取消pid前面的注释即可。
user www;
pid logs/nginx.pid;
六、启动Nginx
nginx的启动程序在nginx的安装目录下的sbin目录下
[root@centos /]# /usr/local/nginx/sbin/nginx
检查端口信息:
[root@centos /]# lsof -i:80
COMMAND PID USER FD TYPE DEVICE SIZE/OFF NODE NAME
nginx 10456 root 6u IPv4 47721 0t0 TCP *:http (LISTEN)
nginx 10457 www 6u IPv4 47721 0t0 TCP *:http (LISTEN)
nginx 10458 www 6u IPv4 47721 0t0 TCP *:http (LISTEN)
可以看到,nginx默认绑定到80端口。
如果防火墙放行了80端口,那么访问机器ip,可以看到下面的页面:
七、Nginx的相关操作命令[root@centos /]# nginx -h
nginx version: nginx/1.15.2
Usage: nginx [-?hvVtTq] [-s signal] [-c filename] [-p prefix] [-g directives]Options:
-?,-h : this help
-v : show version and exit
-V : show version and configure options then exit
-t : test configuration and exit
-T : test configuration, dump it and exit
-q : suppress non-error messages during configuration testing
-s signal : send signal to a master process: stop, quit, reopen, reload
-p prefix : set prefix path (default: /usr/local/nginx/)
-c filename : set configuration file (default: conf/nginx.conf)
-g directives : set global directives out of configuration file
[root@centos /]# nginx -h
nginx version: nginx/1.15.2
Usage: nginx [-?hvVtTq] [-s signal] [-c filename] [-p prefix] [-g directives]Options:
-?,-h : this help
-v : show version and exit
-V : show version and configure options then exit
-t : test configuration and exit
-T : test configuration, dump it and exit
-q : suppress non-error messages during configuration testing
-s signal : send signal to a master process: stop, quit, reopen, reload
-p prefix : set prefix path (default: /usr/local/nginx/)
-c filename : set configuration file (default: conf/nginx.conf)
-g directives : set global directives out of configuration file
上面虽然有很多命令,一般使用最多的是-s选项:
nginx -s stop 立即停止
nginx -s quit 平滑停止进程
nginx -s reopen 重新打开日志
nginx -s reload 重新加载配置文件(热加载)
注意,注意,启动nginx,只需要一个命令就是nginx,不需要加任何选项和任何参数。
nginx -t检测配置文件的语法是否有错误。
八、立即停止进程(stop)和平滑停止进程(quit)的区别
可以用这种场景来理解,有一个请求,需要服务器端运行20秒才能返回给客户端结果。
某一时刻,客户端发起了请求,隔了10秒,还没有获得响应结果(因为前面说了要20秒才能收到响应),所以还要等10秒。
但是如果这个时候,
1、使用nginx -s stop命令停止nginx服务器,那么,客户端会立即收到响应,这个响应不是用户希望收到的请求响应,而是服务器崩溃的响应。那么用户也就不用再等10秒来等待服务器的响应了,因为服务器已经关闭了。
2、使用nginx -s quit命令停止nginx服务器,会发现当前的请求并不会立即终止,客户端可以看到服务器还在运行(注意这个时候,服务器已经quit了),10秒中之后(这个10秒加上之前等的10秒,刚好20秒),客户端收到了服务器的响应。这个响应不是服务器崩溃的响应,而是对之前请求进行的响应。但是,如果客户端此时再次发起一个请求,那么就会立即收到服务器错误的响应。
所以,他们的区别是:是否立即终止当前正在执行的进程。立即停止(stop)就会立即停止,平滑停止(quit)不会立即停止正在进行的进程,而是等他执行完毕之后,再终止。
九、热加载
首先,nginx的运行模式是 主master + 多worker 模式,master监听http请求,然后将请求交给空闲的worker去处理。
1、没有新配置的时候,所有的worker都使用旧配置。
2、当配置有更新的时候,如果某个worker还没有执行结束,那么他就继续执行,仍使用旧的配置。
3、如果worker结束后,该worker不再继续服务,立即终止。
4、新创建的worker使用新的配置文件。
就这样,逐步将所有的旧worker都停止,创建新的worker使用新配置文件,达到热加载的目的。
10、配置文件
具体如下(有注意点都写了)
user www www;#设置工作进程数量(worker)
worker_processes auto;#保存nginx进程id的文件路径
pid /usr/local/nginx/logs/nginx.pid;#设置一个进程最多可以打开多少个文件
worker_rlimit_nofile 51200;events {
#使用epoll模型
use epoll; #每一个worker支持的连接数
worker_connections 51200; multi_accept on;
}#全局设置
http{
include mime.types;
default_type application/octet-stream; server_names_hash_bucket_size 128;
client_header_buffer_size 32k;
large_client_header_buffers 4 32k;
client_max_body_size 50m; sendfile on;
tcp_nopush on; keepalive_timeout 60; tcp_nodelay on; fastcgi_connect_timeout 300;
fastcgi_send_timeout 300;
fastcgi_read_timeout 300;
fastcgi_buffer_size 64k;
fastcgi_buffers 4 64k;
fastcgi_busy_buffers_size 128k;
fastcgi_temp_file_write_size 256k; gzip on;
gzip_min_length 1k;
gzip_buffers 4 16k;
gzip_http_version 1.1;
gzip_comp_level 2;
gzip_types text/plain application/javascript application/x-javascript text/javascript text/css application/xml application/xml+rss;
gzip_vary on;
gzip_proxied expired no-cache no-store private auth;
gzip_disable "MSIE [1-6]\."; #limit_conn_zone $binary_remote_addr zone=perip:10m;
##If enable limit_conn_zone,add "limit_conn perip 10;" to server section. server_tokens off; #是否开启访问日志,如果开启的话,需要设置日志文件路径、日志格式
#access_log off
#默认的日志格式
#log_format main '$remote_addr - $remote_user [$time_local] "$request" '
# '$status $body_bytes_sent "$http_referer" '
# '"$http_user_agent" $http_x
#自定义日志格式
log_format my_format '$remote_addr $request'; #配置上游服务器
upstream imageServer {
server 192.168.1.2:80 weight=1 max_fails=2 fail_timeout=30s;
server 192.168.1.3:80 weight=1 max_fails=2 fail_timeout=30s;
server 192.168.1.4:80 weight=1 max_fails=2 fail_timeout=30s;
} #配置虚拟主机,每一个server { }都是配置一个虚拟主机,所以可以配置多个server{ }
server {
#监听的端口
listen 80 default_server; #指定监听的域名
server_name www.ganlixin.cn ganlixin.cn; #指定根路径
root /var/www; #指定默认首页
index index.html index.htm index.php; #关闭访问日志,每一个虚拟主机的访问日志单独设置
#access_log off
#开启访问日志,使用默认的日志格式
#access_log /var/www/nginx_access.log main;
#开启访问日志,使用自定义的日志格式
access_log /var/www/nginx_access.log my_format; #错误日志路径以及等级
error_log /var/www/ganlixin_error.log crit; #错误页面
#error_page 404 /404.html; #使用location来定义文件路径,相当于Apache的DocumentRoot,location后面跟~表示后面的是正则表达式匹配
#配置php解析
location ~ .*\.php(.*)$ {
#解决无法获取PATH_INFO参数
fastcgi_pass 127.0.0.1:9000;
fastcgi_index index.php;
} include proxy-pass-php.conf; #对静态资源的请求单独处理
location ~ .*\.(gif|jpg|jpeg|png|bmp|swf|js|css)$ {
#设置反向代理(静态资源请求另外一台机器),注意前缀http://
proxy_pass http://192.168.1.2:80;
proxy_set_header X_Forwarded_For $remote_addr; #设置资源过期时间
expires 30d;
} location ~ (.*)$ {
#URL重写
rewrite (.)$ /index.php$1;
}
location ~ /.well-known {
allow all;
} location ~ /\.{
deny all;
}
} #单独配置虚拟机的配置文件
include vhost/*.conf;
}