一.Nginx的特性和一些知识点
1.基本功能服务器
处理静态文件(静态资源的web),支持 反向代理服务器,支持缓存、负载均衡、支持FastCGI
模块化机制,非DOS机制,支持多种过滤器,如gzip,ssl和用来完成图形大小调整的图像模块
支持SSL
2.扩展功能
基于名称和IP做虚拟主机
支持keepalive
支持平滑配置更新和程序版本升级
定制访问日志,支持使用日志缓存以提高性能
支持URL rewrite
支持路径别名
支持基于IP和用户的认证
支持速率限制,并发数限制等
3.Nginx 的基本框架
一个master,生成一个或多个worker
事件驱动:kqueue,epoll,/dev/poll
消息通知:select poll
支持sendfile,sendfile64
支持mmap
4.Nginx 的优点:
1.在高连接并发的情况下,Nginx是Apache服务器不错的替代品。
2.Nginx 作为负载均衡服务器:Nginx 可以作为HTTP代理服务器对外进行服务。Nginx采用C进行编写,在系统资源开销还是CPU使用率效果比较好;
3.作为邮件代理服务器: Nginx 同时也是一个非常优秀的邮件代理服务器;
4. Nginx 是一个 [#installation 安装] 非常的简单 , 配置文件 非常简洁(还能够支持perl语法), Bugs 非常少的服务器: Nginx 启动特别容易, 并且几乎可以做到7*24不间断运行,即使运行数个月也不需要重新启动. 你还能够 不间断服务的情况下进行软件版本的升级 .
5.Nginx 的事件模型
Nginx支持如下处理连接的方法(I/O复用方法),这些方法可以通过use指令指定。
Select 标准方法
Poll标准方法
Kqueue 高效方法。
二.Nginx 的配置文件简单介绍
1.正常运行的必备配置
a. user username [groupname]
以那个用户身份运行,可以在配置文件中指定,如果没有指定则以编译时的用户为运行用户
b. pid /path/to/pidfile_name
指定nginx的pid文件
c. worker_rlimit_nofile #
指定一个worker进程所能打开的最大句柄数
d. worker_rlimit_sigpending #
设定每个用户能够发往worker进程的信息的数量
2.优化性能相关的配置
a. worker_procrsses #
worker进程的个数,通常其数值应该为cpu的物理核心数减1或2
b. worker_cpu_affinity cpumask .....
用来绑定cpu的,比如
worker_processes 4;
worker_cpu_affinity 0001 0010 0100 1000;
c. ssl_engine device
在存在ssl硬件加速器的服务器上,指定所使用的ssl硬件加速设备
d. timer_resolution t
每次内核事件调用返回时,都会使用gettimeday()来更新nginx缓存时钟,timer_resloution用来定义每隔多久才会由gettimeday()更新一次缓存时钟,x86-64系统上,gettimeday()代价已经很小,可以忽略此配置
c. worker_priority nice
-20到19之间的整数值,数值越小越优先被调用
3. 跟事件相关的配置
a. accept_mutex on | off
是否打开nginx的负载均衡器,此锁能够让多个worker轮流地、序列化的与新的客户端请求建立连接;
b. lock_file /path/to/lock_file
锁文件的位置
c. accept_mutex_delay #ms
使用accept锁以后,只有一个worker能取得锁 ,一个worker进程为取得accept锁的等待,即用户建立等待的时间,如果某worker进程在某次试图取得锁时失败了,则至少要等#ms才能再一次请求锁
d. multi_accept on | off
是否允许一次性地响应多个用户请求,默认为off
三. Nginx安装完毕后,会有响应的安装目录,安装目录里nginx.conf为nginx的主配置文件,
nginx主配置文件分为4部分,main(全局配置)、server(主机设置)、
upstream(负载均衡服务器设)和location(URL匹配特定位置的设置),
这四者关系为:server继承main,location继承server,
upstream既不会继承其他设置也不会被继承。
接下来分析nginx 的主配置文件的各项参数
首先切换到配置文件中
**************************************************************
Nginx的main(全局配置段)文件
**************************************************************
[root@stu21 ~]# vim /etc/nginx/nginx.conf
user nginx nginx; //指定nginx运行的用户及用户组为nginx,默认为nobody
worker_processes 2; //开启的进程数,一般跟逻辑cpu核数一致
error_log logs/error.log notice; //定于全局错误日志文件,级别以notice显示。还有debug、info、warn、error、crit模式,debug输出最多,crit输出最少,更加实际环境而定。
pid logs/nginx.pid; //指定进程id的存储文件位置
worker_rlimit_nofile 65535; //指定一个nginx进程打开的最多文件描述符数目,受系统进程的最大打开文件数量限制
events {
use epoll; 设置工作模式为epoll,除此之外还有select、poll、kqueue、rtsig和/dev/poll模式
worker_connections 65535; //定义每个进程的最大连接数 受系统进程的最大打开文件数量限制
}
#**********************************************************************************************
Nginx的HTTP服务器配置段,Gzip配置。
#************************************************************************************************
http {
*****************************以下是http服务器全局配置*********************************
default_type application/octet-stream; //核心模块指令,这里默认设置为二进制流,也就是当文件类型未定义时使用这种方式
//下面代码为日志格式的设定,main为日志格式的名称,可自行设置,后面引用。
log_format main '$remote_addr - $remote_user [$time_local] "$request" '
'$status $body_bytes_sent "$http_referer" '
'"$http_user_agent" "$http_x_forwarded_for"';
access_log logs/access.log main; //引用日志main
client_max_body_size 20m; //设置允许客户端请求的最大的单个文件字节数
client_header_buffer_size 32k; //指定来自客户端请求头的headebuffer大小
client_body_temp_path /dev/shm/client_body_temp; //指定连接请求试图写入缓存文件的目录路径
large_client_header_buffers 4 32k; //指定客户端请求中较大的消息头的缓存最大数量和大小,目前设置为4个32KB
sendfile on; //开启高效文件传输模式
tcp_nopush on; //开启防止网络阻塞
tcp_nodelay on; //开启防止网络阻塞
keepalive_timeout 65; //设置客户端连接保存活动的超时时间
client_header_timeout 10; //用于设置客户端请求读取超时时间
client_body_timeout 10; //用于设置客户端请求主体读取超时时间
send_timeout 10; //用于设置相应客户端的超时时间
//以下是httpGzip模块配置
#httpGzip modules
gzip on; //开启gzip压缩
gzip_min_length 1k; //设置允许压缩的页面最小字节数
gzip_buffers 4 16k; //申请4个单位为16K的内存作为压缩结果流缓存
gzip_http_version 1.1; //设置识别http协议的版本,默认是1.1
gzip_comp_level 2; //指定gzip压缩比,1-9 数字越小,压缩比越小,速度越快.
gzip_types text/plain application/x-javascript text/css application/xml; //指定压缩的类型
gzip_vary on; //让前端的缓存服务器存经过gzip压缩的页面
#nginx的server虚拟主机配置
#两种方式一种是直接在主配置文件中设置server字段配置虚拟主机,另外一种是使用include字段设置虚拟主机,这样可以减少主配置文件的复杂性。
#*****************************以下是server主机设置*********************************
server {
listen 80; //监听端口为80
server_name www.stu21.com; //设置主机域名
charset gb2312; //设置访问的语言编码
access_log logs/www.rsyslog.org.access.log main; //设置虚拟主机访问日志的存放路径及日志的格式为main
location / { //设置虚拟主机的基本信息
root sites/www; //设置虚拟主机的网站根目录
index index.html index.htm; //设置虚拟主机默认访问的网页
}
location /status { // 查看nginx当前的状态情况,需要模块 "--with-http_stub_status_module"支持
stub_status on;
access_log /usr/local/nginx/logs/status.log;
auth_basic "NginxStatus"; }
}
server {
listen 80;
server_name www.stu21.com;
location / {
root /nginx/htdocs;
index index.html index.htm;
}
}
}
注解:server段是在http段里的,而location段是在server段里的;