nginx是高性能的轻量级web服务器。html
特性:前端
1.http代理nginx
2.反向代理c++
3.负载均衡web
4.缓存机制正则表达式
一,安装及启动(centos7,nginx 1.14.0)centos
1.下载浏览器
wget http://nginx.org/download/nginx-1.14.0.tar.gz
2.安装缓存
#第三方库
yum -y install make zlib zlib-devel gcc-c++ libtool openssl openssl-devel yum -y install pcre-devel #可使用pcre-config —version查看版本
#解压安装包
tar zxvf nginx-1.14.0.tar.gz
#从configure脚本自动生成makefile
cd nginx-1.14.0
./configure --prefix=/usr/local/webserver/nginx #--prefix是指定安装路径,根据本身的状况而定
#编译安装
cd nginx-1.14.0
make && make install
#编译成功后查看版本
/usr/local/webserver/nginx/sbin/nginx -v #安装后的目录有四个conf,html,logs,sbin
3.启动bash
/usr/local/webserver/nginx/sbin/nginx
浏览器访问
二,经常使用指令
1.启动测试文件
/usr/local/webserver/nginx/sbin/nginx -t
2.指定配置文件启动
/usr/local/webserver/nginx/sbin/nginx -c /usr/local/nginx/conf/nginx.conf
3.重启
/usr/local/webserver/nginx/sbin/nginx -s reopen
4.重载配置文件,也有重启的做用
/usr/local/webserver/nginx/sbin/nginx -s reload
5.中止
/usr/local/webserver/nginx/sbin/nginx -s stop
三,配置结构图
结构说明:
1)全局块:做用于nginx全局,一般包括如下部分
2)events块:影响nginx服务器与用户的网络链接,包括:
3)http块:
4)server块:
5)location块:
四,配置实例
实例解
#全局块
user nobody nobody; #指定能运行nginx的用户(组) 指令格式:user user [group];若是不配置,或者为本例配置,则全部用户均可以启动nginx进程 worker_processes 3; #nginx的工做进程数,3表示最多能够产生3个工做进程,能够经过ps -aux|grep nginx查看到,若是选auto,则为自动检测 error_log logs/error.log; #错误日志的路径 pid logs/nginx.pid; #nginx进程是做为系统守护进程运行的,须要在某文档中保存当前当前运行程序的主进程号。指令格式pid file;指定文件名称,本例中是默认值 #如下是全局块中此例没有列出的
#配置文件引入。指令格式include file;用于引入第三方模块配置或其余nginx配置
#events块
events { use epoll; #事件驱动模型的选择,能够选择如select、poll、kqueue、epoll、rtsig worker_connections 1024; #表示容许每个worker process能够同时开启的最大链接数,默认是512
#如下是events块没有列出的
#设置网络链接的序列化。指令格式:accept_mutex on|off; 默认是on状态,表示会对多个nginx进程接收链接进行序列化,防止多个进程对链接的争抢,#即worker将是以串行方式来处理,其中有一个worker会被唤醒。#而off 表示全部worker都会被唤醒,但只有一个worker能得到新链接,其余会从新进入休眠。
#是否容许同时接收多个网络链接。指令格式:multi_accept on|off。默认是off,便是每一个worker process一次只能接收一个新到达的网络链接 } #http块 http {
#http块全局 include mime.types; #将mime.types文件包含进来,能够经过cat mime.type来查看mime.types的内容 default_type application/octet-stream; #指令格式是:default_type mime-type;其中MIME-Type指的是网络资源的媒体类型,也即前端请求的资源类型,是mime.types的内容的一种。
log_format main '$remote_addr - $remote_user [$time_local] "$request" ' #定义个一个名为main的日志格式
'$status $body_bytes_sent "$http_referer" '
'"$http_user_agent" "$http_x_forwarded_for"';
access_log logs/access.log main; #自定义服务日志的路径+名称,指令格式是access_log path [format],其中format是日志的字符串格式,可使用log_format定义格式,此处是使用名称为main的format格式,
sendfile on; #是否容许sendfile方式传输文件,指令格式为sendfile on|off;sendfile_max_chunk size; size=0表示每一个worker process每次调用sendfile()传输的数据的最大值。不限制,默认是0
keepalive_timeout 65; #表示server端对链接的保持时间。默认是75s,指令格式为:keeplive_timeout timeout [header_timeout];header_timeout表示在应答报文头部的keep-Alive域设置超时时间“Keep-Alive:timeout=header_timeout"
#如下没有在http块列出
#单链接请求数上限,指令格式为:keepalive_requests number; #用于限制用户经过某一链接向nginx服务器发起请求的次数
#server块 server {
#server全局块 listen 8088; #设置网络监听,指令格式两种:1.listen IP [:port];2.listen port;1是监听某IP的全部(或某一)端口,2是监听某一端口的全部IP server_name codesheep; #基于名称和IP的虚拟主机配置,指令格式:server_name name1 name2 ...;此处的name支持正则表达式,例如:server_name ~^www\d+\.myserver\.com$
3 access_log /codesheep/webserver/server1/log/access.log; #自定义日志 error_page 404 /404.html; #错误提示与错误页
#location块 location /server1/location1 { #location配置,指令格式:location [ = | ~ | ~* | ^~ ] uri {...};其中uri分为标准uri 和 正则uri;
# =(请求字符串与uri严格匹配) 和 ^~(寻找标识uri和请求字符串匹配度最高的location后,当即用此location处理请求) 用于标准uri
# ~(区分大小写)和 ~*(不区分大小写) 用于正则uri root /codesheep/webserver; #请求根目录配置,指令格式:root path;path是nginx接收请求后查找资源的根目录路径;还能够经过alias 更改location接收到的URI请求路径,指令为:alias path index index.server2-location1.htm; #设置网站的默认首页,指令格式:index file ....;其中file能够包含多个用空格隔开的文件名,先找到哪一个就用哪一个响应请求 } location /server1/location2 { root /codesheep/webserver; index index.server2-location2.htm; } } server { listen 8089; server_name 192.168.31.177; access_log /codesheep/webserver/server2/log/access.log; error_page 404 /404.html; location /server2/location1 { root /codesheep/webserver; index index.server2-location1.htm; } location /srv2/loc2 { alias /codesheep/webserver/server2/location2/; index index.server2-location2.htm; } location = /404.html { root /codesheep/webserver/; index 404.html; } } }
https://www.jianshu.com/p/dc61f1789f47
https://www.jianshu.com/p/39bdc25adaf0