Tomcat 클러스터 및 Session 복제 애플리케이션 소개

7022 단어 tomcatsession 복제
하나의 프로필:.설명은 다음과 같습니다. 1. Cluster
 
<Cluster className="org.apache.catalina.ha.tcp.SimpleTcpCluster"
channelSendOptions="6">
<Manager className="org.apache.catalina.ha.session.BackupManager"
expireSessionsOnShutdown="false"
notifyListenersOnReplication="true"
mapSendOptions="6"/>
<!--
<Manager className="org.apache.catalina.ha.session.DeltaManager"
expireSessionsOnShutdown="false"
notifyListenersOnReplication="true"/>
-->
<Channel className="org.apache.catalina.tribes.group.GroupChannel">
<Membership className="org.apache.catalina.tribes.membership.McastService"
address="228.0.0.4"
port="45564"
frequency="500"
dropTime="3000"/>
<Receiver className="org.apache.catalina.tribes.transport.nio.NioReceiver"
address="auto"
port="5000"
selectorTimeout="100"
maxThreads="6"/>
<Sender className="org.apache.catalina.tribes.transport.ReplicationTransmitter">
<Transport className="org.apache.catalina.tribes.transport.nio.PooledParallelSender"/>
</Sender>
<Interceptor className="org.apache.catalina.tribes.group.interceptors.TcpFailureDetector"/>
<Interceptor className="org.apache.catalina.tribes.group.interceptors.MessageDispatch15Interceptor"/>
<Interceptor className="org.apache.catalina.tribes.group.interceptors.ThroughputInterceptor"/>
</Channel>
<Valve className="org.apache.catalina.ha.tcp.ReplicationValve"
filter=".*\.gif|.*\.js|.*\.jpeg|.*\.jpg|.*\.png|.*\.htm|.*\.html|.*\.css|.*\.txt"/>
<Deployer className="org.apache.catalina.ha.deploy.FarmWarDeployer"
tempDir="/tmp/war-temp/"
deployDir="/tmp/war-deploy/"
watchDir="/tmp/war-listen/"
watchEnabled="false"/>
<ClusterListener className="org.apache.catalina.ha.session.ClusterSessionListener"/>
</Cluster>
1) Tomcat 클러스터의 주 요소, 이 요소에 클러스터의 모든 상세한 정보를 설정할 수 있습니다 2)className의 주요 클러스터 클래스는 현재 org만 제공합니다.apache.catalina.ha.tcp.SimpletcpCluste는 구현 클래스 3)channelSendOptionssession 발송 방식으로 기본값은 8입니다. 이 표지는 SimpletcpCluste를 통해 메시지를 어떻게 보내는지 확인합니다. 4)Channel.SEND_OPTIONS_SYNCHRONIZED_ACK = 0x0004 Channel.SEND_OPTIONS_ASYNCHRONOUS = 0x0008 Channel.SEND_OPTIONS_USE_ACK = 0x0002 만약 (ASYNCHRONOUS) 더하기(USE_ACK) 방식으로 메시지를 보낸다면, 값은 10(8+2) 또는 0x000B (SYNCHRONIZED_ACK) 더하기(USE_ACK) 방식으로 메시지를 보낸다면, 값은 6(4+2) 또는 0x0006 2, Manager가 되어야 합니다
 
<Cluster className="org.apache.catalina.ha.tcp.SimpleTcpCluster"
channelSendOptions="6">
1)tomcat 간의 session 복사를 관리합니다2)className에는 현재 두 가지 실행 클래스가 있습니다: org.apache.catalina.ha.session.DeltaManager 및 org.apache.catalina.ha.session.BackupManager 3) DeltaManager는 그룹 아래의 모든 노드에 Session 데이터를 복사하고 발송합니다. 이 구현 클래스는 매우 믿음직하고 잘 실행되고 있음을 증명합니다.그러나 집단의 노드 형식이 같고 같은 응용 프로그램을 배치해야 한다는 한계가 있다. 4) expire Sessions On Shutdown은 웹 프로그램이 끝날 때tomcat에서 모든 Session에 삭제 명령을 나누어 주고 모든 session listener에게 실행할 것을 알려준다.그룹 아래의 노드가 정지되었을 때, 모든 노드 아래의 Session을 삭제하려면true로 설정하고, 기본값은false5)notifyListenersOnReplication이true로 설정하면, session 속성이 복사되고 이동할 때, session listener는 3, Channel로 통지됩니다
 
<Manager className="org.apache.catalina.ha.session.BackupManager"
expireSessionsOnShutdown="false"
notifyListenersOnReplication="true"
mapSendOptions="6"/>
<!--
<Manager className="org.apache.catalina.ha.session.DeltaManager"
expireSessionsOnShutdown="false"
notifyListenersOnReplication="true"/>
-->
채널은Apache Tribes의 메인 구성 요소입니다. 채널은 하위 구성 요소를 관리하고 그것들과 함께tomcat 실례 간의 통신 프레임워크를 구성합니다.tomcat 그룹에서 DeltaManager는 SimpletcpCluster를 통해 채널을 호출하여 정보 전달을 실현하고, BackupManager는 채널과 하위 구성 요소 등 구성 요소를 호출하여 정보 전달을 실현한다.ReplicatedContext도 channel을 호출하여 context 속성을 전달합니다.4、Membership
 
<Channel className="org.apache.catalina.tribes.group.GroupChannel">
MemberShip 구성 요소는 그룹에 있는 새 노드나 작업이 중단된 노드를 자동으로 검색하여 해당하는 알림을 보냅니다.기본적으로 그룹 방송(Multicast)을 사용합니다.5、Receiver
 
<Membership className="org.apache.catalina.tribes.membership.McastService"
address="228.0.0.4"
port="45564"
frequency="500"
dropTime="3000"/>
다른 노드가 전송한 데이터를 감청하고 수신하는 것을 책임진다.기본값은 non-blocking TCP Server sockets입니다.6、Sender
 
<Receiver className="org.apache.catalina.tribes.transport.nio.NioReceiver"
address="auto"
port="5000"
selectorTimeout="100"
maxThreads="6"/>
한 노드에서 다른 노드로 보내는 출구 연결과 데이터 정보를 관리하고 정보를 병행 발송할 수 있다.기본적으로 TCP Client Sockets가 사용됩니다.7、Interceptor
 
<Sender className="org.apache.catalina.tribes.transport.ReplicationTransmitter">
<Transport className="org.apache.catalina.tribes.transport.nio.PooledParallelSender"/>
</Sender>
채널은 인터셉터 창고를 통해 메시지를 전달합니다. 여기서 메시지의 발송과 수신 방식, 심지어 MemberShip 처리 방식을 사용자 정의할 수 있습니다.8、Value
 
<Interceptor className="org.apache.catalina.tribes.group.interceptors.TcpFailureDetector"/>
<Interceptor className="org.apache.catalina.tribes.group.interceptors.MessageDispatch15Interceptor"/>
<Interceptor className="org.apache.catalina.tribes.group.interceptors.ThroughputInterceptor"/>
1) Value는 Http Request 체인을 호출하는 데 차단기 역할을 하여 어떤 상황에서 데이터가 복제되어야 하는지를 결정한다.org.apache.catalina.ha.tcp.ReplicationValve, ReplicationValue는 Http Request 끝에 현재 데이터가 복제되어야 하는지 판단합니다.2) Filter 내용은 URL 또는 파일의 끝입니다. 링크 설정 filter에 접근할 때 실제 세션이 바뀌었든 안 바뀌었든 집단은session에 아무런 변화가 없다고 생각하여 변경된 세션 속성을 복사하고 발송하지 않습니다.9、Deployer
 
<Valve className="org.apache.catalina.ha.tcp.ReplicationValve"
filter=".*\.gif|.*\.js|.*\.jpeg|.*\.jpg|.*\.png|.*\.htm|.*\.html|.*\.css|.*\.txt"/>
클러스터가 farmed deployment 10, ClusterListener를 지원하도록 합니다
 
<Deployer className="org.apache.catalina.ha.deploy.FarmWarDeployer"
tempDir="/tmp/war-temp/"
deployDir="/tmp/war-deploy/"
watchDir="/tmp/war-listen/"
watchEnabled="false"/>
Clusterlistener는 정보의 발송과 수신을 추적하는 데 쓰인다.ClusterSessionListener는 그룹 구성 요소의 수신 정보를 감청하는 데 사용되며, DeltaManager를 사용할 때 정보가 그룹으로 수신되고, ClusterSessionListener를 통해 Session Manager에 전달됩니다.

좋은 웹페이지 즐겨찾기