백엔드 개발 PHP 튜토리얼 Ubuntu1404에서 Tomcat8 Nginx memcache 구성 서버 클러스터 세션 공유

Ubuntu1404에서 Tomcat8 Nginx memcache 구성 서버 클러스터 세션 공유

Jul 29, 2016 am 09:15 AM
memcache quot request session tomcat

이전에 구성된 Tomcat 클러스터는 Tomcat에서 제공하는 간단한 클러스터 관리 방법인 를 사용하며, 이 클러스터 세션 기여는 다음과 같습니다: org .apache.catalina.ha.session.DeltaManager는 특정 노드의 세션을 클러스터의 모든 노드에 복사합니다. 공식 Tomcat 문서에 따르면 이 세션 공유 방법은 클러스터가 커지면 제대로 작동하지 않습니다. 따라서 클러스터가 세션을 공유할 수 있도록 memcached를 사용하려고 했습니다.

구성 참조 문서에는 다음이 포함됩니다. 링크를 열려면 클릭하세요. 이 링크에서 Tomcat과 일치하는 jar 패키지와 Tomcat 구성 방법을 찾을 수 있습니다. 아래에 내 구성 프로세스를 기록해 보겠습니다.

1. 이전 블로그 내용에 따라 Nginx 역방향 프록시를 구성합니다.

2. ubuntu에 memcache를 설치합니다.

다음 명령을 사용하여 직접 설치할 수 있습니다.

sudo apt-get install memcached
로그인 후 복사
3. /etc/memcached.conf 파일을 편집합니다.

이 파일에는 각 매개변수의 구성이 포함되어 있습니다. 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)$"
/>
로그인 후 복사
memcachedNodes는 memcache가 구성되고 설치되는 노드입니다. cloud2와 cloud3은 머신에서 인식해야 하는 호스트 이름입니다. 11211은 memcached 노드의 이름입니다. Memcache가 수신하는 포트는 11211이 기본 포트입니다.

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
로그인 후 복사

6.

여기서 내 테스트 아이디어는 다음과 같습니다. 다음 코드를 사용하여 서블릿을 만든 다음 두 개의 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 튜토리얼에 관심이 있는 친구들에게 도움이 되기를 바랍니다.

본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

Video Face Swap

Video Face Swap

완전히 무료인 AI 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

인기 기사

<gum> : Bubble Gum Simulator Infinity- 로얄 키를 얻고 사용하는 방법
3 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌
Nordhold : Fusion System, 설명
3 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌
Mandragora : 마녀 트리의 속삭임 - Grappling Hook 잠금 해제 방법
3 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌

뜨거운 도구

메모장++7.3.1

메모장++7.3.1

사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전

SublimeText3 중국어 버전

중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

신 수준의 코드 편집 소프트웨어(SublimeText3)

Tomcat에 jar 프로젝트를 배포하는 방법 Tomcat에 jar 프로젝트를 배포하는 방법 Apr 21, 2024 am 07:27 AM

Tomcat에 JAR 프로젝트를 배포하려면 다음 단계를 따르세요. Tomcat을 다운로드하고 압축을 풉니다. server.xml 파일을 구성하고 포트 및 프로젝트 배포 경로를 설정합니다. JAR 파일을 지정된 배포 경로에 복사합니다. 톰캣을 시작하세요. 제공된 URL을 사용하여 배포된 프로젝트에 액세스합니다.

Tomcat 서버에 대한 외부 네트워크 액세스를 허용하는 방법 Tomcat 서버에 대한 외부 네트워크 액세스를 허용하는 방법 Apr 21, 2024 am 07:22 AM

Tomcat 서버가 외부 네트워크에 액세스하도록 허용하려면 다음을 수행해야 합니다. 외부 연결을 허용하도록 Tomcat 구성 파일을 수정합니다. Tomcat 서버 포트에 대한 액세스를 허용하는 방화벽 규칙을 추가합니다. Tomcat 서버 공용 IP에 대한 도메인 이름을 가리키는 DNS 레코드를 만듭니다. 선택 사항: 역방향 프록시를 사용하여 보안 및 성능을 향상합니다. 선택 사항: 보안 강화를 위해 HTTPS를 설정합니다.

Tomcat 설치 디렉터리는 어디에 있나요? Tomcat 설치 디렉터리는 어디에 있나요? Apr 21, 2024 am 07:48 AM

Tomcat 설치 디렉터리: 기본 경로: Windows: C:\Program Files\Apache Software Foundation\Tomcat 9.0macOS:/Library/Tomcat/Tomcat 9.0Linux:/opt/tomcat/tomcat9 사용자 정의 경로: 설치 중에 지정할 수 있습니다. 설치 디렉터리 찾기: whereis 또는 Locate 명령을 사용하세요.

Tomcat에 여러 프로젝트를 배포하는 방법 Tomcat에 여러 프로젝트를 배포하는 방법 Apr 21, 2024 am 09:33 AM

Tomcat을 통해 여러 프로젝트를 배포하려면 각 프로젝트에 대한 webapp 디렉터리를 생성한 후 다음을 수행해야 합니다. 자동 배포: webapp 디렉터리를 Tomcat의 webapps 디렉터리에 배치합니다. 수동 배포: Tomcat의 관리자 애플리케이션에서 프로젝트를 수동으로 배포합니다. 프로젝트가 배포되면 해당 배포 이름(예: http://localhost:8080/project1)으로 액세스할 수 있습니다.

Tomcat에서 동시 연결 수를 확인하는 방법 Tomcat에서 동시 연결 수를 확인하는 방법 Apr 21, 2024 am 08:12 AM

Tomcat 동시 연결 수를 확인하는 방법: Tomcat Manager 페이지(http://localhost:8080/manager/html)를 방문하여 사용자 이름과 비밀번호를 입력하세요. 페이지 상단에서 동시 연결 수를 보려면 왼쪽 탐색 모음에서 상태->세션을 클릭하세요.

Tomcat 웹사이트의 루트 디렉터리는 어디에 있나요? Tomcat 웹사이트의 루트 디렉터리는 어디에 있나요? Apr 21, 2024 am 09:27 AM

Tomcat 웹사이트 루트 디렉터리는 Tomcat의 webapps 하위 디렉터리에 있으며 웹 애플리케이션 파일, 정적 리소스 및 WEB-INF 디렉터리를 저장하는 데 사용됩니다. Tomcat 구성 파일에서 docBase 속성을 찾아 찾을 수 있습니다.

Tomcat의 포트 번호를 확인하는 방법 Tomcat의 포트 번호를 확인하는 방법 Apr 21, 2024 am 08:00 AM

Tomcat 포트 번호는 server.xml 파일에 있는 <Connector> 요소의 포트 속성을 확인하여 볼 ​​수 있습니다. Tomcat 관리 인터페이스(http://localhost:8080/manager/html)를 방문하여 "상태" 탭을 확인하세요. 명령줄에서 "catalina.sh version"을 실행하고 "Port:" 줄을 확인하세요.

Tomcat에서 도메인 이름을 구성하는 방법 Tomcat에서 도메인 이름을 구성하는 방법 Apr 21, 2024 am 09:52 AM

도메인 이름을 사용하도록 Tomcat을 구성하려면 다음 단계를 수행하십시오. server.xml 백업을 생성하십시오. server.xml을 열고 Host 요소를 추가하고 example.com을 도메인 이름으로 바꿉니다. 도메인 이름에 대한 SSL 인증서를 생성합니다(필요한 경우). server.xml에 SSL 커넥터를 추가하고 포트, 키 저장소 파일 및 비밀번호를 변경하십시오. server.xml을 저장합니다. 톰캣을 다시 시작하세요.

See all articles