3步骤教你调试运行在Kubernetes Pod中的应用程序

上文我们讲过,Kubernetes以其良好的容器管理特性和丰富的平台管理能力获得越来越多的开发者的青睐。但是对于那些运行在Kubernetes Pod中的应用程序而言,运维是方便多了,但是调试却成了大大的问题。不同于本地调试,运行在Kubernete Pod中的应用程序受限于容器封装形式、网络环境、开发语言等带给了开发者新的挑战。所谓“磨刀不误砍柴工”,对于开发者而言,寻找合适的、可用的调试方法,花再多的精力和时间都是值得的。本文我就给大家分享一种简单而实用的调试方法,希望对大家有用。(笔者的开发环境是Ubuntu 18.04)

一、安装 krew

# set -x; cd "$(mktemp -d)" &&
  curl -fsSLO "https://github.com/kubernetes-sigs/krew/releases/latest/download/krew.tar.gz" &&
  tar zxvf krew.tar.gz &&
  KREW=./krew-"$(uname | tr '[:upper:]' '[:lower:]')_amd64" &&
  "$KREW" install krew
  
# export PATH=$HOME/.krew/bin:$PATH

二、安装ksniffer插件

# kubectl krew install sniff

三、在你的ubuntu系统中安装wireshark或者tcpdump

四、测试,比如本例中我要调试其他应用对minio服务的访问的细节:

# kubectl sniff minio-7784cf8ddb-bznhk  -n minio

执行时候的log信息如下:


INFO[0000] sniffing method: upload static tcpdump       
INFO[0000] using tcpdump path at: '/root/.krew/store/sniff/v1.4.2/static-tcpdump' 
INFO[0000] no container specified, taking first container we found in pod. 
INFO[0000] selected container: 'minio'                  
INFO[0000] sniffing on pod: 'minio-7784cf8ddb-bznhk' [namespace: 'minio', container: 'minio', filter: '', interface: 'any'] 
INFO[0000] uploading static tcpdump binary from: '/root/.krew/store/sniff/v1.4.2/static-tcpdump' to: '/tmp/static-tcpdump' 
INFO[0000] uploading file: '/root/.krew/store/sniff/v1.4.2/static-tcpdump' to '/tmp/static-tcpdump' on container: 'minio' 
INFO[0000] executing command: '[/bin/sh -c ls -alt /tmp/static-tcpdump]' on container: 'minio', pod: 'minio-7784cf8ddb-bznhk', namespace: 'minio' 
INFO[0000] command: '[/bin/sh -c ls -alt /tmp/static-tcpdump]' executing successfully exitCode: '1', stdErr :'ls: /tmp/static-tcpdump: No such file or directory
' 
INFO[0000] file not found on: '/tmp/static-tcpdump', starting to upload 
INFO[0001] verifying file uploaded successfully         
INFO[0001] executing command: '[/bin/sh -c ls -alt /tmp/static-tcpdump]' on container: 'minio', pod: 'minio-7784cf8ddb-bznhk', namespace: 'minio' 
INFO[0001] command: '[/bin/sh -c ls -alt /tmp/static-tcpdump]' executing successfully exitCode: '0', stdErr :'' 
INFO[0001] file found: '-rwxr-xr-x    1 root     root       2696368 Jan  1  1970 /tmp/static-tcpdump
' 
INFO[0001] file uploaded successfully                   
INFO[0001] tcpdump uploaded successfully                
INFO[0001] spawning wireshark!                          
INFO[0001] start sniffing on remote container           
INFO[0001] executing command: '[/tmp/static-tcpdump -i any -U -w - ]' on container: 'minio', pod: 'minio-7784cf8ddb-bznhk', namespace: 'minio' 
INFO[0127] starting sniffer cleanup                     
INFO[0127] sniffer cleanup completed successfully       

之后就会自动打开wireshark:

3步骤教你调试运行在Kubernetes Pod中的应用程序

接下来就可以输入一些过滤规则来进行数据包分析了。比如我想看看velero如何和minio交互:

3步骤教你调试运行在Kubernetes Pod中的应用程序

是不是很方便呢?如果对您有帮助,点个赞吧。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值