一.下载并安装nginx1.8.1:
1.1 nginx官网下载稳定版本nginx1.81:
http://nginx.org/packages/centos/7/x86_64/RPMS/nginx-1.8.1-1.el7.ngx.x86_64.rpm
其中,预编译好的rpm包内的modules及配置,已经可以满足我们的日常使用需求。
1.2 安装有可能需要到的依赖包:
yum install openssl-devel,pcre-devel,zlib-devel
安装nginx1.8.1:
rpm -Uvh nginx-1.8.1-1.el7.ngx.x86_64.rpm
安装完后的默认配置文件在/etc/nginx/目录下
1.3 测试nginx是否安装成功:
systemctl start nginx
浏览器上输入服务器ip:port(端口默认为80)
显示欢迎信息则为成功安装:
二、nginx的配置详细记录:
1.1 nginx主要的配置文件分为三个模块:
1.nginx核心配置模块
2.httpd功能模块
3.第三方模块
1.2 nginx的核心段落配置:
编辑查看/etc/nginx/nginx.conf文件:
其中:
1、user nginx; ####表示启动nginx的用户
2、worker_processes auto; #####表示启动几个worker进程,auto为自动。一般这个值设定为与服务器的cpu核心数一样或者比cpu核心数少1.查看cpu核心使用lscpu命令。
3、(nginx进程与cpu亲和性配置) work_cpu_affinity 0001 0010 0100 1000;###该值表示将启动的worker_processes绑定在指定的cpu上面,可以避免因cpu切换调度时浪费额外的切换性能。该值设定可以提高nginx的处理性能。其中 0001表示将第一个worker_process绑定在第一个cpu上,0010表示将第二个woer_process绑定在第二个cpu上,以此类推.假如有8个cpu核心则为,00000001,00000010 等等。
4、work_priority -20;########woker_process的优先级,默认为0
范围为-20~19之间。值越小,优先级越高
配置完后可使用命令 ps axo command,pid,psr,ni 查看与nginx进程相关的信息:
14193为当前pid,0表示为该进程运行在第一颗cpu核心上。这里我的阿里云为单cpu的,所以进程都是运行在第1颗cpu上。在真实生产机器中,通过worker_processes与work_cpu_affinity配置后可通过这行命令查看到将woker_processes绑定在指定cpu上。
-20为当前进程优先级.
5、worker_rlimit_nofile 5096; ####单个worker进程最大能打开的文件数,如果有4个worker_processes则最大文件打开数为4X5096
6、error_log /var/log/nginx/error.log warn; ###错误日志输出.
这里也可以使用error_log syslog:server=ip(syslog服务器) warn;这种形式将error_log发送到指定的rsyslog服务器进行集中管理.
日志级别由debug ,info,notice,warn,error,crit,alert,emerg默认为warn.
7、pid /var/run/nginx.pid; ####指定pid文件
以上几个就是常用到的nginx核心模块中配置项。修改/etc/nginx/nginx.conf保存退出后可以使用nginx -t 测试是否有语法错误。其中nginx的配置文件必须是一个配置指令跟一个或多个值value以分号;结尾(分号必不可少!!!)
使用nginx -h 获取命令帮助:
常用命令有nginx -s reload ,重新读取配置.
nginx -t ,测试配置文件是否有语法错误
二、events上下文相关配置
1、worker_connections 1024; ###单个worker进程能处理的最大并发响应数,可以根据需要调整为5096。受worker_rlimit_nofile的大小限制
2、use epoll;###表示worker处理请求时采用epoll方法,默认为epoll
3、accept_mutex on;####启用时表示让多个worker进程轮流地、有序地处理请求,默认为on
三、http上下文相关配置:
1、server {...} 上下文相关配置(定义虚拟主机):
2、listen 配置:
一般为listen+端口:listen 80; 如果服务器有多个网卡,也可以指定ip+端口,如listen ip:80的形式。也可以在本地进程间通信时,listen本地的某一个unix套接字文件.
3、server_name name:
指明当前server的主机名,使用方法为server_name www.cr.com mail.cr.com ... server_name后可跟一个或多个空白分割的主机名,也支持使用通配机制,如*.cr.com ,也支持使用正则表达式匹配,如
~^.*.cr.crom$ server_name的匹配优先级为:
a.精确匹配,如www.cr.com
b.左侧通配符匹配,如*.cr.com
c.右侧通配符匹配,如www.cr.*
d.正则表达式匹配,如~^..com..$
3、root path:可用在http,server,location,if等上下文中:
表示设置web资源映射,用于指明用户请求的url所对应的本地文件系统上的资源所在目录.
4、sendfile on;##开启sendfile功能
5、tcp_nodelay on;####对月keepalived模式下的连接是否启用tcp_nodelay选项,应开启。表示不会将单个很小的数据文件延迟响应。
6、send_timeout;####向客户端发送响应报文的超时时长,特指2次写操作的时间间隔
7、keepalive_requests 100;###在一次长连接中所允许请求的最大资源数
8、keepalive_timeout 120;####设定保持连接的超时时长,0表示禁用长连接.
9、location [=|~|~*|^~] uri :
根据用户请求的URI来匹配定义的location,匹配到时,这个请求将会被location块中的配置处理.
a、= 表示精确匹配,如 location =/404.html ,此匹配法则优先度最高
b、 ^~ 表示做左侧匹配,如 location ^~ /bbs/ , 这种匹配方式优先度第二
c、 ~ 区分大小写匹配,后跟一个模式
d、 ~ 不区分大小写匹配正则表达式,如 location ~ .(jpg|png|jepg) {
root /web/images;
}
e、为不跟任何符号的匹配机制,优先度最低,如 location / {}
10、alias 定义路径别名
11、index index.html;####设置默认主页
12、error_page :
根据用户请求资源的http状态响应码实现错误重定向,如
error_page 500 502 503 504 /50x.html;
location = /50x.html {
root /usr/share/nginx/html;
}
当状态码是500时,请求的资源将会变为/50x.html,再根据location中定义的root 路径进行响应
13、open_file_cache max=1024 inactive=1d;###打开最大的缓存文件及过期时间。max表示可缓存的缓存项上限,inactive表示缓存项的超时时长,超过这个时间没有缓存命中时,cache manager将根据LRU算法清理缓存.
14、open_file_cache_valid 300s;####缓存项有效性的检查频率,默认为60s;
15、limit_rate 20480;###限制响应给客户端的传输速率,单位为字节/秒,此处表示20K/s
四、实现基于basic机制进行用户访问认证
1、在某个location上下文内定义访问控制:
auth_basic "admin";###表示当用于请求到/admin时的提示字符串
auth_basic_user_file /etc/nginx/.ngxpasswd;###指明认证时的密码文件
2、使用htpasswd -c -m /etc/nginx/.ngxpasswd cr创建认证用户cr:
其中htpasswd是httpd自带的命令,需要先安装httpd.-c 表示第一次创建时指定的选项,-m 指定md5加密密码.创建完成重读配置即可:
再次访问时,输入使用htpasswd创建的用户与密码即可访问
3、stub_status模块用于输出nginx的基本状态信息:
只需要在一个location上下文中加入stub_status;即可,也可以结合auth_basic访问控制来限定获取该状态信息.
基本nginx状态信息如下:
Active connections: 2 ###表示处于活动状态的连接数
server accepts handled requests ###服务器已经处理的请求
205 205 215 ###第一个数字表示已经接受的客户端连接数,第二个数字表示已经处理的客户端连接数,第三个数字表示所有客户端发起的请求总数。
Reading: 0 Writing: 1 Waiting: 1 ###Reading表示在处于处理客户端请求首部的连接数,Writing 表示正处于向客户端发响应报文的连接数,Waiting 表示处于等待客户端发出请求的空闲连接数,该值过大有可能为设置的keepalive_timeout过大