일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | |||
5 | 6 | 7 | 8 | 9 | 10 | 11 |
12 | 13 | 14 | 15 | 16 | 17 | 18 |
19 | 20 | 21 | 22 | 23 | 24 | 25 |
26 | 27 | 28 | 29 | 30 | 31 |
- 추천시스템
- 데이터분석
- SQL
- Oracle 논리적 저장 구조
- Spark jdbc parallel read
- enq: FB - contention
- 랜덤포레스트
- CF
- eda
- 앙상블
- Collaborative filtering
- airflow 정리
- git stash
- 리눅스 환경변수
- Oracle ASSM
- 네트워크
- Spark 튜닝
- 배깅
- git init
- Python
- 통계분석
- BFS
- Linux
- 알고리즘
- Spark Data Read
- 의사결정나무
- 오라클 데이터 처리방식
- Decision Tree
- git 기본명령어
- 데이터 분석
- Today
- Total
[Alex] 데이터 장인의 블로그
[네트워크] TCP/UDP, IP, DNS 간단 정리 본문
TCP, UDP
우편과 등기로 비유
TCP : 받는 사람이 받았는지 알 수 있다. (확인)
UDP : 받는 사람이 받았는지 알 수 없다. (확인x)
TCP - 높은 신뢰성, 높은 연결성
연결형 프로토콜
전송속도가 느리다
패킷관리가 필요 없다.
데이터 순서 유지를 위해 데이터 각 바이트마다 번호를 부여함.
데이터를 재전송한다.
1대1 통신 (unicast)
데이터 전달을 보증, 순서를 보장 (3-Way handshake)
흐름 제어 및 혼잡 제어
받는 사람의 환경을 인지한 채로 조절. - 흐름 제어
네트워크 내 패킷 수가 과도하게 증가하는 것을 방지 - 혼잡 제어
UDP - 낮은 신뢰성, 스트리밍 서비스에 활용.
비연결성 프로토콜이며, 연결 없이 통신이 가능.
비 신뢰적인 데이터를 전송. -> 데이터 재전송과 순서 유지를 위한 작업을 하지 않는다.
1대1 통신, 1대다 통신, 다대다 통신 (TCP는 1대1 통신만 가능)
전송속도가 빠르다.
-> 즉 속도가 중요한 스트리밍 서비스에 사용.
비연결형(port 만 확인하여 소켓을 식별하고 송수신)
패킷 오버헤드가 적어 네트워크 부하 감소
비신뢰성 -> 신뢰도가 비교적 낮음
오류검출(헤더에 오류 검출 필드를 포함하여 무결성 검사)
TCP의 hand shaking 같은 연결 설정이 없다.
DNS, NFS, SNMP, RIP 등에 사용.
IP Address
데이터를 전달받고 어떻게 변환할지 정하는 '약속'
비신뢰성
데이터가 제대로 전달되었는지 '보장'하지 않는다.
ICMP - 전송이 제대로 되었는지 확인하고자 하면 활용하는 프로토콜
비연결성
패킷을 받을 대상이 연결 상태임을 확인하지 않고 전송.
받을 대상이 서비스 불능 상태여도 패킷이 전송된다는 문제점이 있음.
DNS
도메인 주소를 IP주소로 변환해주는 시스템.
ISP가 관리하는 DNS 해석기 요청을 라우팅
로드밸런서
서버의 부하의 분산시켜주는 시스템
여러 개의 서버의 로드를 분산시켜주는 역할
웹서버를 예시로, 하나의 서버가 죽는다고 해당 웹이 다운된다면 큰손해라고 할 수 있다.
때문에 여러대의 서버에 동시에 웹서비스를 띄어두고 부하가 올 때, 분산시켜주는 역할을 수행하는 것이 로드 밸런서.
4계층, 7계층 (데이터를 어떤 단계까지 열어보느냐.)
L4(전송) : 전송 계층. 데이터를 받아서 전송계층까지만 열어보고 분산 수행.
- 개개인의 환경(네트워크, 단말기 등) 정보 - Mac(2 계층), IP(3 계층), Port(4 계층)
- 위 정보들을 가지고 로드밸런서에서 '분산' 처리 (TCP/UDP의 Port 정보를 바탕으로)
- 장점: 속도가 빠르고 가격이 저렴함.
- 단점: 섬세한 라우팅이 불가능함.
L7(운영) : 끝까지 다 열어보고 분산을 수행.
- 모든 정보를 가지고 분산을 처리
- URL기반으로 분산 수행.
- DDOS를 방어할 수 있음.(모든 정보를 확인하고 비정상 트래픽을 '거를' 수 있다.
- 장점: 훨씬 섬세한 라우팅이 가능. 서비스의 안정성이 높음.
- 단점: 높은 비용. 클라이언트가 인증서를 로드밸런서와 '공유'해야하기 때문에 공격자가 '클라이언트'의 데이터에 접근할 보안 상의 위험이 존재.
'Linux&OS' 카테고리의 다른 글
[Linux] systemctl & systemd 정리 (0) | 2022.10.17 |
---|---|
[운영체제] 메모리 구조 정리 (0) | 2022.04.05 |
[Linux] grep, awk를 활용한 kill process (1) | 2022.03.21 |
[OS] 캐시메모리와 버퍼메모리 정리(+ 레지스터) (0) | 2021.12.16 |
[Linux] Bash 쉘스크립트 사용법 정리 (0) | 2021.12.12 |