2.3. TCP 연결 구성
AMQ Broker는 Netty를 사용하여 차단 Java IO 또는 최신 비 차단 Java NIO를 사용하도록 구성할 수 있는 기본, 암호화되지 않은 TCP 기반 연결을 제공합니다. Java NIO는 여러 동시 연결로 더 나은 확장성을 위해 선호됩니다. 그러나 이전 IO를 사용하면 수천 개의 동시 연결을 지원하는 것에 대한 걱정이 줄어들 때 NIO보다 더 나은 대기 시간을 제공할 수 있습니다.
신뢰할 수 없는 네트워크에서 연결을 실행하는 경우 TCP 네트워크 연결이 암호화되지 않은 것을 기억하십시오. 암호화가 우선 순위인 경우 SSL 또는 HTTPS 구성을 사용하여 이 연결을 통해 전송된 메시지를 암호화하는 것이 좋습니다. 자세한 내용은 5.1절. “연결 보안” 을 참조하십시오. TCP 연결을 사용하면 클라이언트 측에서 모든 연결이 시작됩니다. 즉, 서버는 클라이언트에 대한 연결을 시작하지 않으며, 이는 한 방향에서 강제로 연결을 시작하도록 하는 방화벽 정책과 잘 작동합니다.
TCP 연결의 경우 커넥터 URI의 호스트 및 포트는 연결에 사용되는 주소를 정의합니다.
절차
-
구성 파일
BROKER_INSTANCE_DIR/etc/broker.xml
을 엽니다. -
연결을 추가하거나 수정하고
tcp
를 프로토콜로 사용하는 URI를 포함합니다. IP 또는 호스트 이름 및 포트를 모두 포함해야 합니다.
아래 예제에서 acceptor
는 TCP 연결로 구성됩니다. 이 허용
자로 구성된 브로커는 IP 10.10.10.1
및 포트 61617
에 대한 TCP 연결을 수행하는 클라이언트를 허용합니다.
<acceptors> <acceptor name="tcp-acceptor">tcp://10.10.10.1:61617</acceptor> ... </acceptors>
거의 동일한 방식으로 TCP를 사용하도록 커넥터를 구성합니다.
<connectors> <connector name="tcp-connector">tcp://10.10.10.2:61617</connector> ... </connectors>
위의 커넥터
는 지정된 IP 및 포트 10.10.10.2:61617
에 TCP 연결을 할 때 클라이언트 또는 브로커 자체에서 참조합니다.
TCP 연결에 사용 가능한 구성 매개변수에 대한 자세한 내용은 Acceptor and Connector Configuration Parameters 를 참조하십시오. 대부분의 매개변수는 어셉터 또는 커넥터와 함께 사용할 수 있지만 일부 매개변수는 수락자에서만 사용할 수 있습니다.