网站金融模版,婚庆公司创业计划书,闵行网站建站多少钿,网页游戏排行版1. 安装nginx
1.1 选择稳定版本
我们编译安装nginx来定制自己的模块#xff0c;机器CentOS 6.2 x86_64。首先安装缺少的依赖包#xff1a;
# yum -y install gcc gcc-c make libtool zlib zlib-devel openssl openssl-devel pcre pcre-devel
这些软件包如果yum上没有的话…1. 安装nginx
1.1 选择稳定版本
我们编译安装nginx来定制自己的模块机器CentOS 6.2 x86_64。首先安装缺少的依赖包
# yum -y install gcc gcc-c make libtool zlib zlib-devel openssl openssl-devel pcre pcre-devel
这些软件包如果yum上没有的话可以下载源码来编译安装只是要注意编译时默认安装的目录确保下面在安装nginx时能够找到这些动态库文件ldconfig。 从 nginx: download 下载稳定版nginx-1.6.3.tar.gz到/usr/local/src下解压。
为了后续准备我们另外下载2个插件模块nginx_upstream_check_module-0.3.0.tar.gz —— 检查后端服务器的状态nginx-goodies-nginx-sticky-module-ng-bd312d586752.tar.gz建议在/usr/local/src下解压后将目录重命名为nginx-sticky-module-ng-1.2.5 —— 后端做负载均衡解决session sticky问题与upstream_check模块结合使用需要另外打补丁请参考nginx负载均衡配置实战。
请注意插件与nginx的版本兼容问题一般插件越新越好nginx不用追新稳定第一。nginx-1.4.7nginx-sticky-module-1.1nginx_upstream_check_module-0.2.0这个搭配也没问题。sticky-1.1与nginx-1.6版本由于更新没跟上编译出错。可以直接使用Tengine默认就包括了这些模块
[rootcachets nginx-1.6.3]# pwd
/usr/local/src/nginx-1.6.3
[rootcachets nginx-1.6.3]# ./configure --prefix/usr/local/nginx-1.6 --with-pcre /--with-http_stub_status_module --with-http_ssl_module /--with-http_gzip_static_module --with-http_realip_module /--add-module../nginx_upstream_check_module-0.3.0
[rootcachets nginx-1.6.3]# make make install
1.2 常用编译选项说明
nginx大部分常用模块编译时./configure –help以–without开头的都默认安装。
–prefixPATH 指定nginx的安装目录。默认 /usr/local/nginx–conf-pathPATH 设置nginx.conf配置文件的路径。nginx允许使用不同的配置文件启动通过命令行中的-c选项。默认为prefix/conf/nginx.conf–username 设置nginx工作进程的用户。安装完成后可以随时在nginx.conf配置文件更改user指令。默认的用户名是nobody。–groupname类似–with-pcre 设置PCRE库的源码路径如果已通过yum方式安装使用–with-pcre自动找到库文件。使用–with-pcrePATH时需要从PCRE网站下载pcre库的源码版本4.4 – 8.30并解压剩下的就交给Nginx的./configure和make来完成。perl正则表达式使用在location指令和 ngx_http_rewrite_module模块中。–with-zlibPATH 指定 zlib版本1.1.3 – 1.2.5的源码解压目录。在默认就启用的网络传输压缩模块ngx_http_gzip_module时需要使用zlib 。–with-http_ssl_module 使用https协议模块。默认情况下该模块没有被构建。前提是openssl与openssl-devel已安装–with-http_stub_status_module 用来监控 Nginx 的当前状态–with-http_realip_module 通过这个模块允许我们改变客户端请求头中客户端IP地址值(例如X-Real-IP 或 X-Forwarded-For)意义在于能够使得后台服务器记录原始客户端的IP地址–add-modulePATH 添加第三方外部模块如nginx-sticky-module-ng或缓存模块。每次添加新的模块都要重新编译Tengine可以在新加入module时无需重新编译
再提供一种编译方案
./configure /--prefix/usr /--sbin-path/usr/sbin/nginx /--conf-path/etc/nginx/nginx.conf /--error-log-path/var/log/nginx/error.log /--http-log-path/var/log/nginx/access.log /--pid-path/var/run/nginx/nginx.pid /--lock-path/var/lock/nginx.lock / --usernginx /--groupnginx /--with-http_ssl_module /--with-http_stub_status_module /--with-http_gzip_static_module /--http-client-body-temp-path/var/tmp/nginx/client/ /--http-proxy-temp-path/var/tmp/nginx/proxy/ /--http-fastcgi-temp-path/var/tmp/nginx/fcgi/ /--http-uwsgi-temp-path/var/tmp/nginx/uwsgi /--with-pcre../pcre-7.8--with-zlib../zlib-1.2.3
1.3 启动关闭nginx
## 检查配置文件是否正确
# /usr/local/nginx-1.6/sbin/nginx -t
# ./sbin/nginx -V # 可以看到编译选项
## 启动、关闭
# ./sbin/nginx # 默认配置文件 conf/nginx.conf-c 指定
# ./sbin/nginx -s stop
或 pkill nginx
## 重启不会改变启动时指定的配置文件
# ./sbin/nginx -s reload
或 kill -HUP cat /usr/local/nginx-1.6/logs/nginx.pid
当然也可以将 nginx 作为系统服务管理下载 nginx 到/etc/init.d/修改里面的路径然后赋予可执行权限。
# service nginx {start|stop|status|restart|reload|configtest}
1.4 yum安装
yum安装rpm包会比编译安装简单很多默认会安装许多模块但缺点是如果你想以后安装第三方模块那就没办法了。
# vi /etc/yum.repo.d/nginx.repo
[nginx]
namenginx repo
baseurlhttp://nginx.org/packages/centos/$releasever/$basearch/
gpgcheck0
enabled1
剩下的就yum install nginx搞定也可以yum install nginx-1.6.3安装指定版本前提是你去packages里看到有对应的版本默认是最新版稳定版。
2. nginx.conf配置文件
Nginx配置文件主要分成四部分main全局设置、server主机设置、upstream上游服务器设置主要为反向代理、负载均衡相关配置和 locationURL匹配特定位置后的设置每部分包含若干个指令。main部分设置的指令将影响其它所有部分的设置server部分的指令主要用于指定虚拟主机域名、IP和端口upstream的指令用于设置一系列的后端服务器设置反向代理及后端服务器的负载均衡location部分用于匹配网页位置比如根目录/,/images,等等。他们之间的关系式server继承mainlocation继承serverupstream既不会继承指令也不会被继承。它有自己的特殊指令不需要在其他地方的应用。
当前nginx支持的几个指令上下文
2.1 通用
下面的nginx.conf简单的实现nginx在前端做反向代理服务器的例子处理js、png等静态文件jsp等动态请求转发到其它服务器tomcat
user www www;
worker_processes 2;
error_log logs/error.log;
#error_log logs/error.log notice;
#error_log logs/error.log info;
pid logs/nginx.pid;
events {use epoll;worker_connections 2048;
}
http {include mime.types;default_type application/octet-stream;#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;sendfile on;# tcp_nopush on;keepalive_timeout 65;# gzip压缩功能设置gzip on;gzip_min_length 1k;gzip_buffers 4 16k;gzip_http_version 1.0;gzip_comp_level 6;gzip_types text/html text/plain text/css text/javascript application/json application/javascript application/x-javascript application/xml;gzip_vary on;# http_proxy 设置client_max_body_size 10m;client_body_buffer_size 128k;proxy_connect_timeout 75;proxy_send_timeout 75;proxy_read_timeout 75;proxy_buffer_size 4k;proxy_buffers 4 32k;proxy_busy_buffers_size 64k;proxy_temp_file_write_size 64k;proxy_temp_path /usr/local/nginx/proxy_temp 1 2;# 设定负载均衡后台服务器列表 upstream backend { #ip_hash; server 192.168.10.100:8080 max_fails2 fail_timeout30s ; server 192.168.10.101:8080 max_fails2 fail_timeout30s ; }# 很重要的虚拟主机配置server {listen 80;server_name itoatest.example.com;root /apps/oaapp;charset utf-8;access_log logs/host.access.log main;#对 / 所有做负载均衡反向代理location / {root /apps/oaapp;index index.jsp index.html index.htm;proxy_pass http://backend; proxy_redirect off;# 后端的Web服务器可以通过X-Forwarded-For获取用户真实IPproxy_set_header Host $host;proxy_set_header X-Real-IP $remote_addr; proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;proxy_next_upstream error timeout invalid_header http_500 http_502 http_503 http_504;}#静态文件nginx自己处理不去backend请求tomcatlocation ~* /download/ { root /apps/oa/fs; }location ~ .*/.(gif|jpg|jpeg|bmp|png|ico|txt|js|css)$ { root /apps/oaapp; expires 7d; }location /nginx_status {stub_status on;access_log off;allow 192.168.10.0/24;deny all;}location ~ ^/(WEB-INF)/ { deny all; }#error_page 404 /404.html;# redirect server error pages to the static page /50x.html#error_page 500 502 503 504 /50x.html;location /50x.html {root html;}}## 其它虚拟主机server 指令开始
}
2.2 常用指令说明
2.2.1 main全局配置
nginx在运行时与具体业务功能比如http服务或者email服务代理无关的一些参数比如工作进程数运行的身份等。
woker_processes 2 在配置文件的顶级main部分worker角色的工作进程的个数master进程是接收并分配请求给worker处理。这个数值简单一点可以设置为cpu的核数grep ^processor /proc/cpuinfo | wc -l也是 auto 值如果开启了ssl和gzip更应该设置成与逻辑CPU数量一样甚至为2倍可以减少I/O操作。如果nginx服务器还有其它服务可以考虑适当减少。worker_cpu_affinity 也是写在main部分。在高并发情况下通过设置cpu粘性来降低由于多CPU核切换造成的寄存器等现场重建带来的性能损耗。如worker_cpu_affinity 0001 0010 0100 1000; 四核。worker_connections 2048 写在events部分。每一个worker进程能并发处理发起的最大连接数包含与客户端或后端被代理服务器间等所有连接数。nginx作为反向代理服务器计算公式 最大连接数 worker_processes * worker_connections/4所以这里客户端最大连接数是1024这个可以增到到8192都没关系看情况而定但不能超过后面的worker_rlimit_nofile。当nginx作为http服务器时计算公式里面是除以2。worker_rlimit_nofile 10240 写在main部分。默认是没有设置可以限制为操作系统最大的限制65535。use epoll 写在events部分。在Linux操作系统下nginx默认使用epoll事件模型得益于此nginx在Linux操作系统下效率相当高。同时Nginx在OpenBSD或FreeBSD操作系统上采用类似于epoll的高效事件模型kqueue。在操作系统不支持这些高效模型时才使用select。
2.2.2 http服务器
与提供http服务相关的一些配置参数。例如是否使用keepalive啊是否使用gzip进行压缩等。
sendfile on 开启高效文件传输模式sendfile指令指定nginx是否调用sendfile函数来输出文件减少用户空间到内核空间的上下文切换。对于普通应用设为 on如果用来进行下载等应用磁盘IO重负载应用可设置为off以平衡磁盘与网络I/O处理速度降低系统的负载。keepalive_timeout 65 : 长连接超时时间单位是秒这个参数很敏感涉及浏览器的种类、后端服务器的超时设置、操作系统的设置可以另外起一片文章了。长连接请求大量小文件的时候可以减少重建连接的开销但假如有大文件上传65s内没上传完成会导致失败。如果设置时间过长用户又多长时间保持连接会占用大量资源。send_timeout : 用于指定响应客户端的超时时间。这个超时仅限于两个连接活动之间的时间如果超过这个时间客户端没有任何活动Nginx将会关闭连接。client_max_body_size 10m 允许客户端请求的最大单文件字节数。如果有上传较大文件请设置它的限制值client_body_buffer_size 128k 缓冲区代理缓冲用户端请求的最大字节数
模块http_proxy
这个模块实现的是nginx作为反向代理服务器的功能包括缓存功能另见文章
proxy_connect_timeout 60 nginx跟后端服务器连接超时时间(代理连接超时)proxy_read_timeout 60 连接成功后与后端服务器两个成功的响应操作之间超时时间(代理接收超时)proxy_buffer_size 4k 设置代理服务器nginx从后端realserver读取并保存用户头信息的缓冲区大小默认与proxy_buffers大小相同其实可以将这个指令值设的小一点proxy_buffers 4 32k proxy_buffers缓冲区nginx针对单个连接缓存来自后端realserver的响应网页平均在32k以下的话这样设置proxy_busy_buffers_size 64k 高负荷下缓冲大小proxy_buffers*2proxy_max_temp_file_size 当 proxy_buffers 放不下后端服务器的响应内容时会将一部分保存到硬盘的临时文件中这个值用来设置最大临时文件大小默认1024M它与 proxy_cache 没有关系。大于这个值将从upstream服务器传回。设置为0禁用。proxy_temp_file_write_size 64k 当缓存被代理的服务器响应到临时文件时这个选项限制每次写临时文件的大小。proxy_temp_path可以在编译的时候指定写到哪那个目录。
proxy_passproxy_redirect见 location 部分。
模块http_gzip
gzip on : 开启gzip压缩输出减少网络传输。 gzip_min_length 1k 设置允许压缩的页面最小字节数页面字节数从header头得content-length中进行获取。默认值是20。建议设置成大于1k的字节数小于1k可能会越压越大。gzip_buffers 4 16k 设置系统获取几个单位的缓存用于存储gzip的压缩结果数据流。4 16k代表以16k为单位安装原始数据大小以16k为单位的4倍申请内存。gzip_http_version 1.0 用于识别 http 协议的版本早期的浏览器不支持 Gzip 压缩用户就会看到乱码所以为了支持前期版本加上了这个选项如果你用了 Nginx 的反向代理并期望也启用 Gzip 压缩的话由于末端通信是 http/1.0故请设置为 1.0。gzip_comp_level 6 gzip压缩比1压缩比最小处理速度最快9压缩比最大但处理速度最慢(传输快但比较消耗cpu)gzip_types 匹配mime类型进行压缩无论是否指定,text/html类型总是会被压缩的。gzip_proxied any Nginx作为反向代理的时候启用决定开启或者关闭后端服务器返回的结果是否压缩匹配的前提是后端服务器必须要返回包含Via的 header头。gzip_vary on 和http头有关系会在响应头加个 Vary: Accept-Encoding 可以让前端的缓存服务器缓存经过gzip压缩的页面例如用Squid缓存经过Nginx压缩的数据。。
2.2.3 server虚拟主机
http服务上支持若干虚拟主机。每个虚拟主机一个对应的server配置项配置项里面包含该虚拟主机相关的配置。在提供mail服务的代理时也可以建立若干server。每个server通过监听地址或端口来区分。
listen 监听端口默认80小于1024的要以root启动。可以为listen *:80、listen 127.0.0.1:80等形式。server_name 服务器名如localhost、www.example.com可以通过正则匹配。
模块http_stream
这个模块通过一个简单的调度算法来实现客户端IP到后端服务器的负载均衡upstream后接负载均衡器的名字后端realserver以 host:port options; 方式组织在 {} 中。如果后端被代理的只有一台也可以直接写在 proxy_pass 。
2.2.4 location
http服务中某些特定的URL对应的一系列配置项。
root /var/www/html 定义服务器的默认网站根目录位置。如果locationURL匹配的是子目录或文件root没什么作用一般放在server指令里面或/下。index index.jsp index.html index.htm 定义路径下默认访问的文件名一般跟着root放proxy_pass http:/backend 请求转向backend定义的服务器列表即反向代理对应upstream负载均衡器。也可以proxy_pass http://ip:port。proxy_redirect off; proxy_set_header Host $host; proxy_set_header X-Real-IP $remote_addr; proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; 这四个暂且这样设如果深究的话每一个都涉及到很复杂的内容也将通过另一篇文章来解读。
关于location匹配规则的写法可以说尤为关键且基础的参考文章 nginx配置location总结及rewrite规则写法;
2.3 其它
2.3.1 访问控制 allow/deny
Nginx 的访问控制模块默认就会安装而且写法也非常简单可以分别有多个allow,deny允许或禁止某个ip或ip段访问依次满足任何一个规则就停止往下匹配。如
location /nginx-status {stub_status on;access_log off;
# auth_basic NginxStatus;
# auth_basic_user_file /usr/local/nginx-1.6/htpasswd;allow 192.168.10.100;allow 172.29.73.0/24;deny all;
}
我们也常用 httpd-devel 工具的 htpasswd 来为访问的路径设置登录密码
# htpasswd -c htpasswd admin
New passwd:
Re-type new password:
Adding password for user admin
# htpasswd htpasswd admin //修改admin密码
# htpasswd htpasswd sean //多添加一个认证用户
这样就生成了默认使用CRYPT加密的密码文件。打开上面nginx-status的两行注释重启nginx生效。
2.3.2 列出目录 autoindex
Nginx默认是不允许列出整个目录的。如需此功能打开nginx.conf文件在locationserver 或 http段中加入autoindex on;另外两个参数最好也加上去:
autoindex_exact_size off; 默认为on显示出文件的确切大小单位是bytes。改为off后显示出文件的大概大小单位是kB或者MB或者GBautoindex_localtime on; 默认为off显示的文件时间为GMT时间。改为on后显示的文件时间为文件的服务器时间
location /images {root /var/www/nginx-default/images;autoindex on;autoindex_exact_size off;autoindex_localtime on;
}
参考
nginx 并发数问题思考worker_connections,worker_processes与 max clients_51CTO博客_nginx设置并发数Core functionalityhttp://wiki.nginx.org/HttpCoreModule#sendfile