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

[经验分享] Linux下Apache+Tomcat负载均衡配置(一机多实例)

[复制链接]

尚未签到

发表于 2015-8-3 10:03:27 | 显示全部楼层 |阅读模式
  LINUX 下配置Apache+Tomcat负载均衡(一机多实例)
  (1)解压安装
  
  1)安装JDK
  #./jdk-6u10-rc-bin-b28-linux-i586-21_jul_2008-rpm.bin
  运行后会显示一大篇协议,按空格跳过。看到最后出现[yes]时输入yes回车确认。
  添加JDK的环境变量
  用文本编辑器打开/etc/profile,在文件的最后添加以下内容:
  JAVA_HOME=/usr/java/jdk1.6.0_10
  CLASSPATH=.:$JAVA_HOME/lib:$JAVA_HOME/jre/lib
  PATH=$PATH:$JAVA_HOME/bin:$JAVA_HOME/jre/bin
  export JAVA_HOME CLASSPATH PATH
  保存退出,然后注销一次或运行:source /etc/profile命令使系统环境变量生效。
  确定环境变量生效后可以终端中运行:java -version命令测试是否安装成功。
  java version "1.6.0_10-rc"
  Java(TM) SE Runtime Environment (build 1.6.0_10-rc-b28)
  Java HotSpot(TM) Client VM (build 11.0-b15, mixed mode, sharing)
  若出现以上文字那么JDK已经OK了。
  
  2)安装apache
  tar -zxvf httpd-2.2.16.tar.gz
  程序解压后得到名为:httpd-2.2.16的文件夹。继续运行以下命令:
  cd httpd-2.2.16
  ./configure --prefix=/usr/local/apache --enable-modules=so --enable-mods-shared-all --enable-proxy --enable-proxy-connect --enable-proxy-ftp --enable-proxy-http --enable-proxy-ajp --enable-proxy-balancer
  make
  make install
  
  3)配置apache文件
  修改apache的配置文件httpd.conf
  vi /usr/local/apache/conf/httpd.conf命令进行编辑。
  
  DirectoryIndex index.html index.jsp
  
  找到#Include conf/extra/httpd-vhosts.conf,将前面的注释符#去掉。
  在文件的最后添加以下内容并保存:
  ProxyRequests Off
  
  BalancerMember ajp://localhost:8009 loadfactor=2 route=jvm1
  BalancerMember ajp://localhost:8010loadfactor=2 route=jvm2
  BalancerMember ajp://localhost:8011loadfactor=2 route=jvm3
  BalancerMember ajp://localhost:8012loadfactor=2 route=jvm3
  
  
  修改apache的配置文件httpd-vhosts.conf
  该文件所在路径为:/usr/local/apache/conf/extra/httpd-vhosts.conf
  将文件中以下内容注释掉:
  #
  #    ServerAdmin webmaster@dummy-host.example.com
  #    DocumentRoot "/usr/local/apache/docs/dummy-host.example.com"
  #    ServerName dummy-host.example.com
  #    ServerAlias www.dummy-host.example.com
  #    ErrorLog "logs/dummy-host.example.com-error_log"
  #    CustomLog "logs/dummy-host.example.com-access_log" common
  #
  #
  #    ServerAdmin webmaster@dummy-host2.example.com
  #    DocumentRoot "/usr/local/apache/docs/dummy-host2.example.com"
  #    ServerName dummy-host2.example.com
  #    ErrorLog "logs/dummy-host2.example.com-error_log"
  #    CustomLog "logs/dummy-host2.example.com-access_log" common
  #
  在文件末尾添加以下内容并保存:
  
  ServerAdmin cntangjun@test.com
  ServerName localhost
  ServerAlias localhost
  ProxyPass / balancer://RHEL5-1/ stickysession=jsessionidnofailover=On
  ProxyPassReverse / balancer://RHEL5-1/
  
  
  修改apache的配置文件httpd-info.conf
  
  SetHandler server-status
      Order deny,allow
  #   Deny from all
      Allow from all
  
  #
  # ExtendedStatus controls whether Apache will generate "full" status
  # information (ExtendedStatus On) or just basic information (ExtendedStatus
  # Off) when the "server-status" handler is called. The default is Off.
  #
  ExtendedStatus On
  #
  # Allow remote server configuration reports, with the URL of
  # http://servername/server-info (requires that mod_info.c be loaded).
  # Change the ".example.com" to match your domain to enable.
  #
  
  SetHandler server-info
      Order deny,allow
  #   Deny from all
      Allow from all
  
  
  SetHandler balancer-manager
      Order deny,allow
  #   Deny from all
      Allow from all
  
  
  
  (2)配置Tomcat
  先在/usr/local目录中建一个名为tomcat的文件夹,然后在终端中运行:
  tar -zxvf apache-tomcat-6.0.20.tar.gz
  程序解压后得到名为:apache-tomcat-6.0.20的文件夹,将它复制四份到/usr/local/tomcat目录并重命名为tomcat6-1、tomcat6-2、tomcat6-3、tomcat6-4、
  进入tomcat6-1目录,修改conf目录下的server.xml文件(以下两个项目不变)
  
  
  找到文件中这一行,将它改为:
  
  说明:这里的jvmRoute的值必须对应于httpd.conf文件中最末添加的route的值。
  接着在刚才修改的那一行下添加以下内容并保存:
  
  -
  
  -
  
  
  -
  
  
  
  
  
  
  
  
  
  
  
  
  将保存后的server.xml文件复制一分到tomcat6-2/3/4的对应文件夹下替换掉原文件。并打开修改下面几处:
  
  
  
  
  
  
  分别对应修改端口,不要冲突就可以了,另外ajp端口一定要对应上httpd.conf中配置的端口
  
  (3)启动服务
  先启动各tomcat:
  /usr/local/tomcat/tomcat6-1/catalina.sh run
  /usr/local/tomcat/tomcat6-2/catalina.sh run
  /usr/local/tomcat/tomcat6-3/catalina.sh run
  /usr/local/tomcat/tomcat6-4/catalina.sh run
  再启动apache:
  /usr/local/apache/bin/httpd -k start
  重启apache
  
/usr/local/apache/bin/httpd -k restart
  打开浏览器,通过http://127.0.0.1来访问一下,应该就会出现大家熟悉的猫猫了。
  然后再分别用
  http://127.0.0.1:8080
  http://127.0.0.1:8081
  http://127.0.0.1:8082
  http://127.0.0.1:8083
  
  来访问一下,
  它们显示的内容应该是和http://127.0.0.1一样的,这样就说明apache和tomcat整合成功!
  
  
  (4)给tomcat增加管理用户(有时间的话分别给tomcat下conf文件下user.xml中添加管理员用户。)
  
  
  
  
  
  
  
  (5)最后完工,重启tomcat,apahce测试平衡负载,新建测试目录test和test.jsp页面
  
  
  
  分别放入到tomcat的ROOT目录中测试
  
  
  测试session复制
  修改测试项目test修改test.jsp,内容如下
  
  
  Cluster App Test
  
  Server Info:
  
   0) {
       String dataValue = request.getParameter("dataValue");
  session.setAttribute(dataName, dataValue);
   } out.print("Session 列表"); Enumeration e = session.getAttributeNames();
   while (e.hasMoreElements()) {
       String name = (String)e.nextElement();
       String value = session.getAttribute(name).toString();
  out.println( name + " = " + value+"");
  System.out.println( name + " = " + value);
     }
  %>
  
  名称:
  
  值:
  
  
  
  
  
  
  然后在test 新建WEB-INF目录,WEB-INF下新建web.xml,内容如下
  
  
  TomcatDemo
  
  
  
  注意:在你的应用的web.xml加入即可
  把test复制到tomcat6-1/2/3/4的webapps下,重启apache,tomcat,
  
  输入网址 http://localhost/test/test.jsp   新建一个名称为:tangjun,值为中国的session,提交查询,新开一个ie窗口,再提交查询,如图,可以看到,两个tomcat 是负载均衡,并且session同步的,也可以不断的刷新,可以看到轮流访问四个页面,但是值仍然是一样的。
  
    
  关于tomcat热备份
  需要修改apache的httpd.conf文件

  
ProxyPass / balancer://hotcluster/

    BalancerMember ajp://localhost:8009
    BalancerMember ajp://localhost:8010 status=+H
    ProxySet lbmethod=bytraffic

  然后重启apache


  
  
  

运维网声明 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-93574-1-1.html 上篇帖子: 基于Apache与Tomcat的Java平台部署方案 下篇帖子: Apache配置文件属性、参数的含义
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

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

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

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

扫描微信二维码查看详情

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


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


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


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



合作伙伴: 青云cloud

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