이전에 구성된 Tomcat 클러스터는 Tomcat에서 제공하는 간단한 클러스터 관리 방법인
구성 참조 문서에는 다음이 포함됩니다. 링크를 열려면 클릭하세요. 이 링크에서 Tomcat과 일치하는 jar 패키지와 Tomcat 구성 방법을 찾을 수 있습니다. 아래에 내 구성 프로세스를 기록해 보겠습니다.
1. 이전 블로그 내용에 따라 Nginx 역방향 프록시를 구성합니다.
2. ubuntu에 memcache를 설치합니다.
다음 명령을 사용하여 직접 설치할 수 있습니다.
sudo apt-get install memcached
이 파일에는 각 매개변수의 구성이 포함되어 있습니다. Memcache가 기본적으로 모든 주소를 수신하므로 여기에서 -l 매개변수를 주석 처리하거나 Memcache가 기본 주소를 수신하도록 127.0.0.1을 0.0.0.0으로 변경합니다.
이렇게 하지 않으면 이 머신에서만 memcached를 사용할 수 있고, 다른 머신은 연결할 수 없으므로 의미가 없습니다.
구성 후 다음 명령을 사용하여 Memcache에 연결할 수 있는지 확인할 수 있습니다. 여기서 ip는 Memcache 호스트에 설치된 IP 주소이고 11211은 Memcache의 수신 대기 포트입니다.
telnet ip 11211
4. 모든 Tomcat 노드에서 CATALINA_HOME/conf/context.xml 파일을 편집하고
<Manager className="de.javakaffee.web.msm.MemcachedBackupSessionManager" memcachedNodes="n1:cloud2:11211,n2:cloud3:11211" sticky="false" sessi lockingMode="auto" requestUriIgnorePattern=".*\.(ico|png|gif|jpg|css|js)$" />
5. CATALINA_HOME/lib에 jar 패키지를 추가합니다.
여기서 사용하는 패키지는 다음과 같습니다.
memcached-session-manager-1.8.3.jar memcached-session-manager-tc8-1.8.3.jar spymemcached-2.11.1.jar
여기서 내 테스트 아이디어는 다음과 같습니다. 다음 코드를 사용하여 서블릿을 만든 다음 두 개의 Tomcat 서버에 배포합니다. 서버 중 하나만 시작한 후 브라우저를 통해 로드밸런싱 서버에 접속하면 이때 브라우저에서 SessionID를 확인하고 기록할 수 있습니다. 그런 다음 이 서버를 닫고 다른 Tomcat 서버를 시작한 다음 동일한 주소를 사용하여 로드 밸런싱 서버에 액세스한 다음 브라우저에서 SessionID를 확인합니다. SessionID가 두 번 동일하면 SessionID가 공유된다는 의미입니다.
package com.cyber_space.Servlet; import java.io.IOException; import java.io.PrintWriter; import java.net.Inet4Address; import javax.servlet.ServletException; import javax.servlet.annotation.WebServlet; import javax.servlet.http.HttpServlet; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; /** * Servlet implementation class TestServlet */ @WebServlet("/TestServlet") public class TestServlet extends HttpServlet { private static final long serialVersionUID = 1L; public TestServlet() { super(); } protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { handle(request, response); } protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { handle(request, response); } private void handle(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { response.setHeader("Content-type", "text/html;charset=UTF-8"); String remoteIpString = request.getRemoteAddr() + " " + request.getRemoteHost() + " " + request.getRemoteUser(); PrintWriter pw = response.getWriter(); pw.println("请求来自:" + remoteIpString); request.getSession().setAttribute("5", 5); String sessionID = request.getSession().getId(); pw.println("赋予它的SESSIONID是:" + sessionID); Inet4Address inet4Address = (Inet4Address) Inet4Address.getLocalHost(); pw.println("服务器的IP地址是:" + inet4Address.getHostAddress()); } }
저작권 안내: 이 글은 해당 블로거의 원본 글이므로 블로거의 허락 없이 복제할 수 없습니다.
위 내용은 Ubuntu1404에서 공유되는 Tomcat8 Nginx memcache 구성 서버 클러스터 세션에 대한 내용을 포함하여 PHP 튜토리얼에 관심이 있는 친구들에게 도움이 되기를 바랍니다.