목록으로

맥을 Docker remote host로 사용하기

낱글
2024. 10. 3. AM 7:49:42

배경

작업 PC로 인텔 아이맥 27인치를 사용했습니다. 디스플레이가 괜찮은데다 램을 128기가로 넉넉하게 구성해서 유용했죠. 그런데 CPU 발열이 심한 편이라서 CPU 과부하가 심할 땐 과열로 시스템이 뻗곤 했습니다. 그래서 작업 PC로 사용할 맥 스튜디오를 샀습니다. 가격이 부담스러워서 램 용량이 적은 32기가 메모리 모델을 샀는데, 램을 주로 점유하는 것들을 아이맥에서 띄워 서버용으로 사용할 계획이기 때문이지요.
램을 많이 사용하는 것 중 하나는 Docker입니다. 그래서 아이맥을 Docker Remote Host용으로, 간단히 말해서 Docker 서버용으로 사용하도록 설정하기로 했습니다. 그런데 Docker를 서버로 구동할 dockerd는 Linux에서 동작하며, Mac OS는 지원하지 않기 때문에 VirtualBox에 Linux를 가상화하여 Guest OS로 구동한 후, 그곳에 Docker를 사용해야 합니다. 따라서 아이맥에 VirtualBox로 Linux를 설치하고, 그 가상화로 구동하는 Linux에 구성한 dockerd를 사용합니다. Host OS인 Mac OS와 Guest OS인 Linux 간 네트워크도 연결해주고 말이지요.
귀찮기도 하고 웬지 무겁고 비효율적일 것 같은데, 이 글에서 사용할 Docker desktop 대체재인 OrbStack을 사용하여 쉽게 설정하고 가볍게 동작하는 환경을 구성할 수 있습니다.
  • 아이맥 : Ventura 13.4
  • Docker client : OrbStack

Docker 설치와 설정

  • Docker remote host인 아이맥에 OrbStack 설치.
  • 원격으로 접근할 client인 맥스튜디오에도 설치.

Docker engine을 daemon으로 구동할 Ubuntu 서버 구성

아이맥이 인텔맥이라서 아키텍쳐를 amd64로 지정했지요.
Linux machine을 만들고 나면 ssh로 접근 가능합니다.
기본으로 생성되는 계정 이름이 default입니다.
Linux machine을 생성하면 OrbStack이 이 ubuntu에 ssh로 접근할 수 있게 ssh host configuration을 자동으로 만들어줘서 더 적게 타이핑하여 접근할 수 있어요.
orb가 OrbStack이 만든 ssh host configuration이다.

Docker engine 설치

충돌날만한 불필요한 패키지 제거

Docker repository 설정

HTTPS로 repository에서 패키지를 가져와 설치해야 하므로 관련 패키지를 설치합니다.
Docker의 공식 GPG 키를 추가하세요.
Docker 공식 repository에서 패키지를 가져와 설치합니다.

Docker를 system 서비스로 등록한다

Remote access되도록 docker 설정

/etc/docker/daemon.json에 설정하거나 systemd에서 docker 서비스 실행에서 인자로 지정하는데, 여기에선 후자 방법으로 합니다. daemon 설정이 더 늘어나면 그때 분리하려고요.
후자 방법은 /etc/systemd/system/docker.service.d/override.conf 파일을 편집하는 겁니다. 이런 단위 구조는 edit 명령을 사용하면 구성됩니다.
이제 /etc/systemd/system/docker.service.d 디렉터리가 생기고 그 안에 override.conf 파일이 만들어지는데, 그곳에 dockerd 실행 유닛을 작성합니다.
-H 옵션은 Docker daemon 소켓이 연결할(사용할) 호스트를 지정합니다. -H fd://는 Unix file descriptor로 호스트 연결을 하는 것이고, -H tcp://127.0.0.1:2375127.0.0.1:2375 TCP IP로 연결하죠 . -H fd://는 기본(default) 옵션이고, TCP로 원격 접근하도록 -H tcp://... 옵션을 추가한 것입니다.
systemd service 스크립트를 수정하지 않고 override.conf를 수정하는 이유는 자동으로 override.conf가 포함되기 때문입니다. sudo systemctl status docker.service 명령을 실행해 확인해볼까요?
Drop-In에 보면 include한 conf 파일 중 하나인 override.conf가 명시되어 있다.
systemd service script를 변경했으니 systemd가 해당 script를 다시 적재하도록 하고, docker를 재실행합니다.

Mac OS에 TCP forwarding 설정

Docker remote host에 Linux machine을 만들어 docker daemon을 띄웠으니 외부에서 이 host에 접근해 docker host에 접근하도록 TCP 포워딩을 합니다. Linux machine에 하는 것이 아니라 Linux machine를 guest OS로 구동한 Host OS인 Mac OS에 설정하는 거죠. 이 글에서는 아이맥에 하는 거예요.

원격 로그인 설정

System Settings - General - Sharing에 들어가세요(한국어로 뭐라고 나오는지는 모르는 점, 양해바랍니다). Remote Login(원격 로그인?)을 활성화하세요. ssh daemon을 사용할지를 설정하는 거예요. 느낌표 아이콘을 클릭하면 ssh로 접근을 허용할 계정을 지정하는 화면이 나옵니다. 이 글에서는 Administrators는 빼고 개인 계정을 추가했습니다.
다른 Host에서 ssh로 접근 가능한지 테스트 해보세요. 이 글에서는 맥 스튜디오에서 아이맥으로 접근하는 거예요.
잘 될 겁니다. 타이핑하기 귀찮으니 ssh host 설정을 해줍니다.
이제 호스트명인 imac으로 간편하게 접근됩니다.
이 ssh host인 imac은 ssh 호스트가 필요한 곳엔 어디에서든지 사용할 수 있으므로 설정해두면 편리하지요.

SSH daemon에 TCP forwarding 허용 설정

/etc/ssh/sshd_config 파일을 열어 AllowTcpForwardingGatewayPorts 설정을 추가하거나 주석을 해제합니다.
이런 설정을 하는 이유는 OrbStack은 보안을 이유로 OrbStack이 관리하는 Linux machine에 원격으로 접근하지 못하기 때문입니다. OrbStack을 구동한 localhost에서만 접근 가능하죠.
ssh daemon 설정을 변경하면 ssh daemon에 반영되도록 재실행해야 합니다. 앞서 Sharing에 있던 Remote Login을 비활성화했다가 다시 활성화하면 됩니다.

Client 설정

Client, 즉, 램이 32기가인 맥 스튜디오에 있는 docker가 아이맥에 있는 docker를 서버로 사용하도록 지정하는 건 대개 두 가지 방법 중 하나를 사용합니다.

DOCKER_HOST 환경 변수 사용

환경변수인 DOCKER_HOST에 docker가 사용할 host를 지정하는 방법입니다.
하지만 환경변수는 실수하기 십상이니 다른 방법을 사용하겠습니다.

docker context 사용

docker에서 제공하는 context 기능을 이용하는 것이다. 먼저 Docker remote host인 imac에 대한 context를 만듭니다.
imac-docker는 context 이름입니다. 잘 만들어졌는지 확인해보죠.
default가 기본으로 존재하고, OrbStack을 설치하면 orbstack도 생겨요. 이들을 포함하여 방금 만든 imac-docker context가 목록에 나옵니다.
docker context는 use 보조 명령어로 사용합니다.
이제 docker는 imac-docker context에 지정된 Host에 연결합니다. 확인해볼까요. imac-docker context를 지정한 상태에서 docker container를 구동합니다.
아이맥에 있는 docker에 컨테이너가 구동된 것이라면 맥 스튜디오에 있는 docker에는 구동된 컨테이너가 없을테니 그걸 확인합니다.
맥 스튜디오엔 아무 컨테이너도 없네요. 아이맥에 있는 docker를 확인해볼까요?
잘 떠있습니다. 이렇게해서 5K 해상도 디스플레이가 달린 Docker 서버를 마련했습니다.
토이스토리 2기 모집 중!
푸딩캠프 뉴스레터를 구독하면 학습과 성장, 기술에 관해 요약된 컨텐츠를 매주 편하게 받아보실 수 있습니다.