linux下一个apache+tomcat负载均衡和集群

先说一下我的环境

一个ubuntu虚拟机,

一个apache2.2示例

两tomcat1.7示例


1.安装apacheserver

sudo apt-get install apache2
假设要重新启动的话,执行命令:

sudo /etc/init.d/apache2 restart

ubuntu下的apache会默认创建路径/var/www,apache默认载入的时候,就是载入的这个路径以下的

2.安装两个tomcat实例

去官网下载一个

然后在本地在cp一下,

此时文件夹结构为:

/home/hehe/my/soft/tomcat1,

/home/hehe/my/soft/tomcat2

3.安装mod_jk

mod_jk实质上是Apache与Tomcat的连接器,并藉此附带提供集群和负载均衡的功能。

地址为http://archive.apache.org/dist/tomcat/tomcat-connectors/jk/binaries/linux/jk-1.2.31/x86_64/,注意要于你安装的apache的版本号相应。

4.配置apache

    ubuntu默认会将apache的安装文件放在/etc/apache2以下

进入这个文件夹之后,新建一个httpd.conf文件

放心apache启动时,会载入这个文件的

然后编译这个文件。加上这么句话

ServerName localhost:80include mod_jk.conf
         

然后我们在当前路径下新建一个mod_jk.conf文件

这里先要将mod_jk-1.2.31-httpd-2.2.x.so放在当前路径下

#load module mod_jk-1.2.31-httpd-2.2.3.so is for Apache 2.2.x.  
LoadModule jk_module /usr/lib/apache2/modules/mod_jk-1.2.31-httpd-2.2.x.so#这个是用来配置负载的
JkWorkersFile workers.properties
#这个是打印日志
JkLogLevel debug
#这个是日志的名称
JkLogFile mod_jk.log
#打印的级别
JkLogLevel warn

所以在当前路径下咱们还得新建一个 mod_jk.log,文件。这里面会记录日志

接下来配置workers.properties文件

在当前路径下新建一个workers.properties文件

#负载均衡器
worker.list=LB_worker,worker_1,worker_2,jkstatus  #第一个tomcat的配置
worker.worker_1.host=localhost #tomcat在哪个机器上面,若是别的机器。须要写上别的机器的ip地址  
worker.worker_1.port=8009      #端口,等会在tomcat里面配置的时候要一一相应
worker.worker_1.type=ajp13     
worker.worker_1.lbfactor=1     #载入因子#第二个tomcat的配置
worker.worker_2.host=localhost  
worker.worker_2.port=9009  
worker.worker_2.type=ajp13  
worker.worker_2.lbfactor=1  #类型是一个负载均衡器
worker.LB_worker.type=lb
#重试三次
worker.LB_worker.retries=3
#负载给tomcat1和tomcat2
worker.LB_worker.balance_workers=worker_1,worker_2
#这是说session的粘性,就是说同一个session是否提交给同一个tomcat。由于等会儿,集群的时候要用到一个session提交给两台机器,所以设置为false
worker.LB_worker.sticky_session=false  
worker.LB_worker.sticky_session_force=false
#jk的状态  
worker.jkstatus.type=status
5.配置请求交给负载均衡器

在/etc/apache2/sites-available下有个default文件,

在这个文件的最后一句话</VirtualHost>之前加上这么一段

JkMount /*.jsp LB_worker
JkMount /jkstatus jkstatus
然后就交给了LB_worker

6.接下来配置tomcat1

改一下conf以下的server.xml文件,改port,和上面的相应

   <Connector port="8009" protocol="AJP/1.3" redirectPort="8443" />

然后找到这句话,改成这样,注意worker_1和workers.properties相应

<Engine name="Catalina" defaultHost="localhost" jvmRoute="worker_1">

若是集群的话,还要改一句话。把这句话的前后的凝视符号给去掉,放开

<Cluster className="org.apache.catalina.ha.tcp.SimpleTcpCluster"/>

接下来配置tomcat2

先把以下这句话给改了,port号改为8006

<Server port="8006" shutdown="SHUTDOWN">

然后改以下这句

    <Connector port="9082" protocol="HTTP/1.1"connectionTimeout="20000"redirectPort="9443" />

改一下conf以下的server.xml文件,改port。和上面的相应

   <Connector port="9009" protocol="AJP/1.3" redirectPort="9443" />

然后找到这句话,改成这样。注意worker_2和workers.properties相应

<Engine name="Catalina" defaultHost="localhost" jvmRoute="worker_2">

若是集群的话,还要改一句话,把这句话的前后的凝视符号给去掉,放开

<Cluster className="org.apache.catalina.ha.tcp.SimpleTcpCluster"/>

7.新建一个项目mytest,里面有一个叫wel.jsp的文件,

这个jsp的内容是:

<%@ page language="java" contentType="text/html; charset=GB18030"pageEncoding="GB18030"%>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=GB18030">
<title>Insert title here</title>
</head>
<body>
<%System.out.println("this is tomcat server nod 2");
%>
<%
int i=0;while(i<3000){i++;}out.println(request.getLocalAddr() + " : " + request.getLocalPort()+"<br>this is tomcat server nod 2");
%>
</body>
</html>
然后将这个项目放在tomcat2的webapp以下

同一时候也放在tomcat1的文件夹下

注意。以下这句改成这样,2改为1

   System.out.println("this is tomcat server nod 1");


    out.println(request.getLocalAddr() + " : " + request.getLocalPort()+"<br>this is tomcat server nod 1");

8.重新启动一个apache,tomcat1,tomcat2

然后在浏览器里面訪问

http://127.0.0.1/mytest/wel.jsp

不断的刷新页面。你会发现其在node1,和node2之间不断换。说明请求有时候交给了1,有时候交给了tomcat2,实现了负载均衡的功能


以下在来实现tomcat1。和tomcat2的集群功能

所谓集群就是。一个client的相应的session在两个tomcat中有一模一样的相应的session

在mytest里面在新建一个wel2.jsp文件

里面的内容为:

<%@ page contentType="text/html; charset=utf-8" %>
<%@ page import="java.util.*" %>
<html><head><title>Cluster App Test</title></head>
<body>
Server Info:
<%
out.println(request.getLocalAddr() + " : " + request.getLocalPort()+"<br>");%>
<%out.println("<br> ID " + session.getId()+"<br>");// 在session里面设置属性String dataName = request.getParameter("attributeName");if (dataName != null && dataName.length() > 0) {String dataValue = request.getParameter("attributeValue");session.setAttribute(dataName, dataValue);}out.print("<b>打印Session内容:>");Enumeration e = session.getAttributeNames();while (e.hasMoreElements()) {String name = (String)e.nextElement();String value = session.getAttribute(name).toString();out.println( name + " = " + value+"<br>");System.out.println( name + " = " + value);}
%><form action="wel2.jsp" method="POST">属性名:<input type=text size=20 name="attributeName"><br>值:<input type=text size=20 name="attributeValue"><br><input type=submit></form>
</body>
   </form>
</body>
</html>
两个tomcat里面都有一个这种文件

然后两个tomcat的web.xml以下加上以下这句话

<distributable/>,两个session之间能相互复制

重新启动

然后訪问http://10.211.55.3/mytest/wel2.jsp


又一次输入这个地址



你会发现确实交给了两个server,并且session里面的值一模一样!

集群完毕。




版权声明:本文博客原创文章,博客,未经同意,不得转载。

转载于:https://www.cnblogs.com/mfrbuaa/p/4662420.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/256988.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

JS实现css属性动画效果

html代码 <!DOCTYPE html> <html><head><meta charset"UTF-8"><title>css属性运动框架</title><style>body,div{margin: 0;padding: 0;}ul,li{list-style: none;}ul li{width: 200px;height: 100px;background: yellowgre…

学习笔记(24):Python网络编程并发编程-进程与线程的区别

立即学习:https://edu.csdn.net/course/play/24458/296438?utm_sourceblogtoedu 线程与进程的区别&#xff1a; 1.消耗区别&#xff1a;进程>线程 1&#xff09;进程运行结果 #进程运行 from multiprocessing import Process def task(name):print("我是%s"%na…

Codeforces Beta Round #1

A /*************************************************************************> File Name: A.cpp> Author: opas_chenxin> Mail: 1017370773qq.com > Created Time: 2016年05月06日 星期五 02时22分23秒 ************************************************…

windows系统中创建线程常用哪几个函数,有什么区别?

windows系统中创建线程常用哪几个函数&#xff1f; 在windows系统中创建线程的函数有&#xff1a; CreadThread&#xff0c;AfxBeginThread&#xff0c;_beginthread&#xff0c;_beginthreadex。 他们的区别在于使用的场景不同。 CreateThread是Windows的API函数(SDK函数的标…

java.lang.String小测试

还记得java.lang.String么&#xff0c;如果现在给你一个小程序&#xff0c;你能说出它的结果么 1 public static String ab(String a){2 return a "b";3 }4 5 public static void testAb(){6 String x "a";7 ab…

Oracle传输表空间

一、简介 可传输表空间(还有个集)最大的优势是其速度比export/import或unload/load要快的多。因为可传输表空间主要是复制数据文件到目标路径&#xff0c;然后再使用export/import或Data Pump export/import等应用仅导出/导入表空间对象的元数据到新数据库。 &#xff08;1&…

进程控制块PCB结构体 task_struct 描述

进程控制块&#xff0c;英文名&#xff08;Processing Control Block&#xff09;&#xff0c;简称 PCB 。 进程控制块是系统为了管理进程设置的一个专门的数据结构&#xff0c;主要表示进程状态。 每一个进程都对应一个PCB来维护进程相关的信息&#xff1b; 在Linux中&#xf…

基于OpenCV与tensorflow实现实时手势识别

基于OpenCV与tensorflow object detection API使用迁移学习&#xff0c;基于SSD模型训练实现手势识别完整流程&#xff0c;涉及到数据集收集与标注、VOC2012数据集制作&#xff0c;tfrecord数据生成、SSD迁移学习与模型导出&#xff0c;OpenCV摄像头实时视频流读取与检测处理&a…

学习笔记(25):Python网络编程并发编程-Thread其他属性和守护线程

立即学习:https://edu.csdn.net/course/play/24458/296440?utm_sourceblogtoedu 1.Thread其他的属性 CurrentThread().getName():获得当前线程的名字 t.is_Alive:判断线程是否还在运行 t.join():等待线程运行结束再执行join后面的代码 t.setName("name"):为线程…

AIX主机信任关系配置

1.配置主机信任关系的时候&#xff0c;需要先在两台主机/etc/hosts文件中添加要信任主机的&#xff29;&#xff30;&#xff0c;假设有(192.168.8.190 aix190,192.168.8.191 aix191)2个主机,在191主机配置如下所示 192.168.8.190 aix190 2.如果系统配置DNS&#xff0c;则需要去…

Sprint2团队贡献分

团队贡献分&#xff1a; 郭志豪&#xff1a;31% http://www.cnblogs.com/gzh13692021053/ 杨子健&#xff1a;22%http://www.cnblogs.com/yzj666/ 谭宇森&#xff1a;23%http://www.cnblogs.com/yzj666/ 刘森松&#xff1a;24% http://www.cnblogs.com/lssh/转载于:https://w…

学习笔记(26):Python网络编程并发编程-GIL与自定义互斥锁的区别

立即学习:https://edu.csdn.net/course/play/24458/296443?utm_sourceblogtoedu 1.GIL的基本概念 答&#xff1a;GIL本质上就是一把锁&#xff0c;只是他是一把在python解释器上的锁 2.GIL与互斥锁的区别 答&#xff1a; 1&#xff09;GIL保护的是在python解释器上的参数&a…

多目标跟踪检测

方法&#xff1a; 1、实时性&#xff0c;每帧视频10ms 2、方法&#xff0c;首先深度学习检测到目标&#xff0c;然后再写跟踪算法

2014年最具人气国外WORDPRESS主题

在国外&#xff0c;WrodPress这个博客系统极为受欢迎&#xff0c;使用WordPress来建站可以降低很多成本&#xff0c;另外还能以十分便宜的价格获得一个漂亮的WP网站模板。 今天向大家分享来自Themeforest 2014年最具人气的高级WrodPress主题&#xff0c;这些主题无论是设计还是…

软件工程学习感想

通过这半学期我对软件工程的学习&#xff0c;从软件工程的基础到考试用户的需求分析与求解&#xff0c;最后到黑盒白盒测试通过自身做过的一些案例&#xff0c;讲解了软件工程这门本身枯燥乏味的课程&#xff0c;这不仅增强了学生学习的积极性&#xff0c;也通过让我们自己去做…

开源视觉salm算法介绍

当前的开源SLAM方案 开源方案传感器形式地址链接MonoSLAM单目https://github.com/hanmekim/SceneLib2 PTAM单目 http://www.robots.ox.ac.uk/~gk/PTAM/ORB-SLAM 单目为主http://webdiis.unizar.es/~raulmur/orbslam/ORB-SLAM2单目https://github.com/raulmur/ORB_SLAM2LSD-SLAM…

学习笔记(27):Python网络编程并发编程-GIL与多线程

立即学习:https://edu.csdn.net/course/play/24458/296444?utm_sourceblogtoedu GIL与多线程 1.须知&#xff1a; 1&#xff09;cpu主要是为了提升计算性能&#xff0c;增加CPU提升计算性能&#xff1b; 2&#xff09;每一个CPU一旦遇到阻塞状态都会处于等待状态&#xff0c…

J0ker的CISSP之路:复习-Access Control(3)

本文同时发表在&#xff1a;[url]http://netsecurity.51cto.com/art/200801/63649.htm[/url] 在《J0ker的CISSP之路》系列的上一篇文章里&#xff0c;J0ker给大家介绍了访问控制CBK里面一些常见的破坏信息资产保密性的威胁类型&#xff0c;那么什么类型的威胁会破坏信息资产的完…

C#中对泛型List进行分组输出元素

背景&#xff1a;在输出列表时&#xff0c;往往需要按照某一字段进行分组&#xff0c;比如在输出城市列表时&#xff0c;按照首字母进行分组&#xff0c;输出学生列表时&#xff0c;按照年级进行分组&#xff0c;然后再对分组的结果按照其他的字段进行排序。 如存在以下STU学生…

分页3

http://www.cnblogs.com/ChrisLee2011/p/4288194.html 页面的HTML部分如下&#xff1a; < div class "tableContainer"> < input id "currentPage" type "hidden" value " ViewData[ "currentPage"] "/> < i…