[Kubernetes] kubectl attach vs exec
보통 pod 터미널에 접속할 때 kubectl exec
로 접근해 왔다. 근데 운영팀에서 kubectl attach
에 대해 물으셨고 나 또한 궁금증에 찾아보게 되었다.
attach
와 exec
의 차이점
attach | exec |
---|---|
We can attach to the main process run by the container, which is not always bash. Which is the PID 1 | It allows us to execute any process within the container |
Attach to the one running (no choice) | Run any command you want to execute |
attach
와 exec
는 동일하게 pod에 접근할 수 있다. 하지만 가장 큰 차이점은 attach
는 실행 중인 메인프로세스에만 접근할 수 있고 exec
는 실행중인 아무 프로세스에나 접근이 가능하다는 것이다.
(참고로 컨테이너에서 메인프로세스는 spec.containers.command
에 적혀진 가장 먼저 실행하는 프로세스이다. (PID 1))
그래서 attach
는 새로운 프로세스를 생성하지 못하고 exec
는 새로운 프로세스를 생성할 수 있다.
또한 attach
로 접근하고 ctrl+c로 프로세스를 중지하는 경우 메인 프로세스를 죽여버리는 것이기 때문에 컨테이너가 restartPolicy
정책에 따라 재기동하게 된다
# attach는 메인프로세스에 바로 붙는 반면, exec는 date라는 명령어를 줌으로써 프로세스를 새로 실행하는 것을 볼 수 있다.
$ kubectl attach [pod명]
$ kubectl exec [pod명] -- date
stdin, tty 옵션 사용
위 글을 보고 attach
를 사용하면 kubectl logs
로 보는 것과 유사하게 stdout,stderr 로 출력하고 exec
와 유사하게 stdin을 통해 입력받는다고 생각했다.
하지만 stdin을 통해 입력을 받으려면 exec
과 attach
는 그냥 동일한 옵션 값을 사용하면 된다.
$ kubectl attach --help
Attach to a process that is already running inside an existing container.
Examples:
# Switch to raw terminal mode; sends stdin to 'bash' in ruby-container from pod mypod
# and sends stdout/stderr from 'bash' back to the client
kubectl attach mypod -c ruby-container -i -t
Options:
-i, --stdin=false: Pass stdin to the container
-t, --tty=false: Stdin is a TTY
help로 살펴 봤을 때, stdin 입력이 들어가면 터미널을 통해 stdout/stderr를 출력해 준다는 것이다
일단 stdin과 tty는 각각 -i
, -t
라는 옵션을 주면 되는데 이는 기본 값이 false 이다.
- spec.containers.stdin: true
- spec.containers.tty: true
위 두 값을 true로 바꿔 준다면 터미널을 통해 stdin/stdout/stderr가 활성화된 것을 볼 수 있다!