📙 CS/📙 Network

📙 CS/📙 Network

[Network] 웹서버 & 웹 애플리케이션 서버

1️⃣ 웹(Web) 'www.xxx.com' 우리가 사용하는 대부분의 웹 주소 형식이다. 그렇다면 www는 무엇일까? 이는 'World Wide Web'의 줄임말로, 인터넷에 연결된 사용자들이 서로 정보를 공유할 수 있는 인터넷 상의 공간을 말한다. W3라고도 하며, 이를 '웹'이라고 부른다. 클라이언트 (Client) 클라이언트는 사용자 또는 사용자가 사용하는 디바이스(컴퓨터, 스마트 폰 등)를 나타냄 클라이언트는 서비스나 리소스에 접근하고 요청을 보내는 주체 사용자는 웹 브라우저를 통해 웹페이지를 요청하는 등 동작이 클라이언트의 역할 서버 (Server) 서버는 말 그대로 클라이언트에게 서비스를 제공하거나 리소스를 제공하는 컴퓨터 또는 소프트웨어 클라이언트의 요청에 응답하고 필요한 데이터 또는 서비스..

📙 CS/📙 Network

[Network] HTTP vs HTTPS 비교

아래는 SSL/TLS 와 SSL/TLS handshake에 대한 글이다. HTTP와 HTTPS를 비교하기 앞서 해당 개념들을 알고 있다면 이해하기 더욱 쉬울 것이다. https://jnsodevelop.tistory.com/68 [Network] SSL/TLS 1. 개념 1) SSL (Secure Sockets Layer) SSL은 '보안 소켓 계층' 이라고 불리는 암호화 기반 인터넷 프로토콜이다. 1995년 Netscape 사에서 처음 개발되었으며, 인터넷 통신에서 개인 정보 보호, 인증, 데이터 jnsodevelop.tistory.com https://jnsodevelop.tistory.com/69 [Network] SSL/TLS handshake 네트워크를 공부했던 사람이라면 TCP 의 접속 과정인..

📙 CS/📙 Network

[Network] 암호 알고리즘

1️⃣ 암호 알고리즘 (Encryption Algorithm) 1) 개념 데이터의 무결성 및 기밀성 확보를 위해 정보를 쉽게 해독할 수 없는 형태로 변환하는 기술이다. 즉 평문(plain text)을 특정 키를 사용해 쉽게 해독할 수 없는 암호문(crypto text)으로, 혹은 그 반대로 변환하는 것을 말한다. 기밀성 (Confidentiality) : 인가된 사용자에 대해서만 자원 접근이 가능해야 한다는 특성 무결성 (Integrity) : 인가된 사용자에 대해서만 자원 수정이 가능하며, 전송 중인 정보는 수정되지 않아야 한다는 특성 가용성 (Availability) : 인가된 사용자는 가지고 있는 권한 범위 내에서 언제든 자원 접근이 가능해야 한다는 특성 2) 종류 2️⃣ 양방향 방식 1) 대칭키 ..

📙 CS/📙 Network

[Network] TCP/IP 흐름 제어, 혼잡 제어

1️⃣ 흐름 제어 (Flow Control) 1) 개념 흐름 제어는 송신 측과 수신 측의 데이터 처리 속도의 차이를 해결하기 위한 방법이다. TCP의 특징중 하나는 패킷 교환 방식의 네트워크에서 패킷들의 안전한 전송을 보장해준다는 것이다. 그러나 패킷을 전송할 때 네트워크 상황에 따라 패킷의 도착 순서가 바뀌거나 유실될 수가 있다. 따라서 TCP는 패킷 번호를 통해 신뢰성 있는 데이터를 전송하고, 순서를 보장한다. 이를 위해선 수신 측에서 데이터 과부하를 송신 측에 통보하는 '피드백 메커니즘'이 필요하다. 패킷을 한 번에 하나씩 송수신하는 것보단 여러 패킷을 한 번에 송수신한 뒤 확인 응답 신호를 전송하는 것이 효율적이기 때문에 흐름 제어를 통해 이동하는 패킷의 양을 조절한다. 수신 측에서 한 번에 받..

📙 CS/📙 Network

[Network] UDP

1️⃣ UDP (User Datagram Protocol) UDP(User Datagram Protocol)는 전송 계층의 프로토콜로, 데이터그램을 사용하여 데이터를 전송하는 비연결형 프로토콜이다. 특히 비디오 재생 또는 DNS 조회 같이 시간에 민감한 전송에 주로 사용된다. 2️⃣ UDP 특징 비연결형 : UDP는 연결을 설정하지 않고 데이터를 전송하기 때문에 신뢰성이나 흐름 제어를 보장하지 않는다. 빠른 속도 : 연결 설정과 흐름 제어 기능이 없기 때문에 전송 속도가 TCP보다 빠를 수 있다. 신뢰성 부족 : 데이터 전송 중 전송 순서가 바뀌거나 데이터 손실이 일어날 수 있다. 통신 방식 : 1:1 or 1:N or N:N 통신이 가능하다. 비상태정보 : 연결 정보나 상태 정보를 저장하지 않는다. 송..

📙 CS/📙 Network

[Network] 3-way & 4-way handshake (TCP Connection)

1️⃣ TCP (Transmission Control Protocol) TCP (Transmission Control Protocol) 란 전송 제어 프로토콜로, IP와 함께 'TCP/IP'로도 불린다. OSI 7 계층 중 전송 계층과 관련있으며, UDP와 함께 가장 널리 쓰인다. TCP는 연결형 서비스로, 패킷의 순서를 보장하며 신뢰성있는 전송을 위해 연결을 시작할 때와 종료할 때 handshake 과정을 거치게 된다. 즉, 3-way handshake 과정을 통해 연결을 설정하고, 4-way handshake 과정을 통해 안전하게 연결을 해제한다. TCP와 UDP의 개념은 중요하므로 다른 글에서 좀 더 자세히 다뤄보도록 하겠다. 2️⃣ Information 1) Port State Informatio..

📙 CS/📙 Network

[Network] OSI 7 계층 (OSI 7 Layer)

1️⃣ OSI 7 계층 개념 OSI 7 계층(OSI 7 Layer)은 'Open System Interconnection'의 참조 모델로, 1984년 국제 표준화 기구인 ISO에서 발표하였다. 통신 기술의 도입 및 기능 확장의 편의를 위해 프로토콜을 7 계층으로 나눴다. 이렇게 통신 기능을 계층화하여 프로토콜을 규정한 규격을 OSI 모델이라고 한다. 쉽게 말해 우리가 인터넷을 사용하는 등 네트워크간 통신이 발생할 때의 과정을 7계층으로 분류한 것이다. OSI 모델은 프로토콜이 아니라 유연하며 안전하고, 상호 연동이 가능한 네트워크 구조를 설계하고 이해할 수 있다. OSI 7 계층은 말 그대로 각각 특정 기능을 수행하는 서로 다른 7단계의 흐름을 나타낸다. 각 계층은 '헤더(Header)'와 '데이터 단위..

📙 CS/📙 Network

[Network] Load Balancing

1️⃣ 로드 밸런싱 개념 로드 밸런싱(Load Balancing)은 컴퓨터 네트워크 기술의 일종으로, 부하 분산이라고도 한다. 이는 애플리케이션을 지원하는 리소스 풀 전체에 네트워크 트래픽을 균등하게 배포하는 방법이다. 쉽게 말해 서버가 처리해야 할 작업이나 요청을 여러 대의 서버로 분산하여 부하를 낮춰 처리하는 기술이다. 보통 트래픽이 많은 웹 사이트, FTP 사이트, NNTP 서버, DNS 서버 등에서 적용된다. 우리가 대형 마트에 갔을 때 계산대가 하나만 존재한다면 어떨까? 계산하려는 많은 사람들이 모이면서 일을 처리하는 속도가 굉장히 느려질 것이다. 하지만 계산대가 여러 개 존재하면 계산 업무를 적절히 배분하여 효율적으로 진행할 수 있게 된다. 혹은 새로 발매한 게임에 갑기 많은 사용자가 몰린다면..

박갈
'📙 CS/📙 Network' 카테고리의 글 목록