Interview/Network

네트워크 인터페이스

김 정출 2024. 10. 18. 23:33

네트워크 인터페이스

네트워크 인터페이스(Network Interface)는 컴퓨터 또는 네트워크 장치가 네트워크에 연결되고 통신할 수 있도록 하는 하드웨어와 소프트웨어의 조합을 의미합니다. 네트워크 인터페이스는 여러 종류가 있으며, 각기 다른 기술과 프로토콜을 사용합니다. 여기서 주요 개념을 살펴보겠습니다.


1. 네트워크 인터페이스의 종류

  • 이더넷 카드 (NIC): 가장 일반적인 네트워크 인터페이스로, 유선 LAN에서 사용됩니다. 컴퓨터의 메인보드에 내장되어 있거나 별도로 추가할 수 있습니다.
  • 무선 LAN 카드 (Wi-Fi): 무선 네트워크에 연결하기 위한 카드로, 무선 신호를 수신하고 송신합니다.
  • 모뎀: 인터넷 서비스 제공업체(ISP)와 연결하기 위한 장치로, 아날로그 신호를 디지털 신호로 변환하는 역할을 합니다.
  • 가상 네트워크 인터페이스: 가상화 환경에서 사용되며, 가상 머신(VM)이나 컨테이너가 물리적 네트워크에 연결될 수 있도록 합니다.

2. 네트워크 인터페이스의 기능

  • 데이터 전송 및 수신: 네트워크 인터페이스는 데이터 패킷을 송수신하여 장치 간의 통신을 가능하게 합니다.
  • 주소 지정: 각 네트워크 인터페이스는 고유한 MAC 주소를 가지며, 이는 네트워크에서 장치를 식별하는 데 사용됩니다.
  • 프로토콜 지원: 다양한 통신 프로토콜(TCP/IP, UDP 등)을 지원하여 네트워크 통신을 관리합니다.

3. 네트워크 인터페이스의 구성

  • 하드웨어: 물리적 장치로, 연결 포트(이더넷 포트, USB 포트 등), 칩셋, 안테나(무선의 경우) 등이 포함됩니다.
  • 소프트웨어: 드라이버와 운영체제의 네트워크 스택이 포함되어, 하드웨어와 소프트웨어 간의 통신을 가능하게 합니다.

4. 네트워크 인터페이스의 설정

  • IP 주소 할당: DHCP(Dynamic Host Configuration Protocol)를 통해 자동으로 IP 주소를 할당받거나, 수동으로 설정할 수 있습니다.
  • 서브넷 마스크: 네트워크의 범위를 정의하는 값으로, IP 주소와 함께 설정됩니다.
  • 게이트웨이: 외부 네트워크와의 연결을 위해 설정하는 라우터의 IP 주소입니다.

5. 네트워크 인터페이스의 성능

  • 대역폭: 네트워크 인터페이스가 지원하는 최대 데이터 전송 속도로, 일반적으로 Mbps(Megabits per second)로 측정됩니다.
  • 지연 시간: 데이터가 송수신되는 데 걸리는 시간으로, 낮을수록 좋습니다.
  • 오류율: 데이터 전송 중 발생하는 오류의 비율로, 낮은 오류율이 이상적입니다.

Ubuntu에서 네트워크 인터페이스 설정 및 관리에 유용한 명령어와 패키지를 소개하겠습니다. 이를 통해 네트워크 인터페이스를 효과적으로 설정하고 문제를 해결할 수 있습니다.

1. 네트워크 인터페이스 설정

Ubuntu에서는 네트워크 인터페이스를 설정하는 데 여러 방법이 있으며, 일반적으로 다음과 같은 파일을 사용합니다.

  • Netplan: Ubuntu 17.10 이후의 기본 네트워크 설정 도구입니다. /etc/netplan/ 디렉터리에 YAML 파일이 위치합니다.
  • 예제 (YAML 설정):
network:
  version: 2
  ethernets:
    enp3s0:
      dhcp4: true
      addresses:
        - 192.168.1.100/24
      gateway4: 192.168.1.1
      nameservers:
        addresses:
          - 8.8.8.8
          - 8.8.4.4

설정 후 다음 명령어로 적용합니다:

sudo netplan apply
  • NetworkManager: GUI와 CLI 모두 지원하는 네트워크 관리 도구입니다. nmcli 명령어로 CLI에서 관리할 수 있습니다.

2. 유용한 명령어

2-1. ip

ip: 네트워크 인터페이스 및 라우팅 정보를 관리하는 데 사용됩니다.

모든 네트워크 인터페이스 보기:

ip addr show
---
1: lo: <LOOPBACK,UP,LOWER_UP> mtu 65536 qdisc noqueue state UNKNOWN group default qlen 1000
    link/loopback 00:00:00:00:00:00 brd 00:00:00:00:00:00
    inet 127.0.0.1/8 scope host lo
       valid_lft forever preferred_lft forever
2: enp3s0: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc fq_codel state UP group default qlen 1000
    link/ether 00:1a:2b:3c:4d:5e brd ff:ff:ff:ff:ff:ff
    inet 192.168.1.100/24 brd 192.168.1.255 scope global dynamic enp3s0
       valid_lft 86400sec preferred_lft 86400sec
    inet6 fe80::21a:2bff:fe3c:4d5e/64 scope link
       valid_lft forever preferred_lft forever

특정 인터페이스의 정보 보기:

ip addr show <interface_name>

인터페이스 활성화/비활성화:

sudo ip link set <interface_name> up
sudo ip link set <interface_name> down

2-2. ifconfig

  • ifconfig: net-tools 패키지를 설치해야 사용할 수 있습니다.

모든 인터페이스 보기:

ifconfig
---
lo        Link encap:Loopback  HWaddr 00:00:00:00:00:00  
          inet addr:127.0.0.1  Mask:255.0.0.0
          inet6 addr: ::1/128 Scope:Host
          UP LOOPBACK RUNNING  MTU:65536  Metric:1
          RX packets:12345 errors:0 dropped:0 overruns:0 frame:0
          TX packets:12345 errors:0 dropped:0 overruns:0 carrier:0
          collisions:0 txqueuelen:0 
          RX bytes:1234567 (1.2 MB)  TX bytes:1234567 (1.2 MB)

enp3s0   Link encap:Ethernet  HWaddr 00:1A:2B:3C:4D:5E  
          inet addr:192.168.1.100  Bcast:192.168.1.255  Mask:255.255.255.0
          inet6 addr: fe80::21a:2bff:fe3c:4d5e/64 Scope:Link
          UP BROADCAST RUNNING MULTICAST  MTU:1500  Metric:1
          RX packets:54321 errors:0 dropped:0 overruns:0 frame:0
          TX packets:54321 errors:0 dropped:0 overruns:0 carrier:0
          collisions:0 txqueuelen:1000 
          RX bytes:9876543 (9.8 MB)  TX bytes:9876543 (9.8 MB)

2-3. ping

  • ping: 네트워크 연결을 확인하는 데 사용됩니다.
ping <IP_address_or_hostname>

2-4. traceroute

  • traceroute: 패킷이 네트워크를 통해 이동하는 경로를 추적합니다.
  • 패킷이 목적지에 도달하기까지 거치는 경로를 추적하는 데 사용됩니다. 이 명령어는 네트워크의 라우터를 통해 데이터 패킷이 이동하는 경로를 보여주므로, 네트워크 문제를 진단하는 데 유용합니다. 아래는 traceroute 명령어의 예제 출력입니다.
sudo apt install traceroute
traceroute <destination>
---
traceroute to google.com (142.250.184.14), 30 hops max, 60 byte packets
 1  192.168.1.1 (192.168.1.1)  1.234 ms  1.456 ms  1.678 ms
 2  10.0.0.1 (10.0.0.1)  10.345 ms  10.567 ms  10.789 ms
 3  isp-gateway.example.com (203.0.113.1)  15.456 ms  15.678 ms  15.890 ms
 4  198.51.100.1 (198.51.100.1)  20.123 ms  20.345 ms  20.567 ms
 5  142.250.185.21 (142.250.185.21)  25.678 ms  25.890 ms  26.123 ms
 6  142.250.184.14 (142.250.184.14)  30.456 ms  30.678 ms  30.890 ms

2-5. nslookup

  • nslookup: DNS 조회를 수행합니다.
  • DNS(Domain Name System) 서버에 쿼리를 보내어 도메인 이름과 관련된 정보를 조회하는 데 사용됩니다. 이 명령어를 통해 IP 주소, MX 레코드(메일 서버), NS 레코드(네임서버) 등을 확인할 수 있습니다. 아래는 nslookup 명령어의 예제 출력입니다.
nslookup <domain_name>
---
Server:		8.8.8.8
Address:	8.8.8.8#53

Non-authoritative answer:
Name:		google.com
Address:	142.250.184.14
Name:		google.com
Address:	2607:f8b0:4005:803::200e

2-6. netstat

  • netstat: 네트워크 연결, 라우팅 테이블 및 인터페이스 통계를 표시합니다. net-tools 패키지가 필요합니다.
netstat -tuln

2-7. telnet

  • telnet : 원격 호스트에 텍스트 기반의 인터페이스를 통해 연결할 수 있는 프로토콜이자 명령어입니다. 주로 네트워크 서비스를 테스트하거나 원격 장비에 접근하기 위해 사용되지만, 보안상의 이유로 많이 사용되지 않는 프로토콜입니다. telnet은 암호화되지 않은 통신을 사용하므로, 민감한 데이터 전송에 적합하지 않습니다.
telnet <hostname> <port>

telnet example.com 80
---
Trying 93.184.216.34...
Connected to example.com.
Escape character is '^]'.

2-8. curl

  • curl: HTTP 요청을 테스트하고 API와 상호작용하는 데 사용됩니다.
curl -I <url>

2-9. wget

  • wget: 파일을 다운로드하는 데 사용됩니다.
wget <url>

이 외에도 Ubuntu의 네트워크 관리에는 많은 도구와 명령어가 있습니다. 상황에 따라 적절한 명령어와 패키지를 선택하여 사용하세요!


네트워크 인터페이스는 현대의 컴퓨터 네트워크에서 매우 중요한 역할을 하며, 안정적이고 빠른 통신을 위해 적절한 구성과 유지 관리가 필요합니다.