设为首页 收藏本站
查看: 770|回复: 0

[经验分享] nginx配置优化+负载均衡+动静分离详解

[复制链接]

尚未签到

发表于 2017-12-22 20:21:08 | 显示全部楼层 |阅读模式
  nginx配置如下:
  #指定nginx进程运行用户以及用户组
  user www www;
  #nginx要开启的进程数为8
  worker_processes  8;
  #全局错误日志文件
  #debug输出日志最为详细,而crit输出日志最少/var/log目录是linux下的日志存放目录
  error_log /var/log/nginx/nginx_error.log crit;
  #指定进程id的存储位置
  pid   /var/run/nginx.pid;
  #绑定worker进程和CPU,linux内核2.4以上可用
  worker_rlimit_nofile 51200;
  #nginx的工作模式及连接输上线
  events {
  #nginx工作模式,epoll是linux平台下的高效模式
  use epoll;
  #定义nginx每个进程的最大连接数为51200,一般网上都配置65535,根据张宴大神的建议51200即可
  worker_connections  51200;
  }
  http {
  #实现对配置文件所包含的文件的设定
  include       mime.types;
  #设置默认类型为二进制流
  default_type  application/octet-stream;
  server_names_hash_bucket_size  128;
  #指定来自客户端请求头的headerbuffer大小,设置为32KB
  client_header_buffer_size  32k;
  #指定客户端请求中较大的消息头的缓存最大数量和大小,这里是4个32KB
  large_client_header_buffers 4 32k;
  #上传文件大小
  client_max_body_size 356m;
  #nginx的HttpLog模块指定,指定nginx日志的输出格式,输出格式为access
  log_format access '$remote_addr - $remote_user [$time_local] "$request" '
  '$status $body_bytes_sent "$http_referer" '
  '"$http_user_agent" "$http_x_forwarded_for"';
  #access日志存在未知
  access_log  /var/log/nginx/access.log  access;
  #开启高效模式文件传输模式,将tcp_nopush和tcp_nodely两个指另设置为on,用于防止网络阻塞。
  sendfile        on;
  tcp_nopush      on;
  tcp_nodely      on;
  #设置客户端连接保持活动的超时时间
  keepalive_timeout  65;
  server_tokens   off;
  #客户端请求主体读取缓存
  client_body_buffer_size  512k;
  proxy_connect_timeout    5;
  proxy_send_timeout      60;
  proxy_read_timeout       5;
  proxy_buffer_size       16k;
  proxy_buffers         4 64k;
  proxy_busy_buffers_size  128k;
  proxy_temp_file_write_size 128k;   
  #fastcgi_connect_timeout 300;
  #fastcgi_send_timeout    300;
  #fastcgi_read_timeout    300;
  #fastcgi_buffer_timeout  300;
  #fastcgi_buffers 4 64k;
  #fastcgi_busy_buffers_size 128k;
  #fastcgi_temp_file_write_size 128k;
  #开启gzip
  gzip  on;
  #允许压缩的最小字节数
  gzip_min_length 1k;
  #4个单位为16k的内存作为压缩结果流缓存
  gzip_buffers 4 16k;
  #设置识别HTTP协议版本,默认是1.1
  gzip_http_version 1.1;
  #gzip压缩比,可在1~9中设置,1压缩比最小,速度最快,9压缩比最大,速度最慢,消耗CPU
  gzip_comp_level  2;
  #压缩的类型
  gzip_types text/plain application/x-javascript text/css application/xml;
  #让前端的缓存服务器混村经过的gzip压缩的页面
  gzip_vary  on;
  #负载均衡
  upstream localhost.com {
  #每个请求按照ip的hash结果分配,同一个ip的访客固定访问一个后端服务器,可解决动态网页session共享问题。
  ip_hash;
  server 127.0.0.1:8080;
  server 127.0.0.1:8082;
  }
  禁止通过ip访问
  server {
  server_name _;
  return 404;
  }
  server {
  listen       88;
  server_name  www.test.com;# 对应你的域名
  charset    utf-8; #设置编码为utf-8
  index index.html index.htm index.jsp index.do index.action;
  #指定虚拟主机根目录为/var/www/
  root /var/www/;
  if ( -d $request_filename)
  {
  rewrite ^/(.*)([^/])$ http://$host/$1$2/permanent;
  }
  #方法1:将jsp等动态文件交给的localhost.com处理,此方法用的不多
  location ~ \.(jsp|jspx|do|action)(\/.*)?$ {
  index index.jsp;
  proxy_set_header  Host $host;  
  proxy_set_header  X-Real-IP  $remote_addr;
  proxy_pass http://localhost.com;
  }
  #方法2:将所有请求交给localhost.com处理,静态文件通过额外定义location交给nginx处理。
  location / {
  #当502或504时,将请求转发到负载均衡中正常server中
  proxy_next_upstream http_502 http_504 error timeout invalid_header;
  proxy_pass http://localhost.com;
  proxy_redirect    off;
  proxy_set_header Host  $host;
  #若nginx为最前端时,后端获得X-Real-IP传递的ip即为实际ip,若nginx不是最前端时,实际ip为X-Forwarded-For值。
  proxy_set_header X-Forwarded-For  $remote_addr;
  }
  #静态文件交给nginx处理
  location ~ .*\.(htm|html|gif|jpg|jpeg|png|bmp|swf|ioc|rar|zip|txt|flv|mid|doc|ppt|pdf|xls|mp3|wma)$
  {
  root /var/www;
  expires   30d;
  }
  #静态文件交给nginx处理
  location ~ .*\.(js|css)?$     
  {
  root /var/www;      
  expires      1h;     
  }
  location /media {
  #指定后端服务器地址和端口
  proxy_pass         http://localhost.com;
  #proxy_next_upstream 故障转移待空
  proxy_redirect     off;
  #后端服务器获取用户的主机名或真实IP地址
  proxy_set_header   Host            $host;
  proxy_set_header   X-Real-IP       $remote_addr;
  proxy_set_header   X-Forwarded-For $proxy_add_x_forwarded_for;
  #客户端请求主体缓冲区最大值
  client_max_body_size       10m;
  #客户端请求主体缓存区大小
  client_body_buffer_size    128k;   
  #与后端服务器连接的超时时间
  proxy_connect_timeout      90;
  #后端服务器的数据回传时间90s,90s内未传回,nginx将断开连接
  proxy_send_timeout         90;   
  #nginx从代理的后端服务器获取信息的时间90s
  proxy_read_timeout         90;   
  #缓冲区大小默认等于proxy_buffers设置的大小
  proxy_buffer_size          4k;
  #设置缓冲区的数量和大小
  proxy_buffers              4 32k;
  #设置系统很忙时可以使用的proxy_buffers的大小,官方推荐位proxy_buffersX2
  proxy_busy_buffers_size    64k;   
  #指定proxy缓存临时文件的大小
  proxy_temp_file_write_size 64k;
  }
  location /files/ {
  #静止外部访问
  internal;
  #
  alias     /home/nfs/media/;
  }
  }
  # HTTPS server配置
  server {
  listen       443;
  server_name  www.test.com; # 对应你的域名
  root /var/www/webapps;
  ssl on;
  ssl_certificate      /usr/local/nginx/conf/test.crt;
  ssl_certificate_key  /usr/local/nginx/conf/test_nopass.key;
  ssl_session_timeout  5m;
  ssl_protocols  SSLv2 SSLv3 TLSv1;
  ssl_ciphers  HIGH:!aNULL:!MD5;
  ssl_prefer_server_ciphers   on;
  location / {
  root   html;
  index  index.html index.htm;
  }
  }
  }

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-426952-1-1.html 上篇帖子: nginx的301与302跳转详细配置教程 下篇帖子: Nginx配置同一个域名同时支持http与https两种方式访问
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表