lnmp构架——对tomcat详解
tomcat的安裝部署
安裝jdk和tomcat
tar zxf jdk-7u79-linux-x64.tar.gz -C /usr/local/ tar zxf apache-tomcat-7.0.37.tar.gz -C /usr/local/做好軟連接便于訪問
cd /usr/local ln -s jdk1.7.0_79/ java ln -s apache-tomcat-7.0.37/ tomcat配置環境變量
vim /etc/profile export JAVA_HOME=/usr/local/java export CLASSPATH=.:$JAVA_HOME/lib:$JAVA_HOME/jre/lib export PATH=$PATH:$JAVA_HOME/binsource /etc/profile # 使文件生效編寫測試網頁并測試
vim test.java public class test {public static void main(String[] args){System.out.println("Hello World1");} } javac test.java java test開啟tommcat
cd /usr/local/tomcat bin/startup.sh打開瀏覽器測試
打開瀏覽器測試
測試
設置nginx對tomcat的負載均衡
打開瀏覽器刷新測試:
再次刷新會發現時間在變
sticky(粘滯)模塊
重新編寫兩臺tomcat服務器的網頁
vim /usr/local/tomcat/webapps/ROOT/test.jsp <%@ 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>進行測試
在nginx配置文件中增加tomcat模塊,為了實現session共享,需要支持sticky(粘滯)模塊,nginx-1.14不支持sticky,所以使用nginx-1.10版本,重新編譯nginx
備份之前版本nginx的配置文件到/mnt
并刪除nginx目錄
解壓編譯安裝
切換到新編譯安裝好的nginx
從/mnt恢復原nginx.conf
測試:
再次刷新頁面,訪問的ID號不會變,實現了sticky
session共享(交叉存儲)
在設置之前
關閉一個服務器的tomca查看網頁
刷新網頁發現立即切換到了另外一臺服務器,并且id發生變化
這樣極為的不安全,且服務器發生故障時,會丟失數據,所以要設置交叉存儲的方式
設置步驟:(兩臺服務器相同設置)
進入/usr/local/tomcat/lib目錄(兩臺服務器都做)
將以下jar包拷貝到該目錄:
編輯/usr/local/tomcat/conf/context.xml文件,加入session共享配置
vim /usr/local/tomcat/conf/context.xml<Manager className="de.javakaffee.web.msm.MemcachedBackupSessionManager" memcachedNodes="n1:172.25.11.4:11211,n2:172.25.11.4:11211" failoverNodes="n1" (在172.25.11.5上"n1"改為"n2") requestUriIgnorePattern=".*\.(ico|png|gif|jpg|css|js)$" transcoderFactoryClass="de.javakaffee.web.msm.serializer.kryo.KryoTranscoderFactory" /> </Context>在兩臺服務器安裝memcached并開啟
yum install memcached -y systemctl start memcached設置完畢測試:
關閉server4的tomcat
刷新頁面:發現ID沒有變
開啟server4的tomcat同時關閉server5的tomcat
再次刷新頁面
關閉server5的memcached
刷新頁面
開啟server5的memcached同時關閉server4的memcached
刷新頁面
發現ID始終沒有改變,即達到了交叉存儲的目的
總結
以上是生活随笔為你收集整理的lnmp构架——对tomcat详解的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 安装完成后的配置_cent os7 默认
- 下一篇: mysql text保存图片_用mysq