유선 : 고객에게 서비스를 제공. 멀티캐스트 방식(가입이 필요)
안테나 방송 : 서비스를 지정된 채널로 제공. 브로드캐스트 방식(가입 필요 없음)
14-1. 멀티캐스트(Multicast)
멀티캐스트 전송 방식.
UDP를 기반으로 하는 전송 방식.
멀티캐스트 그룹(클래스 D에 속하는 IP주소)을 기반으로 멀티캐스트 패킷을 주고 받음.
하나의 멀티캐스트 패킷은 라우터를 통해서 다수의 호스트에 전송.
(한 번만 방송하면 가입자 모두 시청 가능.)
(정보를 단방향으로 제공할 때 주로 사용.)
라우팅(Routing)과 TTL(Time To Live)
라우팅 : 라우터에 의해서 패킷이 경로를 찾는 과정
TTL
거쳐갈 수 있는 라우터의 수(홉)를 의미.
이 값이 0이 되면 패킷은 더 이상 전달되지 못하고 소멸된다.
멀티캐스트 Sender와 Receiver
Sender : 멀티캐스트 그룹에 데이터를 전송하는 호스트
Receiver : 멀티캐스트 그룹으로부터 데이터를 수신하는 호스트
※ Sender는 서버(제공자), Receiver는 클라이언트로 구분 지을 수 있지만 요청하는 부분과는 관련이 적다.
멀티캐스트 Sender와 Receiver
Sender | Receiver |
UDP 소켓 생성 반드시 TTL 설정(소켓 옵션 설정) 멀티캐스트 그룹으로 데이터 전송 |
UDP 소켓 생성 멀티캐스트 그룹 지정(ip_mreq) 멀티캐스트 그룹 가입(소켓 옵션 설정) |
Sender TTL 설정
state = setsockopt(send_sock, IPPROTO_IP, IP_MULTICAST_TTL, (void*)&multi_TTL, sizeof(multi_TTL));
Receiver 멀티캐스트 그룹 지정.
struct ip_mreq
{
struct in_addr imr_multiaddr; // 가입하고자 원하는 D 클래스 ip주소
struct in_addr imr_interface; // 나의 ip 주소. htonl(IN_ADDR);을 써주면 된다.
};
※ 서로 포트는 일치 해야 한다.
14-2. 브로드캐스트(Broadcast)
브로드캐스트 전송방식
UDP를 기반으로 하는 전송 방식(=멀티캐스트와 같다.)
일반적으로 UDP 패킷과의 차이점은 전송 목적지 ip주소 뿐이다.
(멀티캐스트와의 차이점)
동일 네트워크에 속하는 모든 호스트에 동시 전송
인터넷 상에서 지역 네트워크 내에서만 브로드캐스를 허용한다. (네트워크 부하를 고려)
주소선택에 따른 브로드캐스트 방식 구분
지정된 브로드캐스트
예 : 192.12.31.255 -> 자신이 속한 IP주소만 설정 가능. (지역적 브로드캐스트를 더 많이 사용.)
지역적 브로드캐스트
예 : 255.255.255.255 -> 알아서 현재 네트워크(LAN)에 브로드캐스트.
'네트워크 프로그래밍' 카테고리의 다른 글
[TCP/IP 소켓 프로그래밍] 16. 입력과 출력 스트림의 완벽 분리 (0) | 2009.08.17 |
---|---|
[TCP/IP 소켓 프로그래밍] 15. 소켓과 표준 입출력 (0) | 2009.08.08 |
[TCP/IP 소켓 프로그래밍] 13. 고급 입출력 함수 (0) | 2009.08.06 |
[TCP/IP 소켓 프로그래밍] 12. 프로세스간 통신(IPC) (0) | 2009.08.06 |
[TCP/IP 소켓 프로그래밍] 11. 프로세스간 통신(IPC) (0) | 2009.07.30 |