우분투 17.10 이상에서 IP 설정하기

우분투 17.10부터는 여태까지 우리가 쓰던 NetworkManager 에서 netplan 이 기본값으로 변경됐다.
근데 한국에서 몇몇 리눅스 진영에서 “우분투 17.10 부터 netplan으로 바꾼다더라” 외에는 아무런 정보가 없다.

하긴… 신문물을 거부하는 김치새끼들이 뭐 그렇지 뭐. 그러면서 iOS 운영체제 알파만 나와도 하악하악…

어쨌든, 어쩌다 보니 깐 사람이던 쓰고 싶어서 깔던 뭐 어쩌던 우분투 17.10 환경에서 IP 설정하는 법을 지금부터 싸지르도록 하겠다.

우분투에서 네트워크 관리가 재밌게 변했는데, 사용자가 netplan을 통해 네트워크를 설정하면, netplan은 우리가 썼던 NetworkManager 에 설정을 자동 적용하여 네트워크를 관리하는 그런 도구다.
이는 영문이지만 우분투 위키 에 소개되어 있다.

이 도구는 설정 파일이 파이썬이나 루비 개발자를 제외한 한국인에게 좀 생소한 형식으로 관리를 하는데, 바로 YAML 형식으로 관리한다는 것이다.
뭐… 우리가 많이 쓰는 텍스트 교환 형식이 XML, JSON, 그리고 자바에서 많이 쓰는 Properties와 행 단위로 설정하는 그런 것들인데…
설명하기 귀찮으니 기냥 위키백과 가서 봐라.

설정 파일은 대충 이렇게 생겼다.

# This file describes the network interfaces available on your system
# For more information, see netplan(5).
network:
 version: 2
 renderer: networkd
 ethernets:
   ens33:
     dhcp4: yes
     dhcp6: yes

여기서 뭔자 이상한 문자가 있는데, 우분투 17.10부터 이더넷 식별자가 우리가 알던 ethX 방식이 아닌 ensXYZ 방식으로 바뀌었다.
ifconfig 로 볼 수 있으며, 만약 도커 때문에 가려져서 보기 어려우면 ipconfig | grep : 치면 IPv6 항목과 함께 네트워크 식별자들이 나올 것이다.
당연하겠지만 자동 IP 할당이 기본값이다. 이를 담당하는 게 IPv4의 경우 dhcp4, IPv6의 경우 dhcp6 키로 관리한다. 간단하게 쓸거면 yes, 아니면 no로 설정한다.

그렇다면 수동으로 IP를 관리하고자 한다면 어떻게 변경해야 하나?
바로 생소해 보이는 이더넷 식별자 아래 몇가지 사항을 추가하면 된다.
상하위 구분을 공백 수로 구분하기 때문에 공백으로 고생하는 파이썬 개발자들에겐 익숙할 것이다.

# This file describes the network interfaces available on your system
# For more information, see netplan(5).
network:
 version: 2
 renderer: networkd
 ethernets:
   ens33:
     dhcp4: no
     dhcp6: no
     addresses: [192.168.1.2/24]
     gateway4: 192.168.1.1
     nameservers:
       addresses: [8.8.8.8,8.8.4.4]

여기서 3가지 속성이 추가되는데, addresses, gateway4, nameservers 이다.
뭐 별거 없다. 순서대로 할당할 IP주소, IPv4 방식의 게이트웨이 주소, 그리고 DNS 서버다.
DNS 서버에 하위 항목인 addresses 속성을 추가하여 대괄호로 감싼 쉼표(,) 구분으로 IP를 부여하면 된다.
눈치 깠다면 알겠지만 당연히 IPv6 방식의 게이트웨이 설정은 gateway6이다.
그렇다면 IPv6 방식으로 세팅하려면? 그냥 배열 쳐넣듯이 멀티IP 추가하여 IPv4 IPv6 이렇게 넣는다.
아가리 벌려라 예제 날아온다!

# This file describes the network interfaces available on your system
# For more information, see netplan(5).
network:
 version: 2
 renderer: networkd
 ethernets:
   ens33:
     dhcp4: no
     dhcp6: no
     addresses: [192.168.1.2/24, '2001:1::2/64']
     gateway4: 192.168.1.1
     nameservers:
       addresses: [8.8.8.8,8.8.4.4]

자 이제 한가지 문제가 남았다. 서브넷 마스크는 어디로 간 것일까?
안타깝게도 서브넷 마스크 속성은 여기에 없다. 하지만, 할당 IP주소 뒤에 붙는 저 익숙치 않은 /24를 주목하자.
아는 사람은 알 것이다. 바로 저건 CIDR, 사이더라고 발음하는 마스킹 넘버다.
위 링크로 들어가면 슬래시 뒤에 들어가는 숫자를 “접두어 합침” 제목 아래 나열되어 있다. 저 숫자에 해당하는 서브넷 마스크를 친절하게 소개하니 참고하여 적용한다.
홈 네트워크나 소규모 네트워크라면 보통 IPv4의 경우 24, IPv6의 경우 64를 쓰면 된다. 끝자리 IP 개수만 할당하는 서브넷 마스크 255.255.255.0 주소와 동일하다.

자, 이제 수정을 했으니 적용해야겠지? 아래 명령어 한번 치면 끝난다.
sudo netplan apply

끝이다. 상당히 간결해졌다.
우부투 위키에서 소개하는 netplan 명령어가 몇가지 있는데, 소개하는 것으로 글을 마치도록 하겠다.

  • netplan generate : 명령어를 실행하면 네트워크 구성에 가장 필수적인 설정 파일을 생성하게 된다. 실수로 네트워크 구성이 망가졌을 경우 쓰면 되겠다.
  • netplan apply : 위에서 소개했듯이 변경한 네트워크 설정을 적용한다. 필요시 재시작할 수 있다.
  • netplan ifupdown-migrate : generate와 동일하긴 한데 /etc/network/interfaces 경로에 있는 네트워크 속성을 netplan 방식으로 마이그레이션 하는 명령어이다.

끗.

참고

답글 남기기

Your email address will not be published / Required fields are marked *