先在官网上下载jdk以及
tomcat的tar包
解压 我这里解压在/usr/local
做一个软连接 可以方便更新所用
在全局变量里面做好声明
vim /etc/profile
下面做一个调度
重新打开一台机器作相同的配置
#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 65536;
}
http {
upstream tomcat{ #这里做了一个负载均衡器
sticky;
server 172.25.19.1:8080;
server 172.25.19.2:8080;
}
相应的需要在下面
location ~ \.jsp$ {
proxy_pass http://tomcat;
}
在tomcat的发布目录里面
编写一个网页
内容如下:
<%@ page contentType="text/html; charset=GBK" %>
<%@ 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>");
String dataName = request.getParameter("dataName");
if (dataName != null && dataName.length() > 0) {
String dataValue = request.getParameter("dataValue");
session.setAttribute(dataName, dataValue);
}
out.print("<b>Session list</b>");
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="test.jsp" method="POST">
name:<input type=text size=20 name="dataName">
<br>
key:<input type=text size=20 name="dataValue">
<br>
<input type=submit>
</form>
</body>
</html>
效果如下
加入sticky 的原因是因为基于浏览器锁定它不来回论叫 , 因为每次变换数据都会变更 , 所谓 sticky 模式
就是指同一个用户的访问请求都被发送到同一个 tomcat 实例上处理。
但是无法做到session的共享 也就是说当server1down掉之后虽然server2会顶替但是数据回丢失
所以接下来就要memcache
两台机器都要倒 两台机器都要加
将架包导入到/lib之中
vi /usr/local/tomcat/conf/context.xml
<Context>
在末尾加入
......
<Manager className="de.javakaffee.web.msm.MemcachedBackupSessionManager"
memcachedNodes="n1:192.168.0.91:11211,n2:192.168.0.92:11211"
failoverNodes="n1"
#在 node2 上此项设置为“n2”
requestUriIgnorePattern=".*\.(ico|png|gif|jpg|css|js)$"
transcoderFactoryClass="de.javakaffee.web.msm.serializer.kryo.KryoTranscoderFactory"
/>
</Context>
需要在日志里面出现这一行表示成功
下载telnet可以做测试