详解Ngigx+Tomcat配置动静分离,负载均衡_nginx

由于公司使用过Ngnix,对于刚接触Nginx来说,感觉有些好奇,于是研究了下。

本人在windows下使用的版本是nginx-1.8.1:

1. 启动Ngnix

双击nginx-1.8.1文件夹中nginx.exe,当任务管理器中存在两个nginx进程时,则说明启动成功!

2. Ngnix常用命令

  • nginx -s stop 强制关闭
  • nginx -s quit 安全关闭
  • nginx -s reload 改变配置文件的时候,重启nginx工作进程,来时配置文件生效 
  •  nginx -s reopen 打开日志文件

3. Nginx配置

下面配置综合了网上的资料,记下,防止自己忘记。

#Nginx所用用户和组
#user nobody;
#工作的子进程数量(通常等于CPU数量或者2倍于CPU)
worker_processes 1;

#错误日志存放路径
#error_log logs/error.log;
#error_log logs/error.log notice;
#error_log logs/error.log info;

#指定pid存放文件
#pid    logs/nginx.pid;

events {
  #使用网络IO模型linux建议epoll,FreeBSD建议采用kqueue
  #use epoll;

  #使用epoll模型提高性能 win下不需要
  #use epoll;
  #允许最大连接数
  worker_connections 1024;
}

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;

  # 启用内核复制模式,应该保持开启达到最快IO效率
  sendfile    on;
  #tcp_nopush   on;

  #keepalive_timeout 0;
  # HTTP1.1支持持久连接alive
  # 降低每个连接的alive时间可在一定程度上提高可响应连接数量,所以一般可适当降低此值
  keepalive_timeout 65;

  # 启动gzip压缩功能设置,有效降低网络流量
  gzip on;
  gzip_min_length 1k;  #最小1K
  gzip_buffers  4 16k;
  gzip_http_version 1.0;
  gzip_comp_level 2;
  gzip_types text/plain application/x-javascripttext/css application/xml;
  gzip_vary on;

  # 静态文件缓存
  # 最大缓存数量,文件未使用存活期
  open_file_cache max=655350 inactive=20s;
  # 验证缓存有效期时间间隔
  open_file_cache_valid 30s;
  # 有效期内文件最少使用次数
  open_file_cache_min_uses 2;

  #xbq add
  #upstream作负载均衡,在此配置需要轮询的服务器地址和端口号,max_fails为允许请求失败的次数,默认为1.
  #weight为轮询权重,根据不同的权重分配可以用来平衡服务器的访问率。
  upstream hostname {
    server 127.0.0.1:9000 max_fails=0 weight=2;
    server 127.0.0.1:9001 max_fails=0 weight=2;
  }

  server {
    listen    8181;
    server_name localhost;

    #charset koi8-r;
    #access_log logs/host.access.log main;

    root /img; #在nginx-1.8.1文件夹中新建img文件夹,用于存放静态资源

    location / {
      #root  html;
      #index index.html index.htm;
      #xbq add
      proxy_pass http://hostname;
      #下面三条指令允许重新定义和添加一些将被转移到被代理服务器的请求头部信息
      # 请求头中Host信息
      proxy_set_header Host $host;
      # 真实的客户端IP
      proxy_set_header X-Real-IP $remote_addr;
      # 代理路由信息,此处取IP有安全隐患
      proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
      # 真实的用户访问协议
      proxy_set_header X-Forwarded-Proto $scheme;

      # 默认值default,
      # 后端response 302时 tomcat header中location的host是http://192.168.1.62:8080
      # 因为tomcat收到的请求是nginx发过去的, nginx发起的请求url host是http://192.168.1.62:8080
      # 设置为default后,nginx自动把响应头中location host部分替换成当前用户请求的host部分
      # 网上很多教程将此值设置成 off,禁用了替换,
      # 这样用户浏览器收到302后跳到http://192.168.1.62:8080,直接将后端服务器暴露给浏览器
      # 所以除非特殊需要,不要设置这种画蛇添足的配置
      proxy_redirect default;
      client_max_body_size 10m;  #允许客户端请求的最大单文件字节数
      client_body_buffer_size 128k; #缓冲区代理缓冲用户端请求的最大字节数
      proxy_connect_timeout 90;  #nginx跟后端服务器连接超时时间
      proxy_read_timeout 90;   #连接成功后,后端服务器响应时间
      proxy_buffer_size 4k;    #设置代理服务器(nginx)保存用户头信息的缓冲区大小
      proxy_buffers 6 32k;    #proxy_buffers缓冲区,网页平均在32k以下的话,这样设置
      proxy_busy_buffers_size 64k;#高负荷下缓冲大小(proxy_buffers*2)
      proxy_temp_file_write_size 64k; #设定缓存文件夹大小,大于这个值,将从upstream服务器传

    }

    #xbq add
    #配置Nginx动静分离,定义的静态页面直接从/usr/nginxStaticFile(Nginx发布目录)读取。
    location ~\.(gif|jpg|jpeg|png|css|js|php)$ {

      #expires定义用户浏览器缓存的时间为7天,如果静态页面不常更新,可以设置更长,这样可以节省带宽和缓解服务器的压力  E:/staticResource;
      expires 7d;
    }

    #xbq add
    #启用nginx status 监听页面
    location /nginxstatus {
      stub_status on;
      access_log on;
    }

    #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;
    }

    # proxy the PHP scripts to Apache listening on 127.0.0.1:80
    #
    #location ~ \.php$ {
    #  proxy_pass  http://127.0.0.1;
    #}

    # pass the PHP scripts to FastCGI server listening on 127.0.0.1:9000
    #
    #location ~ \.php$ {
    #  root      html;
    #  fastcgi_pass  127.0.0.1:9000;
    #  fastcgi_index index.php;
    #  fastcgi_param SCRIPT_FILENAME /scripts$fastcgi_script_name;
    #  include    fastcgi_params;
    #}

    # deny access to .htaccess files, if Apache's document root
    # concurs with nginx's one
    #
    #location ~ /\.ht {
    #  deny all;
    #}
  }

  # another virtual host using mix of IP-, name-, and port-based configuration
  #
  #server {
  #  listen    8000;
  #  listen    somename:8080;
  #  server_name somename alias another.alias;

  #  location / {
  #    root  html;
  #    index index.html index.htm;
  #  }
  #}

  # HTTPS server
  #
  #server {
  #  listen    443 ssl;
  #  server_name localhost;

  #  ssl_certificate   cert.pem;
  #  ssl_certificate_key cert.key;

  #  ssl_session_cache  shared:SSL:1m;
  #  ssl_session_timeout 5m;

  #  ssl_ciphers HIGH:!aNULL:!MD5;
  #  ssl_prefer_server_ciphers on;

  #  location / {
  #    root  html;
  #    index index.html index.htm;
  #  }
  #}

}

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。

以上是小编为您精心准备的的内容,在的博客、问答、公众号、人物、课程等栏目也有的相关内容,欢迎继续使用右上角搜索按钮进行搜索nginx
, tomcat负载均衡
tomcat动静分离
nginx负载均衡配置、nginx 负载均衡、nginx tomcat负载均衡、nginx tcp 负载均衡、nginx负载均衡策略,以便于您获取更多的相关知识。

时间: 2024-10-04 12:13:42

详解Ngigx+Tomcat配置动静分离,负载均衡_nginx的相关文章

Nginx配合Apache或Tomcat的动静分离基本配置实例_nginx

其实本人比较喜欢nginx跑静态和做负载反向代理,动态php还是交给apache处理比较稳定,jsp就交给tomcat.resin或jboss.nginx跑静态的能力是无与伦比的,是目前web服务器里最强的.nginx和apache.tomcat.resin的动静分离配置其实很简单,就几句配置,稳定性也非常好. 1.nginx和apache的动静分离配置: 把下面配置放到nginx配置文件相应的server { }里面,如果使用其他端口号,改一下就行: #所有php的动态页面均交由apache处

详解Nginx + Tomcat 反向代理 负载均衡 集群 部署指南_nginx

Nginx是一种服务器软件,也是一种高性能的http和反向代理服务器,同时还是一个代理邮件服务器.也就是说,我们在Nginx上可以发布网站,可以实现负载均衡(提高应答效率,避免服务器崩溃),还可以作为邮件服务器实现收发邮件等功能.而最常见的就是使用Nginx实现负载均衡. Nginx与其他服务器的性能比较: Tomcat服务器面向Java语言,是重量级的服务器,而Nginx是轻量级的服务器.Apache服务器稳定.开源.跨平台,但是Apache服务器不支持高并发,Nginx能支持处理百万级的TC

Nginx与Tomcat实现动静态分离和负载均衡_nginx

本文介绍了Nginx与Tomcat实现动静态分离和负载均衡,所谓动静分离就是通过nginx(或apache等)来处理用户端请求的图片.html等静态的文件,tomcat(或weblogic)处理jsp.do等动态文件,从而达到动静页面访问时通过不同的容器来处理. 一.Nginx简介: Nginx一个高性能的HTTP和反向代理服务器, 具有很高的稳定性和支持热部署.模块扩展也很容易.当遇到访问的峰值,或者有人恶意发起慢速连接时,也很可能会导致服务器物理内存耗尽频繁交换,失去响应,只能重启服务器,N

nginx tomcat 配置集群负载

开发的应用采用F5负载均衡交换机,F5将请求转发给5台hp unix服务器,每台服务器有多个webserver实例,对外提供web服务和socket等接口服务.之初,曾有个小小的疑问为何不采用开源的apache.Nginx软件负载,F5设备动辄几十万,价格昂贵?自己一个比较幼稚的问题,后续明白:F5是操作于IOS网络模型的传输层,Nginx.apache是基于http反向代理方式,位于ISO模型的第七层应用层.直白些就是TCP UDP 和http协议的区别,Nginx不能为基于TCP协议的应用提

tomcat+nginx动静分离后 图片上传问题

问题描述 tomcat+nginx动静分离后 图片上传问题 采用动静分离后我怎么通过java代码把图片上传到nginx服务器上呢. nginx可以放在windows下吗? 解决方案 Nginx + Tomcat 实现动静分离Nginx+Tomcat实现反向代理与动静分离Nginx+Tomcat实现动静分离

垃圾收集器详解及参数配置

垃圾收集器详解及参数配置 垃圾搜集器简介 垃圾搜集器大致分为以下三类 串行搜集器(serial collector):它只有一条GC线程,且就像前面说的,它在运行的时候需要暂停用户程序(stop the world). 并行搜集器(parallel collector):它有多条GC线程,且它也需要暂停用户程序(stop the world). 并发搜集器(concurrent collector):它有一条或多条GC线程,且它需要在部分阶段暂停用户程序(stop the world),部分阶段

nginx+iis实现简单的负载均衡_nginx

最近在研究分布式系统架构方面的知识,包括负载均衡,数据库读写分离,分布式缓存redis等.本篇先从负载均衡服务架构入手,关于负载均衡百度百科的定义如下:负载均衡,英文名称为Load Balance,其意思就是分摊到多个操作单元上进行执行,例如Web服务器.FTP服务器.企业关键应用服务器和其它关键任务服务器等,从而共同完成工作任务. 我的解释:一项任务交由一个开发人员处理总会有上限处理能力,这时可以考虑增加开发人员来共同处理这项任务,多人处理同一项任务时就会涉及到调度问题,即任务分配,这和多线程

nginx+tomcat实现动静分离(转)

本文设计的动静分离结构   在本文中,我们将静态资源放在 A 主机的一个目录上,将动态程序放在 B 主机上,同时在 A 上安装 Nginx 并且在 B 上安装 Tomcat.配置 Nginx,当请求的是 html.jpg 等静态资源时,就访问 A 主机上的静态资源目录:当用户提出动态资源的请求时,则将请求转发到后端的 B 服务器上,交由 Tomcat 处理,再由 Nginx 将结果返回给请求端.   提到这,可能有您会有疑问,动态请求要先访问 A,A 转发访问 B,再由 B 返回结果给 A,A

详解spring注解配置启动过程_java

       最近看起spring源码,突然想知道没有web.xml的配置,spring是怎么通过一个继承于AbstractAnnotationConfigDispatcherServletInitializer的类来启动自己的.鉴于能力有限以及第一次看源码和发博客,不到之处请望谅~ 我用的IDE是IntelliJ IDEA,这个比myEclipse看源码方便一点,而且黑色背景挺喜欢.然后项目是在maven下的tomcat7插件运行.spring版本是4.3.2.RELEASE.  如果写过纯注