1.1. 장점 ¶
- MiKTeX 특유의 MPM 시스템 덕분에 작은 크기의 이미지만 설치하고도 이후의 작업에 지장이 없다. 패키지나 유틸리티가 필요해지면 스스로 다운로드받는다.
- 현재 MiKTeX (21.X)은 갱신이 빠르고 상당히 안정적이다. TeX Live와 큰 차이가 없다.
- texmf를 추가하여 운영할 수 있기 때문에 사용자 패키지를 활용하는 것이 가능하다. (KTUG 사설저장소 패키지들을 미리 설치해둔 후에 등록하여 쓸 수 있다.)
- Linux MiKTeX은 실행 속도에서도 만족스럽다.
- 호스트 운영체제가 무엇이든 상관없이 동일하게 동작한다.
- docker에서 돌아간다는 것이 장점이다.
2. 설치 ¶
- miktex docker image
docker pull miktex/miktex
- miktex/miktex이 ARM 아키텍처를 제공하지 않는 듯한데, M1 Mac에서 Rosetta2로 어찌어찌 되는지 어떤지 해보지 않아서 모릅니다. 시도해보신 분은 추가바람.
- build container
docker run -ti \ --name <unique_name> \ -v miktex:/miktex/.miktex \ -v <working_dir>:/miktex/work \ miktex/miktex
<unique_name>
은 기억하기 쉬운 container 이름으로. (이하
mymiktex
으로 예를 들 것임.)
<working_dir>
는 host측 작업 디렉토리. Windows라면
C:/MyTeXWork
과 같은 방법으로 지정한다.
- starting/stopping container
docker start mymiktex docker stop mymiktex
- executing container
docker exec -ti mymiktex /bin/bash
/bin/bash
를 실행하면 docker container 시스템 내부의 bash가 열린다. 이 시스템은 Debian Linux이다.
/bin/bash
대신 컴파일 명령을 줄 수 있다. ex)
docker exec -ti mymiktex xelatex --shell-escape --synctex=1 mytex.tex
3. novadehi/miktexwktug ¶
- 소개글
- Dockerized MiKTeX에 KTUG Private Repository의 주요 패키지들과 미리 설정된 Emacs + Okular 작업 환경을 추가한 개인 배포 버전.
- Windows 11, Linux, Mac OS에서 실행 가능하다.
- Apple Silicon Mac을 위한 arm64 플랫폼의 MikTeX binary가 (아직) 없기 때문에
--platform linux/amd64
옵션을 주어서 (로제타를 경유하여) 실행하여야 한다. DeleteMe 확인요망. - 별도로 TeX 시스템과 에디터를 설치할 필요 없이 이 도커 이미지 하나로 TeX 사용환경을 설정할 수 있다.
- Workflow 자동화 프로그램은 latexmk, spix, cluttex, texify 등이 있다. arara는 jre가 설치되어 있지 않기 때문에(용량문제로) 사용할 수 없다. cluttex의 경우 clxelatex과 같은 단축 명령은 제공하지 않는다.
cluttex -e xelatex
과 같이 사용하여야 한다. latexmk 또는 spix를 권장함.- arara가 꼭 필요하면 container를 만들어서
apt install default-jre
명령을 한 번 준다. 이 container를 commit하여 사용할 수 있다.
- arara가 꼭 필요하면 container를 만들어서
- pygments는 설치되어 있다. minted 사용 가능함.
- 한글 폰트는 함초롬LVT와 나눔글꼴(사설저장소 제공 글꼴) 및 Noto CJK KR. 다른 폰트가 필요하면 host computer의 폰트 폴더를 volume 옵션(
-v
)으로/root/.fonts
아래 디렉터리로 연결하여 사용한다. - Emacs의 한영 전환은
C-\
이외에Shift-SPC
. - Emacs에서 View를 열려면
C-c C-c
, 또는C-c C-a
. Okular에서 Inverse Search는 "Browse" 도구 상태에서Shift+Click
. - Emacs 내부에서 ShellEscape 해야 한다면
M-x customize-variable RET TeX-command-extra-options RET
로 편집창을 연 상태에서-shell-escape
를 추가하고 Apply.
- Workflow 자동화 프로그램은 latexmk, spix, cluttex, texify 등이 있다. arara는 jre가 설치되어 있지 않기 때문에(용량문제로) 사용할 수 없다. cluttex의 경우 clxelatex과 같은 단축 명령은 제공하지 않는다.
3.1.1. 공통 ¶
아래 docker 명령은 (시스템 설정에 따라)
sudo
를 필요로 할 수 있음.
- 시작하기:
$ docker pull novadehi/miktexwktug
- 볼륨 만들기 (처음 한 번만 하면 되고 볼륨은 docker로 관리 가능)
$ docker volume create --name miktex
- 컴파일 명령으로 실행 (xelatex)
$ docker -v miktex:/miktex/.miktex -v $(pwd):/miktex/work novadehi/miktexwktug xelatex <filename>.tex
3.1.2. Windows ¶
- Windows 11 (build 22000) 필요. WSL 2 설정을 행한 다음 다음 순서로 진행한다.
- ubuntu 설치 실행
> winget ubuntu
- docker desktop 설치 실행
> winget "Docker Desktop"
- ubuntu 설치 실행
- GUI 프로그램은 wsl 명령행에서 실행한다.
# docker run -ti --rm \ -v miktex:/miktex/.miktex \ -v $(pwd):/miktex/work \ -e DISPLAY=:0 \ -v /tmp/.X11-unix:/tmp/.X11-unix \ novadehi/miktexwktug emacs
- 윈도우즈 시스템 폰트를 컴파일에 사용하려면 다음 행을 추가한다. (wsl 명령행 기준)
-v /mnt/c/Windows/Fonts:/root/.fonts/winfonts
- GUI Emacs 없이 컴파일러로만 사용하려면 cmd 명령행에서도 가능하다. 다만
$(pwd)
대신 현재 작업 디렉터리를 다음과 같은 형식으로 지정.-v C:/Users/myname/Documents/texwork:/miktex/work
3.1.3. Mac OS ¶
- XQuartz를 설치하고 Preferences에서 Security -> Allow connections from network clients 체크
- terminal에서 다음 명령을 한 번 실행
# xhost + localhost
- Emacs를 실행하는 명령
# docker run -ti --rm \ -v miktex:/miktex/.miktex \ -v $(pwd):/miktex/work \ -e DISPLAY=host.docker.internal:0 \ -v /tmp/.X11-unix:/tmp/.X11-unix \ novadehi/miktexwktug emacs
/tmp/.X11-unix
부분은 없어도 된다.
3.1.4. Linux ¶
- GUI를 위하여 다음 명령을 미리 실행해둔다.
# xhost local:root
- Emacs 실행
# docker run -ti --rm \ -v miktex:/miktex/.miktex \ -v $(pwd):/miktex/work \ -e DISPLAY -v /tmp/.X11-unix:/tmp/.X11-unix \ novadehi/miktexwktug emacs
4.1. Docker daemon 실행 방법 ¶
- Windows, Mac OS에서는 Docker Desktop을 이용하는 것이 제일 쉽다.
- OpenSUSE의 경우, 다음과 같이.
sudo systemctl start docker
- Ubuntu에서는
sudo service docker start