윈도우 네트워크 프로그래밍 √ 원리를 알면 IT가 맛있다 TCP/IP 소켓 프로그래밍 광주대학교 정보통신학과 조 정 호
Chapter 01. 네트워크와 소켓 프로그래밍
윈도우 소켓 애플리케이션 작성과 실행 과정의 이해 학습 목표 TCP/IP 프로토콜의 동작 원리 이해 소켓의 기본 개념 이해 윈도우 소켓의 역사와 특징 이해 윈도우 소켓 애플리케이션 작성과 실행 과정의 이해
인터넷 구성 (1/2) 종단 시스템 (PC, PDA, ...) 라우터 ① ② ③ ④
종단 시스템(end-system) 라우터(router) 프로토콜(protocol) 인터넷 구성 (2/2) 종단 시스템(end-system) 최종 사용자(end-user)를 위한 애플리케이션을 수행하는 개체(entity). 예) PC, 워크스테이션, PDA, 휴대폰 등 라우터(router) 종단 시스템이 속한 네트워크와 다른 네트워크를 연결함으로써 서로 다른 네트워크에 속한 종단 시스템끼리 상호 데이터를 교환할 수 있도록 하는 장비 프로토콜(protocol) 종단 시스템과 라우터간, 라우터와 라우터간, 그리고 종단 시스템과 종단 시스템간 통신을 수행하기 위한 정해진 절차와 방법
TCP/IP 프로토콜 인터넷에서 사용하는 핵심 프로토콜
TCP/IP 프로토콜 (2/2) TCP/IP 프로토콜 (운영체제) 애플리케이션 라우터 종단 시스템
Q&A : 통신을 수행하는 개체중에 최종적인 목적지가 되는 것은? 종단시스템 애플리케이션 TCP/IP 프로토콜 라우터
Q&A : 애플리케이션간 통신을 위해 만족시켜야 할 사항은? TCP/IP 프로토콜 (2/2) Q&A : 애플리케이션간 통신을 위해 만족시켜야 할 사항은? 통신할 대상(종단시스템 자체, 종단시스템에서 수행되는 애플리케이션)을 지정하는 상호 약속된 방법 전송오류 확인 기능 오류 발생 시 재전송 기능 데이터의 순서 유지 기능 …………..
TCP/IP 프로토콜 구조 계층적 구조 TCP/IP 프로토콜 구조 (1/6) 네트워크 액세스 계층 인터넷 계층 전송 계층 애플리케이션 계층 디바이스 드라이버 네트워크 하드웨어 IP TCP, UDP TELNET, FTP, HTTP, SMTP, MIME, SNMP, ...
네트워크 액세스 계층(network access layer) TCP/IP 프로토콜 구조 (2/6) 네트워크 액세스 계층(network access layer) 역할 물리적 네트워크를 통한 실제적인 데이터 전송 구성 요소 네트워크 하드웨어 + 디바이스 드라이버 주소 지정 방식 물리 주소(physical address) 예 이더넷(Ethernet)
인터넷 계층(Internet layer) TCP/IP 프로토콜 구조 (3/6) 인터넷 계층(Internet layer) 역할 네트워크 액세스 계층의 도움을 받아, 전송 계층이 내려 보낸 데이터를 종단 시스템까지 전달 구성 요소 논리 주소 + 라우팅 주소 지정 방식 IP 주소(Internet Protocol address) 라우팅(routing) 목적지까지 데이터를 전달하기 위한 일련의 작업 라우팅을 위한 정보 획득 라우팅 정보를 기초로 실제 데이터 전달(forward)
전송 계층(transport layer) TCP/IP 프로토콜 구조 (4/6) 전송 계층(transport layer) 역할 최종적인 통신 목적지(프로세스)를 지정하고, 오류 없이 데이터를 전송 최종적인 통신 목적지(프로세스)의 주소 지정 방식 포트 번호(port number) 이용 예 TCP(Transmission Control Protocol) UDP(User Datagram Protocol)
TCP와 UDP TCP/IP 프로토콜 구조 (5/6) TCP UDP 연결형(connection-oriented) 프로토콜 - 연결이 성공해야 통신 가능 비연결형(connectionless) 프로토콜 - 연결 없이 통신 가능 데이터 경계를 구분하지 않음 - 바이트 스트림(byte-stream) 서비스 데이터 경계를 구분함 - 데이터그램(datagram) 서비스 신뢰성 있는 데이터 전송 - 데이터를 재전송함 비신뢰적인 데이터 전송 - 데이터를 재전송하지 않음 1 대 1 통신(unicast) 1 대 1 통신(unicast), 1 대 다 통신(broadcast), 다 대 다 통신(multicast)
애플리케이션 계층(application layer) TCP/IP 프로토콜 구조 (6/6) 애플리케이션 계층(application layer) 역할 전송 계층을 기반으로 한 다수의 프로토콜과 이 프로토콜을 이용하는 애플리케이션을 포괄 다양한 애플리케이션 서비스 제공 예 Telnet, FTP, HTTP, SMTP 등
패킷 전송 원리 (1/5) 패킷(packet) 제어 정보+ 데이터 제어 정보의 위치에 따라, 앞쪽에 붙는 헤더(header)와 뒤쪽에 붙는 트레일러(trailer)로 구분 Q&A : 패킷에서 제어정보란? Q&A : 패킷에서 데이터란 무엇을 가르키는가?
패킷 전송 형태 송신측 패킷 전송 원리 (2/5) 이더넷 IP TCP 애플리케이션 데이터 TCP 헤더 IP 헤더 이더넷 헤더 이더넷 트레일러
패킷 전송 형태 수신측 패킷 전송 원리 (3/5) 이더넷 IP TCP 애플리케이션 데이터 TCP 헤더 IP 헤더 이더넷 헤더 이더넷 트레일러
패킷 전송 형태 계층별 패킷 전송 원리 (4/5) 애플리케이션 데이터 애플리케이션 TCP 데이터 TCP 헤더 TCP IP
TCP/IP 프로토콜을 이용한 패킷 전송 패킷 전송 원리 (5/5) 네트워크 액세스 계층 인터넷 계층 전송 계층 애플리케이션 계층 종단 시스템 라우터
IP 주소 포트 번호 인터넷에 존재하는 호스트(종단 시스템, 라우터)를 유일하게 구별할 수 있는 식별자 IPv4는 32비트, IPv6는 128비트 사용 8비트 단위로 구분하여 10진수로 표기(IPv4) 예) 147.46.114.70 포트 번호 최종 통신 종착지(하나 혹은 여러 개의 프로세스)를 나타내는 식별자
IP 주소와 포트 번호 (2/3) IP 주소와 포트 번호 TCP IP 프로세스 UDP 포트 번호(0~65535) IP 주소
도메인 이름 IP 주소에 대한 (기억하기 쉬운) 별명 실제 통신을 하기 위해서는 IP 주소로 변환해야 함
클라이언트/서버(client/server) 모델 클라이언트/서버 모델 클라이언트/서버(client/server) 모델 두 개의 애플리케이션이 상호 작용하는 방식을 나타냄 서버가 먼저 실행하여 대기 클라이언트가 서버에게 요청을 하면 서버는 이 요청을 받아 처리 서버 클라이언트 접속 대기
세 가지 관점 ① 데이터 타입(자료형) ② 통신 종단점(communication end-point) 소켓의 개념 (1/5) 세 가지 관점 ① 데이터 타입(자료형) ② 통신 종단점(communication end-point) ③ 네트워크 프로그래밍 인터페이스
데이터 타입 운영체제가 통신을 위해 관리하는 데이터를 간접적으로 참조할 수 있도록 만든 일종의 핸들(handle) 소켓의 개념 (2/5) 데이터 타입 운영체제가 통신을 위해 관리하는 데이터를 간접적으로 참조할 수 있도록 만든 일종의 핸들(handle) 생성과 설정 과정이 끝나면 이를 이용하여 통신과 관련된 다양한 작업을 할 수 있는 간편한 데이터 타입 // 파일 생성 int fd = open("myfile", ...); ... read(fd, ...) // 읽기 write(fd, ...) // 쓰기 // 소켓 생성 SOCKET sock = socket(...); ... recv(sock, ...) // 받기 send(sock, ...) // 보내기
통신 종단점 소켓은 통신을 위해 필요한 여러 요소의 집합체 소켓의 개념 (3/5) 통신 종단점 소켓은 통신을 위해 필요한 여러 요소의 집합체 사용할 프로토콜(TCP/IP, UDP/IP 등) 송신측 IP 주소, 송신측 포트 번호 수신측 IP 주소, 수신측 포트 번호 애플리케이션은 자신의 소켓이 상대방의 소켓과 연결된 것으로 생각하고 데이터를 교환
통신 종단점(cont’d) 소켓의 개념 (4/5) 클라이언트 send (sock, ...) 서버 recv (sock, ...) 데이터 <클라이언트 소켓> • 프로토콜: TCP/IP • IP 주소: 147.46.114.70 • 포트 번호: 12023 <서버 소켓> • IP 주소: 61.72.244.22 • 포트 번호: 9001
네트워크 프로그래밍 인터페이스 통신 양단이 모두 소켓을 사용할 필요는 없음 소켓의 개념 (5/5) 네트워크 프로그래밍 인터페이스 통신 양단이 모두 소켓을 사용할 필요는 없음 TCP/IP 프로토콜 구조에서 (일반적으로) 애플리케이션 계층과 전송 계층 사이에 위치하는 것으로 간주 애플리케이션 TCP IP UDP 소켓 인터페이스 ICMP, IGMP
윈도우 소켓(Windows Sockets, Winsock) 윈도우 소켓 (1/6) 윈도우 소켓(Windows Sockets, Winsock) 버클리 유닉스(Berkeley Software Distribution UNIX)에서 개발한 네트워크 프로그래밍 인터페이스를 윈도우 환경에서 사용할 수 있도록 한 것 소스 코드 수준에서 호환성이 높음 윈도우 95 버전부터 API(Application Programming Interface)에 정식으로 포함되어 제공
유닉스 소켓과의 차이점 윈도우 소켓은 DLL을 통해 대부분의 기능이 제공되므로 DLL 초기화와 종료 작업을 위한 함수가 필요 윈도우 소켓 (2/6) 유닉스 소켓과의 차이점 윈도우 소켓은 DLL을 통해 대부분의 기능이 제공되므로 DLL 초기화와 종료 작업을 위한 함수가 필요 윈도우 애플리케이션은 대개 그래픽 사용자 인터페이스(GUI, Graphical User Interface)를 기반으로 하며, 메시지 구동 방식으로 동작하므로 이를 위한 확장 함수가 존재 윈도우는 운영체제 차원에서 멀티스레드(multithread)를 지원하므로 멀티스레드 환경에서 안정적으로 동작하기 위한 구조와 이를 위한 함수가 필요
윈도우 소켓 (3/6) 운영체제별 지원 사항 지원 프로토콜 TCP/IP, IPv6(윈도우 XP 이상), IrDA(윈도우 98 이상), Bluetooth(윈도우 XP SP2 이상), IPX/SPX, ATM, DECNet, TP4(윈도우 2000부터 지원하지 않음), DLC(윈도우 XP부터 지원하지 않음), NetBEUI(윈도우 XP부터 지원하지 않음) 운영체제 윈속 버전 윈도우 95 1.1 (2.2) 윈도우 98/Me, 윈도우 NT/2000/XP/2003 2.2 윈도우 CE
장점 유닉스 소켓과 소스 코드 수준에서 호환성이 높으므로 기존 프로그램을 포팅하기가 쉬움 윈도우 소켓 (4/6) 장점 유닉스 소켓과 소스 코드 수준에서 호환성이 높으므로 기존 프로그램을 포팅하기가 쉬움 가장 널리 쓰이는 네트워크 프로그래밍 인터페이스이므로 한번 배워두면 여러 환경(윈도우, 유닉스, ...)에서 사용할 수 있음 TCP/IP 이외에도 다양한 종류의 프로토콜을 지원하므로 최소한의 코드 수정으로 애플리케이션에서 사용할 프로토콜을 변경 가능 비교적 저수준(low-level 혹은 mid-level)의 프로그래밍 인터페이스로, 세부적인 제어가 가능하므로 고성능의 네트워크 애플리케이션을 개발할 수 있음
단점 애플리케이션 수준의 프로토콜을 프로그래머가 직접 설계해야 함 윈도우 소켓 (5/6) 단점 애플리케이션 수준의 프로토콜을 프로그래머가 직접 설계해야 함 데이터 포맷이나 전송 절차 등을 고려하여 프로그래밍해야 하므로 프로토콜을 변경할 경우 코드 수정이 불가피 서로 다른 바이트 정렬(byte ordering) 방식을 사용하거나 데이터 처리 단위(32비트, 64비트, ...)가 서로 다른 종단 시스템간 통신을 할 경우, 애플리케이션 수준에서 데이터 변환을 처리해야 함
구조 윈도우 소켓 (6/6) 윈속 2.x 애플리케이션 윈속 1.x WINSOCK.DLL (16 비트) WSOCK32.DLL (32 비트) WS2_32.DLL (32 비트) 윈속 1.x API 윈속 2.x API TCP/IP IrDA IPX/SPX MSWSOCK.DLL ... Bluetooth 윈속 1.x 확장 API
윈속 애플리케이션 작성 윈속 라이브러리 추가