웹서비스 프로토콜 중 포트번호에 대한 질문입니다.
글쓴이: kesyut / 작성시간: 수, 2011/07/20 - 4:41오전
안녕하세요. 컴공 학생입니다.
뜬금없지만 웹서비스 시 포트번호에 대해 궁금증이 생겨서 질문을 드립니다.
웹 서비스 시 tcp든 udp든 헤더정보에 소스포트번호와 목적지포트번호가 있는데
이 두개의 포트번호는 어떻게 정해지는지 궁금합니다.
서버측에서 웹서비스로 80을 쓴다고 가정하고 예상되는 시나리오를 생각해보면
1) 소스포트번호와 목적지포트번호 모두 80
2) 소스포트번호는 랜덤한 포트번호가 생성되어 붙고 목적지포트번호는 80
3) 3 hand shaking 시 소스포트번호와 목적지포트번호 모두 80이 붙고 세션이 맺어지면
소스포트번호는 랜덤하게 생성되어 붙고 목적지포트번호는 80으로 변화없음
4) 3 hand shaking 시 소스포트번호와 목적지포트번호 모두 80이 붙고 세션이 맺어지면
랜덤한 포트번호를 생성하여 붙이되 동일한 포트번호를 사용
5) 3 hand shaking 시라도 소스포트번호는 랜덤한 포트번호가 붙어 변함이 없고
목적지 포트번호는 80이 붙다가 세션이 맺어지면 랜덤한 포트번호를 사용
제가 쓰고도 무지 헷갈리네요. 아마 고수님들이라면 이해하실거라 믿습니다.
그럼 답변 기다리겠습니다. 감사합니다. ^^;
Forums:
서비스를 하는 입장이라면 알려진 포트 번호 (미리
서비스를 하는 입장이라면 알려진 포트 번호 (미리 정해진 포트 번호, HTTP 80 HTTPS 443 등)를 쓰고
서비스에 접속하는 입장은 랜덤 포트 번호 (컴퓨터에서 현재 사용하지 않는 포트 번호)를 쓰는 것으로
알고 있습니다.
서비스를 특정인에게만 제공하려 한다면 미리 포트번호를
서비스를 특정인에게만 제공하려 한다면 미리 포트번호를 약속해서
웹 서비스가 서비스를 제공하는 포트 번호를 바꿀 수 있기는 합니다.
(예를 들어 저희 홈페이지는 8080번 포트 번호로 접속해야 웹 서비스에 접속 가능합니다.)
2번으로 알고 있습니다. 1번은 당연히 말이
2번으로 알고 있습니다.
1번은 당연히 말이 안되고..
3번과 4번의 경우 방화벽으로 incoming 포트중 80번이 막혀있다면 3hand shaking도 불가능하게 됩니다.
처음 접속시 syn은 보낼수 있지만 그에 응답인 syn-ack받을 수 없습니다. 왜냐면 방화벽에서 들어오는 80포트를 막았을 경우기 때문입니다.
5번의 경우도 말이 안됩니다. 목적지 포트는 정해진것을 계속 사용합니다.
-------------------------------------------------------------------------------
It's better to appear stupid and ask question than to be silent and remain stupid.
http://www.ncftp.com/ncftpd/d
http://www.ncftp.com/ncftpd/doc/misc/ephemeral_ports.html
댓글 달기