본문 바로가기
리눅스 이야기

네트워크 어떻게 동작하나요? 라우팅이란?

by reallinux1 2024. 3. 21.

네트워크 어떻게 동작하나요? 라우팅이란?

네트워크의 동작 과정과 라우터 추적, 그리고 웹 HTTP 통신에 대한 예를 설명드리겠습니다. 이 과정을 통해, 네트워크의 기본적인 원리와 데이터가 어떻게 전송되는지에 대한 이해를 도울 수 있습니다.

●네트워크의 동작 과정

네트워크의 기본 동작과 구조에 대해 실생활 예시를 통해 설명해보겠습니다. 우리는 주로 웹 브라우저를 사용해 naver.com이나 google.com과 같은 웹사이트에 접속합니다. 이 때, 우리의 브라우저는 네이버 서버에서 HTML, CSS, 이미지, 자바스크립트 파일들을 받아와서 페이지를 렌더링하게 됩니다. 이 과정은 브라우저에서 시작하여 웹 서버에서 끝나며, 여러 라우터를 거쳐 이루어집니다.

네트워크를 이해하는 데 있어 '라우터'의 역할을 이해하는 것이 중요합니다. 가정집이나 카페에서 사용되는 여러 기기들(스마트폰, PC, 노트북 등)은 하나의 네트워크 망으로 연결되어 있으며, 이러한 소규모 네트워크들은 라우터를 통해 서로 연결됩니다. 라우터는 카페, 건물, 지역 등 다양한 네트워크 망들 사이를 연결하는 역할을 합니다. 가정에서는 무선 공유기나 AP(Access Point) 같은 장비를 통해 네트워크가 형성되며, 이러한 네트워크들이 라우터를 통해 서로 연결됨으로써, 광범위한 네트워크 연결이 가능해집니다. 결국, 라우터는 다양한 네트워크 망들을 연결하여 커뮤니케이션을 가능하게 하는 중요한 역할을 합니다.

정리하면, 브라우저를 사용하여 웹사이트에 접속하는 과정은 라우터를 포함한 네트워크 장비들을 거치며, 여러 기기가 연결된 가정집이나 카페에서의 네트워크 구성은 우리가 일상에서 직접 경험하는 네트워크의 실제 사례입니다. 이러한 이해를 바탕으로 네트워크의 동작 원리를 더 깊이 이해할 수 있습니다.


●라우터 추적 (Traceroute)
라우터 추적은 데이터 패킷이 송신자로부터 수신자에게 도달하기까지 거치는 라우터들의 경로를 추적하는 과정입니다. 이는 네트워크의 연결 상태와 성능을 진단하는 데 유용합니다. 추적 과정에서는 각 라우터에서의 지연 시간과 패킷 손실 등을 측정할 수 있습니다.

 

웹 HTTP 통신 예
HTTP(HyperText Transfer Protocol)는 웹에서 정보를 교환하기 위한 프로토콜입니다. 사용자가 웹 브라우저를 통해 웹페이지를 요청할 때 다음과 같은 과정을 거칩니다.

요청(Request): 사용자가 웹 브라우저에 URL을 입력하면, 브라우저는 해당 서버에 HTTP 요청을 전송합니다. 이 요청은 웹 서버에 특정 페이지나 자원을 요청하는 것을 포함합니다.
응답(Response): 웹 서버는 요청을 받고, 요청된 페이지나 자원을 찾아 HTTP 응답으로 사용자에게 전송합니다. 이 응답에는 실제 페이지의 내용(HTML, CSS, JavaScript 등)이 포함됩니다.
렌더링: 브라우저는 서버로부터 받은 자원을 해석하고 화면에 표시합니다. 사용자는 이제 원하는 웹페이지를 볼 수 있습니다. 이 과정을 통해, 웹 상에서 정보의 요청과 응답이 어떻게 이루어지는지를 알 수 있습니다.

 

●내부망 네트워크 연결과 데이터 통신
내부망, 즉 인트라넷(Intranet)은 한 조직이나 기업 내부에서만 사용되는 프라이빗 네트워크를 말합니다. 이 네트워크는 기업의 정보, 자원을 공유하고, 내부 커뮤니케이션을 용이하게 하기 위해 구축됩니다. 내부망을 통한 네트워크 연결과 데이터 통신은 다음과 같은 과정으로 이루어집니다.


●내부망 네트워크 연결
내부망, 또는 로컬 네트워크(Local Area Network, LAN)는 한정된 지역 내에서 여러 컴퓨터와 기기들이 서로 연결되어 데이터를 공유할 수 있는 네트워크를 말합니다. 예를 들어, 가정, 학교, 사무실, 카페 등 특정한 공간 내의 기기들이 서로 연결되어 있는 상황을 생각할 수 있습니다.

내부망에서는 여러 기기들이 서로 정보를 교환하기 위해 공유기, 스위치, 무선 액세스 포인트와 같은 네트워크 장비를 사용합니다. 이 장비들은 내부 네트워크 내에서 데이터 패킷의 전송을 중개하며, 각 기기가 고유한 MAC 주소와 IP 주소를 할당받아 네트워크 내에서 서로를 식별할 수 있게 합니다.

네트워크 연결과 데이터 통신의 기본 원리는 기본적으로, 컴퓨터 두 대 이상이 연결되어 있으면 네트워크가 형성됩니다. 이는 두 대의 노트북이 랜선으로 연결되어 있을 때처럼 가장 단순한 형태의 네트워크 예시입니다. 이러한 연결을 통해 데이터 통신이 가능해지며, 단순한 데이터 전송뿐만 아니라 주소 정보를 포함한 데이터 패킷을 전송하는 것이 중요해집니다. 이 주소 정보에는 IP 주소와 TCP/UDP 포트 번호가 포함됩니다. 이는 데이터가 정확한 목적지로 전달될 수 있도록 하는 데 필요합니다.

데이터 통신을 이해하기 위해서는 네트워크 내의 모든 기기가 고유한 MAC 주소를 가지고 있다는 것을 알아야 합니다. MAC 주소는 기기의 네트워크 카드에 할당된 고유한 식별자입니다. 이를 통해 네트워크 상에서 기기를 구분하고, 올바른 목적지로 데이터를 전송할 수 있습니다.

또한, 네트워크 연결과 데이터 통신의 이해를 위해 OSI 7계층 모델을 고려하는 것이 중요합니다. 여기서 L1은 물리적 연결을 나타내며, L2에서는 MAC 주소를 통한 데이터 링크 계층이, 그리고 L3에서는 IP 주소를 통한 네트워크 계층이 활용됩니다. 이 계층들은 데이터가 어떻게 처리되고 전달되는지를 정의합니다.

네트워크 통신에 있어서 MAC 주소와 IP 주소의 역할은 매우 중요합니다. MAC 주소는 네트워크 내의 기기를 구분하는 데 사용되며, IP 주소는 네트워크를 통해 데이터가 올바른 목적지로 전달될 수 있도록 합니다. 또한, TCP와 UDP 포트 번호는 특정 서비스나 애플리케이션에 데이터를 전달하는 데 사용됩니다.

이러한 네트워크 연결과 데이터 통신의 기본 원리는 내부 네트워크(예: 가정집, 카페의 내부 네트워크)와 외부 네트워크(예: 인터넷) 간의 연결을 이해하는 데 도움이 됩니다. 내부 네트워크는 특정한 물리적 공간 내의 기기들이 서로 연결된 네트워크를 말하며, 외부 네트워크는 더 넓은 인터넷을 통한 연결을 의미합니다. 이러한 연결을 가능하게 하는 것은 라우터와 같은 네트워크 장비입니다. 라우터는 다양한 내부 네트워크들을 인터넷과 같은 외부 네트워크에 연결하는 역할을 합니다.

요약하자면, 네트워크 연결과 데이터 통신은 컴퓨터 또는 기기 간의 정보 교환을 가능하게 하는 기본적인 메커니즘입니다. 이 과정에서 MAC 주소, IP 주소, TCP/UDP 포트 번호와 같은 주소 정보가 중요한 역할을 하며, OSI 7계층 모델은 이러한 통신 과정을 이해하는 데 도움이 됩니다.

 

●내부망에서의 데이터 통신
내부망 내에서의 데이터 통신은 주로 TCP/IP 프로토콜을 사용하여 이루어집니다. 각 기기는 고유한 IP 주소를 할당받아 네트워크 내에서 식별될 수 있으며, MAC 주소를 사용하여 물리적으로 구분됩니다. 데이터 패킷은 소스 IP 주소와 목적지 IP 주소, 그리고 필요에 따라 TCP 또는 UDP 포트 번호를 포함하여 전송됩니다. 이러한 주소 정보는 데이터가 네트워크 내의 올바른 목적지로 정확하게 전송되도록 보장합니다.

내부망은 정보의 공유, 리소스의 중앙 집중화, 그리고 네트워크 보안 관리 측면에서 중요한 역할을 합니다. 기기들 간의 효율적인 데이터 교환을 가능하게 하며, 외부로부터의 접근을 제어하여 네트워크의 안전성을 유지합니다

 

●외부망 네트워크 연결과 데이터 통신
외부망 통신과 패킷 전송에 관해 설명하면서, 특히 MAC 주소의 역할과 변화에 대해 상세히 설명해보겠습니다. 외부망으로의 데이터 전송 과정에서는 Ethernet 헤더, IP 헤더, TCP 헤더와 같이 다양한 헤더 정보가 사용됩니다. 이러한 헤더들은 데이터 패킷의 올바른 전달을 위해 필요한 정보를 담고 있으며, 전송 프로토콜에 따라 포함되는 헤더 정보가 다를 수 있습니다.


●MAC 주소의 역할과 변화
외부망 통신에서 MAC 주소는 중요한 역할을 합니다. 하지만, 데이터가 송신자로부터 수신자에게 전달될 때, 매 중계 단계마다 MAC 주소가 변경됩니다. 이는 네트워크 패킷이 라우터나 스위치와 같은 네트워크 장비를 거치면서, 해당 장비의 MAC 주소를 기준으로 다음 목적지로 전송되기 때문입니다.

예를 들어, 사용자가 구글의 웹사이트에 접속하고자 할 때, 사용자의 컴퓨터는 초기에 자신의 MAC 주소를 출발지 MAC 주소로, 그리고 가장 가까운 네트워크 장비(예: 라우터 또는 게이트웨이)의 MAC 주소를 목적지 MAC 주소로 설정하여 데이터 패킷을 전송합니다. 이후에 패킷은 네트워크 장비들을 거치며 각 단계마다 출발지와 목적지 MAC 주소가 해당 장비의 주소로 갱신됩니다. 최종적으로, 패킷이 목적지에 도달할 때까지 이 과정이 반복됩니다.

●외부망 통신의 핵심 포인트
라우터와 게이트웨이의 역할: 데이터 패킷이 내부 네트워크에서 외부 네트워크로 전송될 때, 라우터나 게이트웨이와 같은 네트워크 장비가 중요한 역할을 합니다. 이 장비들은 데이터를 인터넷으로 라우팅하는 데 필요한 정보를 제공합니다.

MAC 주소의 변화: 네트워크 패킷이 각 중계 장비를 거치면서 MAC 주소가 계속해서 갱신된다는 점은 외부망 통신에서 중요한 특징입니다. 이는 패킷이 최종 목적지에 도달하기까지 많은 중계 과정을 거친다는 것을 의미합니다.

IP 주소와 TCP/UDP 주소의 중요성: 외부망 통신에서는 MAC 주소와 함께 IP 주소와 TCP 또는 UDP 포트 번호가 핵심적인 역할을 합니다. 이 주소들은 인터넷 상에서 패킷이 올바른 목적지로 전달되도록 하는 데 필수적인 정보입니다.

네트워크 통신의 이해에서 MAC 주소의 변화와 라우팅 과정의 이해는 중요한 요소입니다. 이는 데이터가 네트워크 장비를 통해 효율적으로 전달되도록 하는 기본 메커니즘으로, 네트워크의 복잡성과 효율성을 동시에 증가시킵니다. 이러한 과정은 네트워크의 효율적인 운영과 데이터의 신속한 전송을 가능하게 하며, 각 네트워크 장비의 역할을 이해하는 것이 중요합니다. 결국, 외부망 통신에서는 네트워크의 물리적 연결과 더불어, 전송되는 데이터의 경로가 어떻게 설정되고, 변경되는지를 이해하는 것이 핵심입니다.

이러한 이해를 통해, 우리는 네트워크 상에서 데이터가 어떻게 효율적으로 이동하는지, 그리고 다양한 네트워크 장비가 어떻게 협력하여 데이터를 최종 목적지까지 안전하게 전달하는지를 파악할 수 있습니다. 또한, 이 과정에서 IP 주소와 TCP/UDP 포트 번호와 같은 주소 정보의 중요성을 다시 한 번 확인할 수 있습니다. 이들은 네트워크의 복잡한 구조 속에서도 데이터가 정확한 목적지로 전달되도록 보장하는 역할을 합니다.

네트워크 통신의 이해는 단순히 기술적인 지식을 넘어서, 현대 사회에서 정보가 어떻게 흐르고, 사람들 간의 커뮤니케이션이 어떻게 이루어지는지를 이해하는 데 깊은 통찰을 제공합니다. 네트워크 기술의 발전과 함께, 우리는 더욱 빠르고 안정적인 데이터 통신의 혜택을 누릴 수 있게 되었으며, 이를 통해 글로벌 커뮤니케이션이 가능한 오늘날의 디지털 시대의 기반을 이해할 수 있습니다. 따라서 네트워크 통신의 기본 원리를 이해하는 것은 단순한 기술적 호기심을 넘어, 현대 사회를 살아가는 데 있어 필수적인 지식이 됩니다.


●NAT 공인 IP 주소에서 사설 IP 주소 변환
NAT(Network Address Translation)은 공인 IP 주소와 사설 IP 주소 사이의 변환을 담당하는 기술로, 하나의 공인 IP 주소를 여러 장치가 공유하여 인터넷에 접속할 수 있게 합니다. 이 과정은 주로 라우터에서 수행되며, 내부 네트워크(사설 네트워크)와 외부 네트워크(인터넷) 사이에서 IP 주소를 변환하는 역할을 합니다. NAT의 주요 목적은 IP 주소의 효율적인 사용과 네트워크 보안 강화입니다.

●NAT 작동 방식
사설 IP 주소 할당: 내부 네트워크에 있는 각 장치(컴퓨터, 스마트폰 등)는 고유의 사설 IP 주소를 할당받습니다. 이 주소들은 인터넷 전체에서 유일하지 않으며, 같은 사설 네트워크 내에서만 의미가 있습니다.

인터넷 요청 시 NAT 변환: 내부 네트워크의 장치가 인터넷에 데이터를 요청할 때, 해당 요청은 먼저 NAT를 수행하는 라우터로 전송됩니다. 라우터는 이 요청에서 사설 IP 주소를 라우터의 공인 IP 주소로 변환합니다.
외부 응답과 내부 전달: 외부 서버로부터 응답이 돌아오면, NAT 라우터는 이 응답을 적절한 내부 장치의 사설 IP 주소로 다시 변환하여 전달합니다. 이 과정에서 NAT 테이블(또는 NAT 매핑 정보)을 사용하여 어떤 외부 응답이 어떤 내부 장치로 전달되어야 하는지를 판단합니다.

●NAT의 주요 유형
정적 NAT(Static NAT): 공인 IP 주소와 사설 IP 주소를 1:1로 고정적으로 매핑합니다. 이는 주로 공인 IP 주소를 고정적으로 사용해야 하는 웹 서버나 메일 서버에 사용됩니다.

동적 NAT(Dynamic NAT): 여러 사설 IP 주소와 공인 IP 주소 간의 동적 매핑을 제공합니다. 사용 가능한 공인 IP 주소 풀에서 필요에 따라 자동으로 IP 주소를 할당받습니다.
PAT(Port Address Translation), 또는 NAT 오버로딩: 여러 사설 IP 주소를 단일 공인 IP 주소에 매핑하되, 각 연결을 구분하기 위해 포트 번호를 사용합니다. 이 방식은 가장 널리 사용되며, 하나의 공인 IP 주소로 많은 내부 장치들이 인터넷에 접근할 수 있게 합니다.
NAT는 IP 주소의 부족 문제를 해결하고, 내부 네트워크의 보안을 강화하는 중요한 기술입니다. 또한, 내부 네트워크 구성의 유연성을 제공하며, 외부로부터의 직접적인 접근을 차단함으로써 네트워크를 보호합니다.

이와 관련된 리얼리눅스 강의는
도커/K8s/클라우드(AWS) 네트워크 완전 정복 :https://reallinux.co.kr/course/se_network

 

Reallinux | 서버엔지니어 | 도커/K8s/클라우드(AWS) 네트워크 완전 정복

네트워크 기본개념핵심정리/ 다양한 네트워크 추적/분석실습 네트워크 실전능력향상

reallinux.co.kr

https://www.youtube.com/watch?v=UmfhI8AYHuA