Nginx简要安装配置说明
一. Nginx简介
Nginx是一款高性能的HTTP和反向代理服务器软件,可以运行在UNIX、GNU/Linux、BSD、Mac OS X、 Solaris 以及 Microsoft Windows等操作系统中。其优点是占用系统资源少,支持大并发连接(官方声称最大支持5万并发连接响应而只占2.5M内存);因其部署简单,配置灵活、高效、稳定的特点已被广泛应用于各大型网站架构中。
二.安装
1).安装所需环境
1
|
gcc-c++ 、openssl-devel 、pcre-devel 、zlib-devel 、libtool
|
2).安装pcre,使Nginx支持rewrite模块
1
2
3
|
tar
zxvf pcre-8.30.
tar
.gz
cd
pcre-8.30
make
&&
make
install
|
3).安装Nginx
1
2
|
tar
zxvf nginx-1.2.3.
tar
.gz
cd
nginx-1.2.3
.
/configure
--user=www --group=www --prefix=
/usr/local/nginx
--with-http_gzip_static_module --with-http_ssl_module
|
编译时可根据实际需要进行编译所需要的模块,用./configure –help查看可编译的模块
三.常用命令
1).检查配置文件是否正确
1
|
/usr/local/nginx/sbin/nginx
-t -c
/usr/local/nginx/conf/nginx
.conf
|
2).启动
1
|
/usr/local/nginx/sbin/nginx
|
3). 平滑重启
1
|
/usr/local/nginx/sbin/nginx
-s reload
|
四.配置
1).配置文件结构
Nginx的配置文件是一个纯文本文件,它一般位于Nginx安装目录的conf目录下,整个配置文件是以block的形式组织的。每个block一般以一个大括号“{}”来表示,block可以分为几个层次,整个配置文件中main指令位于最高层,在main层下面可以有Events、HTTP等层级,而在HTTP层中又包含有server层,即server block,server block中又可分为location层,并且一个server block中可以包含多个location block。
如下图所示:
Nginx配置文件主要分为4部分:main(全局设置)、server(主机设置)、upstream(负载均衡服务器设置)和 location(URL匹配特定位置的设置)。
main部分设置的指令将影响其他所有设置;
server部分的指令主要用于指定主机和端口;
upstream指令主要用于负载均衡,设置一系列的后端服务器;
location部分用于匹配网页位置。
这四者之间的关系如下:server继承main,location继承server,upstream既不会继承其他设置也不会被继承。
在这4个部分当中,每个部分都包含若干指令,这些指令主要包含Nginx的主模块指令、事件模块指令、HTTP核心模块指令。同时每个部分还可以使用其他HTTP模块指令,例如Http SSL模块、Http Gzip Static模块和Http Addition模块等。
2).配置实例
main部分(全局属性配置)
user www www; #指定Nginx Worker进程运行用户以及用户组
worker_processes 2; #指定了Nginx要开启的进程数,多核CPU指定和核数一样多的进程数
pid logs/nginx.pid; #指定进程id的存储文件位置
worker_rlimit_nofile 65535; #指定单进程打开文件数,需与系统设定一致
events {
use epoll; #指定nginx工作模式,nginx主要的工作模式有select、poll、kqueue、epoll 其中select、poll是标准工作模式,kqueue、epoll为高效工作模式,epoll 用在Linux系统中,而kqueue用在BSD系统中
worker_connections 65535;#指定单进程的最大连接数
}
HTTP部分
http {
include mime.types; #指定配置文件所包含的文件
default_type application/octet-stream; #指定默认类型为二进制流,也就是当文件类型未
定义时使用这种方式,例如在没有配置PHP环境时,Nginx是不予解析的,此时,用浏览器访问PHP文件就会出现下载窗口
log_format main '$remote_addr - $remote_user [$time_local] "$request" '#设定日志格式 '$status $body_bytes_sent "$http_referer" '
'"$http_user_agent" "$http_x_forwarded_for"';;
client_max_body_size 20m; #设置允许客户端请求的最大的单个文件字节数
client_header_buffer_size 16k; # 指定来自客户端请求头的headerbuffer大小,如果自
定义了消息头或有更大的cookie,可以在这里增加缓冲大小
large_client_header_buffers 4 32k;# 指定客户端请求中较大的消息头的缓存最大数量
和大小,4为个数,32k为大小,最大缓存为4个32kb
sendfile on;#开启高效传输模式
tcp_nopush on; # tcp_nopush,tcp_nodelay设置on,防止网络阻塞 tcp_nodelay on;
keepalive_timeout 65; #指定客户端连接保持活动的超时时间
client_header_timeout 10;#指定客户端请求头读取超时时间,如果超过这个时间,客户
端还没有发送任何数据,Nginx将返回“Request time out(408)”错误
client_body_timeout 10;#指定客户端请求主体读取超时时间,如果超过这个时间,客
户端还没有发送任何数据,Nginx将返回“Request time out(408)”错误
send_timeout 10;# 指定响应客户端的超时时间。这个超时仅限于两个连接活
动之间的时间,如果超过这个时间,客户端没有任何活动,Nginx将会关闭连接
gzip on; #开启gzip压缩,实时压缩输出数据流
gzip_min_length 1k; #设置允许压缩的页面最小字节数
gzip_buffers 4 16k; #指定内存空间来存贮压缩结果,这里指定4个单位为16k的
内存来存储压缩结果,即总大小为64k
gzip_http_version 1.1; #指定识别HTTP协议版本,默认是1.1
gzip_comp_level 2; # 指定gzip压缩比,1 压缩比最小,处理速度最快;9 压缩比最大,传输速度快,但处理最慢,也比较消耗CPU资源
gzip_types text/plain application/x-javascript text/css application/xml;# 指定压缩的类型,无论是否指定,“text/html”类型总是会被压缩
gzip_vary on; #该选项开启可以让前端的缓存服务器缓存经过gzip压缩的页面,例如,用Varnish缓存经过Nginx压缩的数据
server_tokens off; #隐藏Nginx版本号
server {
listen 8000; #指定Nginx监端口
server_name localhost;#用来指定IP或者域名
charset utf-8; #指定Nginx默认的字符集,只有utf-8支持中文字符 access_log logs/host.access.log main;#指定访问日志的名称及位置
location / {
index index.html index.htm;#设定默认首页
root /tom/webapps/ROOT; #指定网页根目录
}
location ~ (jsp|\?) { #指定url中包含jsp或者?的全部转发到192.168.0.10的80端口即tomcat处理
proxy_pass http://192.168.0.10:80;
}
}