nginx+tomcat实现负载均衡,使用redis session共享

环境准备

1、准备一台nginx服务器 ip192.168.1.133 端口81

安装过程:

#首先安装依赖:
yum -y install gcc-c++
yum -y install pcre pcre-devel
yum -y install zlib zlib-devel
yum -y install openssl openssl—devel
#注意 : 安装nginx必须使用 root 用户安装
#创建一个nginx目录
mkdir /usr/local/src/nginx
#进入到nginx目录
cd /usr/local/src/nginx
#下载或上传安装包
wget http://nginx.org/download/nginx.tar.gz 或 rz上传
#解压安装包
tar -xvf nginx.tar.gz
#进入到解压后的目录
cd nginx
# 下面 才开始正式安装
#把nginx安装到指定用户的目录
mkdir -p /ucenter/soft/nginx
#安装配置 prefix为安装目录 user为用户 group为 组
./configure --prefix=/ucenter/soft/nginx --user=ucenter --group=ucenter
#编译
make
#安装
make install
#在linux系统中由于非root用户不能占用80端口,所以需要使普通用户以root身份启动nginx。
cd /ucenter/soft/nginx/sbin
#把soft文件下所有的文件所属者修改为ucener -R 表示递归
chown ucenter:ucenter ./soft/ -R
#修改 ./nginx 的所属为root
chown root nginx
#让普通用户可以使用80端口,可以使用root权限启用nginx
chmod u+s nginx
#修改配置文件 在修改配置文件之前 ,要备份该文件
cd conf/
# 要注意nginx 的工作进程,一般根据cpu的核数去修改
vim nginx.conf
#关闭防火墙,打开80端口
service iptables stop
#启动nginx
./nginx
#重启nginx
./nginx -s reload
#关闭nginx
./nginx -s stop

准备一台tomcat服务器,先准备java环境,安装jdk步骤省略

然后分别安装3个tomcat 服务器ip地址:192.168.1.143,tomcat1 8080端口,tomcat2 8081端口,tomcat3 8082端口。

apache-tomcat-7.0.64/conf/server.xml配置文件修改这三个地方,这样端口就不会冲突

<Server port="8005" shutdown="SHUTDOWN">
<Connector port="8080" protocol="HTTP/1.1"
connectionTimeout="20000"
redirectPort="8443" />
<Connector port="8009" protocol="AJP/1.3" redirectPort="8443" />

修改tomcat ROOT目录下index.jsp,分别增加每个tomcat的标识,以及在页面上显示session ID

<%--
Licensed to the Apache Software Foundation (ASF) under one or more
contributor license agreements. See the NOTICE file distributed with
this work for additional information regarding copyright ownership.
The ASF licenses this file to You under the Apache License, Version 2.0
(the "License"); you may not use this file except in compliance with
the License. You may obtain a copy of the License at

 http://www.apache.org/licenses/LICENSE-2.0

Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.
--%>
<!DOCTYPE html>
<%@ page session="true" %>
<%
java.text.SimpleDateFormat sdf = new java.text.SimpleDateFormat("yyyy");
request.setAttribute("year", sdf.format(new java.util.Date()));
request.setAttribute("tomcatUrl", "http://tomcat.apache.org/");
request.setAttribute("tomcatDocUrl", "/docs/");
request.setAttribute("tomcatExamplesUrl", "/examples/");
%>
<html lang="en">
 <head>
  <title><%=request.getServletContext().getServerInfo() %></title>
  <link href="favicon.ico" rel="icon" type="image/x-icon" />
  <link href="favicon.ico" rel="shortcut icon" type="image/x-icon" />
  <link href="tomcat.css" rel="stylesheet" type="text/css" />
 </head>

 <body>
  <div id="wrapper">
   <div id="navigation" class="curved container">
    <span id="nav-home"><a href="${tomcatUrl}">Home--<%=request.getSession().getId() %></a></span>
    <span id="nav-hosts"><a href="${tomcatDocUrl}">Documentation</a></span>
    <span id="nav-config"><a href="${tomcatDocUrl}config/">Configuration</a></span>
    <span id="nav-examples"><a href="${tomcatExamplesUrl}">Examples</a></span>
    <span id="nav-wiki"><a href="http://wiki.apache.org/tomcat/FrontPage">Wiki</a></span>
    <span id="nav-lists"><a href="${tomcatUrl}lists.html">Mailing Lists</a></span>
    <span id="nav-help"><a href="${tomcatUrl}findhelp.html">Find Help</a></span>
    <br class="separator" />
   </div>
   <div id="asf-box">
    <h1>${pageContext.servletContext.serverInfo}--8080</h1>
   </div>
   <div id="upper" class="curved container">
    <div id="congrats" class="curved container">
     <h2>If you're seeing this, you've successfully installed Tomcat. Congratulations!</h2>
    </div>
    <div id="notice">
     <img src="tomcat.png" alt="[tomcat logo]" />
     <div id="tasks">
      <h3>Recommended Reading:</h3>
      <h4><a href="${tomcatDocUrl}security-howto.html">Security Considerations HOW-TO</a></h4>
      <h4><a href="${tomcatDocUrl}manager-howto.html">Manager Application HOW-TO</a></h4>
      <h4><a href="${tomcatDocUrl}cluster-howto.html">Clustering/Session Replication HOW-TO</a></h4>
     </div>
    </div>
    <div id="actions">
     <div class="button">
      <a class="container shadow" href="/manager/status"><span>Server Status</span></a>
     </div>
     <div class="button">
      <a class="container shadow" href="/manager/html"><span>Manager App</span></a>
     </div>
     <div class="button">
      <a class="container shadow" href="/host-manager/html"><span>Host Manager</span></a>
     </div>
    </div>
    <!--
    <br class="separator" />
    -->
    <br class="separator" />
   </div>
   <div id="middle" class="curved container">
    <h3>Developer Quick Start</h3>
    <div class="col25">
     <div class="container">
      <p><a href="${tomcatDocUrl}setup.html">Tomcat Setup</a></p>
      <p><a href="${tomcatDocUrl}appdev/">First Web Application</a></p>
     </div>
    </div>
    <div class="col25">
     <div class="container">
      <p><a href="${tomcatDocUrl}realm-howto.html">Realms & AAA</a></p>
      <p><a href="${tomcatDocUrl}jndi-datasource-examples-howto.html">JDBC DataSources</a></p>
     </div>
    </div>
    <div class="col25">
     <div class="container">
      <p><a href="${tomcatExamplesUrl}">Examples</a></p>
     </div>
    </div>
    <div class="col25">
     <div class="container">
      <p><a href="http://wiki.apache.org/tomcat/Specifications">Servlet Specifications</a></p>
      <p><a href="http://wiki.apache.org/tomcat/TomcatVersions">Tomcat Versions</a></p>
     </div>
    </div>
    <br class="separator" />
   </div>
   <div id="lower">
    <div id="low-manage" class="">
     <div class="curved container">
      <h3>Managing Tomcat</h3>
      <p>For security, access to the <a href="/manager/html">manager webapp</a> is restricted.
      Users are defined in:</p>
      <pre>$CATALINA_HOME/conf/tomcat-users.xml</pre>
      <p>In Tomcat 7.0 access to the manager application is split between
       different users.   <a href="${tomcatDocUrl}manager-howto.html">Read more...</a></p>
      <br />
      <h4><a href="${tomcatDocUrl}RELEASE-NOTES.txt">Release Notes</a></h4>
      <h4><a href="${tomcatDocUrl}changelog.html">Changelog</a></h4>
      <h4><a href="${tomcatUrl}migration.html">Migration Guide</a></h4>
      <h4><a href="${tomcatUrl}security.html">Security Notices</a></h4>
     </div>
    </div>
    <div id="low-docs" class="">
     <div class="curved container">
      <h3>Documentation</h3>
      <h4><a href="${tomcatDocUrl}">Tomcat 7.0 Documentation</a></h4>
      <h4><a href="${tomcatDocUrl}config/">Tomcat 7.0 Configuration</a></h4>
      <h4><a href="http://wiki.apache.org/tomcat/FrontPage">Tomcat Wiki</a></h4>
      <p>Find additional important configuration information in:</p>
      <pre>$CATALINA_HOME/RUNNING.txt</pre>
      <p>Developers may be interested in:</p>
      <ul>
       <li><a href="http://tomcat.apache.org/bugreport.html">Tomcat 7.0 Bug Database</a></li>
       <li><a href="${tomcatDocUrl}api/index.html">Tomcat 7.0 JavaDocs</a></li>
       <li><a href="http://svn.apache.org/repos/asf/tomcat/tc7.0.x/">Tomcat 7.0 SVN Repository</a></li>
      </ul>
     </div>
    </div>
    <div id="low-help" class="">
     <div class="curved container">
      <h3>Getting Help</h3>
      <h4><a href="${tomcatUrl}faq/">FAQ</a> and <a href="${tomcatUrl}lists.html">Mailing Lists</a></h4>
      <p>The following mailing lists are available:</p>
      <ul>
       <li id="list-announce"><strong><a href="${tomcatUrl}lists.html#tomcat-announce">tomcat-announce</a><br />
        Important announcements, releases, security vulnerability notifications. (Low volume).</strong>
       </li>
       <li><a href="${tomcatUrl}lists.html#tomcat-users">tomcat-users</a><br />
        User support and discussion
       </li>
       <li><a href="${tomcatUrl}lists.html#taglibs-user">taglibs-user</a><br />
        User support and discussion for <a href="${tomcatUrl}taglibs/">Apache Taglibs</a>
       </li>
       <li><a href="${tomcatUrl}lists.html#tomcat-dev">tomcat-dev</a><br />
        Development mailing list, including commit messages
       </li>
      </ul>
     </div>
    </div>
    <br class="separator" />
   </div>
   <div id="footer" class="curved container">
    <div class="col20">
     <div class="container">
      <h4>Other Downloads</h4>
      <ul>
       <li><a href="${tomcatUrl}download-connectors.cgi">Tomcat Connectors</a></li>
       <li><a href="${tomcatUrl}download-native.cgi">Tomcat Native</a></li>
       <li><a href="${tomcatUrl}taglibs/">Taglibs</a></li>
       <li><a href="${tomcatDocUrl}deployer-howto.html">Deployer</a></li>
      </ul>
     </div>
    </div>
    <div class="col20">
     <div class="container">
      <h4>Other Documentation</h4>
      <ul>
       <li><a href="${tomcatUrl}connectors-doc/">Tomcat Connectors</a></li>
       <li><a href="${tomcatUrl}connectors-doc/">mod_jk Documentation</a></li>
       <li><a href="${tomcatUrl}native-doc/">Tomcat Native</a></li>
       <li><a href="${tomcatDocUrl}deployer-howto.html">Deployer</a></li>
      </ul>
     </div>
    </div>
    <div class="col20">
     <div class="container">
      <h4>Get Involved</h4>
      <ul>
       <li><a href="${tomcatUrl}getinvolved.html">Overview</a></li>
       <li><a href="${tomcatUrl}svn.html">SVN Repositories</a></li>
       <li><a href="${tomcatUrl}lists.html">Mailing Lists</a></li>
       <li><a href="http://wiki.apache.org/tomcat/FrontPage">Wiki</a></li>
      </ul>
     </div>
    </div>
    <div class="col20">
     <div class="container">
      <h4>Miscellaneous</h4>
      <ul>
       <li><a href="${tomcatUrl}contact.html">Contact</a></li>
       <li><a href="${tomcatUrl}legal.html">Legal</a></li>
       <li><a href="http://www.apache.org/foundation/sponsorship.html">Sponsorship</a></li>
       <li><a href="http://www.apache.org/foundation/thanks.html">Thanks</a></li>
      </ul>
     </div>
    </div>
    <div class="col20">
     <div class="container">
      <h4>Apache Software Foundation</h4>
      <ul>
       <li><a href="${tomcatUrl}whoweare.html">Who We Are</a></li>
       <li><a href="${tomcatUrl}heritage.html">Heritage</a></li>
       <li><a href="http://www.apache.org">Apache Home</a></li>
       <li><a href="${tomcatUrl}resources.html">Resources</a></li>
      </ul>
     </div>
    </div>
    <br class="separator" />
   </div>
   <p class="copyright">Copyright ©1999-${year} Apache Software Foundation. All Rights Reserved</p>
  </div>
 </body>

</html>

这时候 修改nginx配置文件nginx.conf,把三台tomcat的ip地址以及端口号加入进去,使用nginx做代理

#user nobody;
worker_processes 1;

#error_log logs/error.log;
#error_log logs/error.log notice;
#error_log logs/error.log info;

#pid  logs/nginx.pid;

events {
 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;

 sendfile  on;
 #tcp_nopush  on;

 #keepalive_timeout 0;
 keepalive_timeout 65;

 #gzip on;

 upstream localhost1 { 

   #ip_hash;
   server 192.168.1.143:8080;
   server 192.168.1.143:8081;
   server 192.168.1.143:8082;
 } 

 server {
  listen  81;
  server_name localhost;

  #charset koi8-r;

  #access_log logs/host.access.log main;

  location / {
    proxy_connect_timeout 3;
    proxy_send_timeout  30;
    proxy_read_timeout  30;
    proxy_pass http://localhost1;
  }

  #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;
 # server_name localhost;

 # ssl     on;
 # ssl_certificate  cert.pem;
 # ssl_certificate_key cert.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;
 # }
 #}

}

这时候,分别启动三台tomcat以及nginx,访问http://192.168.1.133:81,这时候每次刷新页面,都会随机访问8080或者8081或者8082,而且页面上出现的session id也都是不一样的,我们应该如何让这三台tomcat共享session呢,我们使用redis来做。

这时候,在已经按照三台tomcat的服务器192.168.1.143上,安装redis,安装步骤如下:

$ wget http://download.redis.io/releases/redis-3.2.3.tar.gz
$ tar xzf redis-3.2.3.tar.gz
$ cd redis-3.2.3
$ make MALLOC=libc
#启动redis src前面是安装的路径
$ src/redis-server &

#关闭redis
src/redis-cli shutdown
#使用redis 放入键值对 key value
$ src/redis-cli
127.0.0.1:6379> set foo bar
OK
127.0.0.1:6379> get foo
"bar"
$

安装完redis之后,在三个tomcat的lib文件夹内分别上传这五个所依赖的jar,分别是

commons-pool2-2.0.jar

jedis-2.5.2.jar

tomcat-redis-session-manager1.2.jar

tomcat-juli.jar

tomcat-juli-adapters.jar

所有jar在这里了,下载地址

然后分别修个三个tomcat的context.xml文件,增加如下的配置

<?xml version='1.0' encoding='utf-8'?>

<Context>

 <!-- Default set of monitored resources -->
 <WatchedResource>WEB-INF/web.xml</WatchedResource>

 <!-- 这里增加redis session共享的配置 6379是redis的端口-->
 <Valve className="com.orangefunction.tomcat.redissessions.RedisSessionHandlerValve" />
 <Manager className="com.orangefunction.tomcat.redissessions.RedisSessionManager"
 host="127.0.0.1"
 port="6379"
 database="0"
 maxInactiveInterval="60" />
</Context>

这时候,分别重启三个tomcat以及nginx,查看tomcat日志之后,发现没有任何异常报错,说明我们成功了,接下来开始测试。

我们访问nginx服务器地址:http://192.168.1.133:81/

得到的是8080端口的 tomcat1 ,session id为1A0625767F27BA95EF4D5F061FE0568D

这时候按F5刷新页面,得到的是8081端口的 tomcat2 ,session id依旧是 1A0625767F27BA95EF4D5F061FE0568D

再次刷新页面,得到的是8082端口的 tomcat3,session id依旧是 1A0625767F27BA95EF4D5F061FE0568D。 、

这时候,说明我们搭建tomcat + nginx负载均衡 + redis session同步成功啦!

nginx帮助把我们的请求均匀的分发给三个tomcat --》tomcat1 、tomcat2以及tomcat3

redis帮助我们同步session,这样一来,我们的服务器性能就会提高许多,任何一台tomcat发生故障后,对整体的服务都不会有影响了。

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

(0)

相关推荐

  • 深入浅析TomCat Session管理分析

    前言 对于广大java开发者而已,对于J2EE规范中的Session应该并不陌生,我们可以使用Session管理用户的会话信息,最常见的就是拿Session用来存放用户登录.身份.权限及状态等信息.对于使用Tomcat作为Web容器的大部分开发人员而言,Tomcat是如何实现Session标记用户和管理Session信息的呢? 概要 SESSION Tomcat内部定义了Session和HttpSession这两个会话相关的接口,其类继承体系如图1所示. 图1 Session类继承体系 图1中额

  • Java中tomcat memecached session 共享同步问题的解决办法

    事件缘由:一个主项目"图说美物",另外一个子功能是品牌商的入驻功能,是跟主项目分开的项目,为了共享登录的用户信息,而实现session共享,俩个tomcat,一个tomcat6,一个tomcat7 web项目windows系统下实现session的共享 第一个步: 在俩个tomcat的context.xml这个文件中配置如下代码: <Manager className="de.javakaffee.web.msm.MemcachedBackupSessionManage

  • Tomcat集群和Session复制应用介绍

    一个配置文件: 复制代码 代码如下: <Cluster className="org.apache.catalina.ha.tcp.SimpleTcpCluster" channelSendOptions="6"> <Manager className="org.apache.catalina.ha.session.BackupManager" expireSessionsOnShutdown="false"

  • Tomcat中实现Session小结

    什么是Session 对Tomcat而言,Session是一块在服务器开辟的内存空间,其存储结构为ConcurrentHashMap: Session的目的 Http协议是一种无状态协议,即每次服务端接收到客户端的请求时,都是一个全新的请求,服务器并不知道客户端的历史请求记录: Session的主要目的就是为了弥补Http的无状态特性.简单的说,就是服务器可以利用session存储客户端在同一个会话期间的一些操作记录: 实现机制 先看两个问题,如下: 1.服务器如何判断客户端发送过来的请求是属于

  • Tomcat中session的管理机制

    详细描述Tomcat中session的管理机制: 1. 请求过程中的session操作: 简述:在请求过程中首先要解析请求中的sessionId信息,然后将sessionId存储到request的参数列表中.然后再从 request获取session的时候,如果存在sessionId那么就根据Id从session池中获取session,如果sessionId不 存在或者session失效,那么则新建session并且将session信息放入session池,供下次使用. (1)SessionId

  • Tomcat实现session共享(session 会话复制)

    一.如何保持session会话 目前,为了使web能适应大规模的访问,需要实现应用的集群部署.集群最有效的方案就是负载均衡,而实现负载均衡用户每一个请求都有可能被分配到不固定的服务器上,这样我们首先要解决session的统一来保证无论用户的请求被转发到哪个服务器上都能保证用户的正常使用,即需要实现session的共享机制. 在集群系统下实现session统一的有如下几种方案: 1.请求精确定位:session sticky,例如基于访问ip的hash策略,即当前用户的请求都集中定位到一台服务器中

  • Nginx+Tomcat高性能负载均衡集群搭建教程

    Nginx是一个高性能的HTTP服务器/反向代理服务器及电子邮件(IMAP/POP3)代理服务器.其占有内存少,并发能力强,在同类型的网页服务器中表现较好.Nginx可以在大多数Unix Linux OS上编译运行,并有Windows移植版.一般情况下,对于新建站点,建议使用最新稳定版作为生产版本. 单个Tomcat最大支持在线访问是500左右,要通知支持更多的访问量一个Tomcat就没法做到了.在这里我们采用集群部署方式,使用多个Tomcat,反向代理使用Nginx. 架构如下: 准备工作 a

  • Windows下使用Nginx+Tomcat做负载均衡的完整步骤

    前言 今天,王子与大家闲谈一下如何在Windows下使用Nginx+Tomcat做负载均衡的完整步骤,小伙伴们可以试着自己动手实践一下哦. 另外说明一点,本篇文章是纯实操文章,不涉及太多原理的解读,后期可能单独开一个专栏来深入讨论Nginx的原理. 好了那我们直接开始. 下载Nginx 首先我们去官网下载一个Windows稳定版本的Nginx,官网地址:http://nginx.org/en/download.html 下载后解压到想要的位置,小伙伴们要注意了,千万不要把它解压到带有中文的文件夹

  • Nginx+Tomcat实现负载均衡、动静分离的原理解析

    一.Nginx 负载均衡实现原理 1.Nginx 实现负载均衡是通过反向代理实现 反向代理(Reverse Proxy) 是指以 代理服务器(例:Nginx) 来接受 internet 上的连接请求,然后将请求转发给内部网络上的服务器(例:Tomcat),并将从服务器上得到的结果返回给 internet 上请求连接的客户端,此时代理服务器(例:Nginx)对外就表现为一个反向代理服务器. 我们从客户端的视野来看,实际上客户端并不知道真实的服务提供者是哪台服务器,它只知道它请求了反向代理服务器.因

  • 使用Nginx+Tomcat实现负载均衡的全过程

    目录 1. 环境 2. 安装 2.1 安装 Nginx 2.2 安装 Java 2.3 安装 Tomcat 3. 部署 3.1 Tomcat 服务器部署 3.2 Nginx 反向代理 4. 负载均衡 4.1 轮询 4.2 加权轮询 4.2 IP Hash 总结 Nginx + Tomcat 实现负载均衡 1. 环境 Linux version: 5.4.0-96-generic OS Version: ubuntu1~20.04 Architecture: amd64 Nginx version

  • nginx+tomcat实现负载均衡,使用redis session共享

    环境准备 1.准备一台nginx服务器 ip192.168.1.133 端口81 安装过程: #首先安装依赖: yum -y install gcc-c++ yum -y install pcre pcre-devel yum -y install zlib zlib-devel yum -y install openssl openssl-devel #注意 : 安装nginx必须使用 root 用户安装 #创建一个nginx目录 mkdir /usr/local/src/nginx #进入到

  • windows下nginx+tomcat配置负载均衡的方法

    目标:Nginx做为HttpServer,连接多个tomcat应用实例,进行负载均衡. 注:本例程以一台机器为例子,即同一台机器上装一个nginx和2个Tomcat且安装了JDK1.7. 1.安装Nginx 安装Nginx教程 2.配置两个Tomcat 在本机上配置两个Tomcat,分别为tomcat7-8081.tomcat7-8082. tomcat7-8081访问地址:http://localhost:8081,浏览显示内容:this is 8081 port tomcat7-8082访问

  • Nginx服务器做负载均衡反向代理的超级攻略

    nginx 做反向代理时,后端主机有多台,可以使用 upstream 定义一个后端主机池,在反向代理时直接使用主机池的名字.在 upstream 中可以定义负载均衡调度算法,权重,健康状态检测等参数. 例如: upstream backend { server 172.16.0.1:80 weight=1 max-fails=3 fail_timeout=10; server 172.16.0.2:80 weight=1max-fails=3 fail_timeout=10;; } 默认请求下,

  • 简单了解Nginx七层负载均衡的几种调度算法

    这篇文章主要介绍了简单了解Nginx七层负载均衡的几种调度算法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下 Nginx是一款轻量级的高性能web服务器,同时也是一款非常优秀的负载均衡器和反向代理服务器.由于支持强大的正则匹配规则.动静分离.URLrewrite功能及安装配置简单且对网络稳定性依赖非常小等优点,所以常用来做为七层负载均衡使用.在硬件不差的情况下,通常可以稳定支持几万的并发连接,在硬件性能足够好,且对系统内核参数及Nginx配置进

  • Nginx如何配置负载均衡

    Nginx配置负载均衡 使用nginx来配置负载均衡也是比较简单的 首先在http块中配置虚拟域名所对应的地址 # 负载均衡 upstream myserver { server 127.0.0.1:8080; server 127.0.0.1:8082; } 然后在server块中配置监听 server { listen 9000; server_name localhost; location / { root html; index index.html index.htm; # 对应上述

  • Nginx stream 配置代理(Nginx TCP/UDP 负载均衡)

    前奏 我们都知道 nginx 是一款优秀的反向代理服务,用过 nginx 的也应该都知道 upstream,upstream 节点一般置于 http 节点大括号中,常规在 upstream 中配置需要被负载均衡的服务器列表. 比较多的使用做如下示意: #user nobody nobody. #worker_processes 2; #pid /nginx/pid/nginx.pid; error_log log/error.log debug; events { -- } http { --

随机推荐