0
0

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

#15.kubectl debugコマンドを試してみた+おまけ

Last updated at Posted at 2025-02-01

はじめに

以前に、Xでkubectl debugコマンドという便利なコマンドがあることを教えてもらったことがあり、試してみようとは思っていたのですが先延ばしになっていました。
今回はkubectl debugコマンドの動作確認とcompassのイベントに参加してきたのでそちらについて記事にしました。

kubectl debugコマンドとは?

名前の通りにKubernetes用に使用されるdebug用のコマンドです。
基本的にはコンテナイメージを指定してエフェメラルコンテナ(一時的なdebug用のコンテナ)を作成後、実際に調査をしたり、動作確認をするといった感じです。

image (81).png

以下のリンクに記載されているコマンドのオプションを組み合わせて作ったコマンドでエフェメラルコンテナを作成してコンテナ内に入ってみました。
debug用のコマンドとはいえサポートされているオプションが多く、用途によって使い分けるのが難しそうですね。

# kubectl debug {Pod名} -n {namespace名} -it --image={コンテナイメージ名} -- /bin/bash 
--profile=legacy is deprecated and will be removed in the future. It is recommended to explicitly specify a profile, for example "--profile=general".
Defaulting debug container name to debugger-bwgg7.
If you don't see a command prompt, try pressing enter.

debugger-bwgg7という名前で作成されましたね。
今回私が使用したコンテナイメージがNginxを動作させる環境のものとなっているので、
Nginx関連のファイルを確認します。

  • エフェメラルコンテナ内
# ls -la /etc/nginx/
total 40
drwxr-xr-x    1 root     root          4096 Jan 21 08:29 .
drwxr-xr-x    1 root     root          4096 Feb  1 20:27 ..
drwxr-xr-x    1 root     root          4096 Jan 21 08:29 conf.d
-rw-r--r--    1 root     root          1077 Nov 27 02:22 fastcgi.conf
-rw-r--r--    1 root     root          1007 Nov 27 02:22 fastcgi_params
-rw-r--r--    1 root     root          5349 Nov 27 02:22 mime.types
lrwxrwxrwx    1 root     root            22 Jan  9 02:59 modules -> /usr/lib/nginx/modules
-rwxrwxrwx    1 root     root          1592 Jan  9 20:19 nginx.conf
-rw-r--r--    1 root     root           636 Nov 27 02:22 scgi_params
-rw-r--r--    1 root     root           664 Nov 27 02:22 uwsgi_params

ちゃんと作成されていますね。
もちろん、実際のファイルの修正やテストコマンドの確認も行えます。

# vi /etc/hosts

出力情報
# Kubernetes-managed hosts file.
127.0.0.1       localhost nayanaya
# ping nayanaya
PING nayanaya (127.0.0.1): 56 data bytes
64 bytes from 127.0.0.1: seq=0 ttl=64 time=0.027 ms
64 bytes from 127.0.0.1: seq=1 ttl=64 time=0.034 ms
64 bytes from 127.0.0.1: seq=2 ttl=64 time=0.045 ms
64 bytes from 127.0.0.1: seq=3 ttl=64 time=0.042 ms

kubectl describeで確認してみるとEphemeral Containersとして作成されてますね。

# kubectl describe pod {Pod名} -n {namespace名}
Ephemeral Containers:
  debugger-bwgg7:
    Container ID:  docker://d5b73ff7d7502e10563d50709983b214995e384bba5c27a9a2d9826d77ab44b3
    Image:         Kubernetes/nginx:v1.0.0
    Image ID:      docker-pullable://Kubernetes/nginx@sha256:ef17aaeed3f04d99242801859b2c1adaa61ff29230a88ae9a56f7c46492d2141
[以下省略]

これらのことからkubectl debugコマンドを使用することで本番環境でも安全にトラブルシューティングを行うことが可能になりそうです。

おまけ

1月27日(月)に「皇居ラン」という Compass のイベントが開催されており、参加してみました。内容はITエンジニアを対象に皇居の周りを約5km走るというものでした。

実際に参加して参加者の話を聞いてみると、マラソン大会に出場経験のある方もいて驚きました。私も一般人にしてはよく走る方だと思っており、体力には少し自信があったのですが、実際に話を聞いてみると、参加者の方々のランニング距離が想像を超えていて、化け物(もちろん良い意味で)ばかりでしたね~。

また、個人的にモチベーションにつながったのが、同じ参加者の方との会話です。その方は私より少し年上くらいの方で、以前は激務で永遠にタスクが降り注ぎ、さらにドキュメント作成が多く、とてもつらかったと話していました。しかし、今は案件が変わり、AWSを使ってやりたい仕事をさせてもらえているとのことで、この話を聞いて、自分のモチベにもつながりました。

まとめ

今までは自分のローカル環境とはいえ直接Podのコンテナ内に入ってファイルの修正をすることなどがあったのですが、
実際に本番環境を扱う際は、このようなテスト方法を用いるのはもちろんよろしくないため、今後はこちらのkubectl debugコマンドを使用してテストしていこうと思います。

参加したイベント

参考リンク

0
0
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
0
0

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?