背景

我们经常需要在kubernetes中运行一些任务性质的Job或者Pod。在调试过程中,我们对日志有如下两个需求

  • 需求一:日志输出到stdout。因为stdout的输出,可以非常方便的通过kubectl logs进行查看,结合图形化的界面,很容易看到Pod最后的堆栈或输出,不用kubectl exec -it进入Pod查看log。比如
  • 需求二:日志持久化到文件(如 /tmp/t)。持久化的日志文件,为了便于做日志管理和日志追踪。

实现

写一个非常简单的例子,第一步先把日志输出到stdout,实现需求一

---
apiVersion: v1
kind: Pod
metadata:name: usecase-loggingnamespace: default
spec:restartPolicy: Nevercontainers:- name: usecase-loggingsecurityContext:privileged: falseimage: ccr.ccs.tencentyun.com/prometheus/busybox:latestargs: [/bin/sh, -c,'i=0; while true; do echo "$i: $(date)"; i=$((i+1)); sleep 1; done ']imagePullSecrets:- name: qcloudregistrykeysecurityContext:runAsUser: 0

为了实现需求二,可以重定向stdout到文件。但是,这样会丢失到stdout的输出。

    args: [/bin/sh, -c,'i=0; while true; do echo "$i: $(date)"; i=$((i+1)); sleep 1; done > /tmp/t']

好在可以用tee命令,stdout + 持久化两不误。这样就可以了么?

    args: [/bin/sh, -c,'i=0; while true; do echo "$i: $(date)"; i=$((i+1)); sleep 1; done | tee /tmp/t']

实际使用中,tee命令前面运行的是业务逻辑,我们需要知道业务逻辑是否正确运行。下面的例子中,我故意“业务逻辑”的shell语法写错了,但是Pod仍然会正常返回(exit 0),这是因为后面的tee命令是exit 0的。

args: [/bin/sh, -c,'i=0; while shangoucun true; do echo "$i: $(date)"; i=$((i+1)); sleep 1; done | tee /tmp/t']

可以使用”exit ${PIPESTATUS[0]}“,返回指定管道的返回值,可以看到这个Pod的返回结果应该是Error的。这样就完美了吗?

    args: [/bin/sh, -c,'i=0; while shangoucun true; do echo "$i: $(date)"; i=$((i+1)); sleep 1; done | tee /tmp/t; exit ${PIPESTATUS[0]}']

很不幸,在项目中我们还真的遇到了问题,因为项目的YAML是动态用正则表达式生成的,“exit ${PIPESTATUS[0]}”这个命令中的花括号等字符和正则表达式冲突了。我们知道修改正则表达式可以解决问题,但是由于不可描述的原因,还是使用了下面这种方法去解决上面的问题。即一个container用来写日志到文件,另一个container用tail来输出到stdout。全部YAML如下

---
apiVersion: v1
kind: Pod
metadata:name: usecase-loggingnamespace: default
spec:restartPolicy: Nevercontainers:- name: usecase-loggingsecurityContext:privileged: falseimage: ccr.ccs.tencentyun.com/prometheus/busybox:latestargs: [/bin/sh, -c,'i=0; while true; do echo "$i: $(date)"; i=$((i+1)); sleep 1; done > /tmp/t']volumeMounts:- name: logmountPath: /tmp- name: persitent-logimage: ccr.ccs.tencentyun.com/prometheus/busybox:latestargs: [/bin/sh, -c, 'tail -f /tmp/t']volumeMounts:- name: logmountPath: /tmpimagePullSecrets:- name: qcloudregistrykeyvolumes:- name: logemptyDir: {}securityContext:runAsUser: 0

这样就真的没问题了吗?

原创不易,请保护版权。如需转载,请联系获得授权,并注明出处。

日志的log中如何输出变量_如何在kubernetes中优雅的输出日志相关推荐

  1. linux中设置环境变量_如何在Linux中设置环境变量

    linux中设置环境变量 Wondering how to set environment variables in Linux? This is exactly what we'll be doin ...

  2. web服务器中启用作业储存_如何在Kubernetes中启用无服务器计算

    web服务器中启用作业储存 在本系列的前两篇文章中,介绍了在开放源代码平台上使用无服务器平台的过程,我介绍了如何开始使用无服务器平台,以及如何使用流行的语言编写函数以及如何在Apache OpenWh ...

  3. java中的最终变量_在lambda表达式中使用的变量应该是最终变量或有效的最终变量。...

    A final变量意味着它只能被实例化一次.在Java中,您不能在lambda和匿名内部类中使用非最终变量. 您可以使用旧的for-each循环重构代码:private TimeZone extrac ...

  4. activiti 变量_如何在Activiti中使用瞬态变量

    activiti 变量 我们昨天发布的Activiti v6 Beta3中已经加入了很多需要的功能-临时变量. 在这篇文章中,我将向您展示一个示例,说明如何使用瞬态变量来覆盖一些以前不可能(或最佳)的 ...

  5. python中如何不换行_如何在Python中不换行输出

    如何在Python中不换行输出 发布时间:2020-09-22 15:04:14 来源:亿速云 阅读:161 作者:小新 小编给大家分享一下如何在Python中不换行输出,希望大家阅读完这篇文章后大所 ...

  6. python如何定义一个空变量_如何在python中定义自由变量? - python

    python doc中的本地/全局/自由变量定义: 如果名称绑定在块中,则除非声明为非本地,否则它是该块的局部变量.如果在模块级别绑定了名称,则该名称为全局变量. (模块代码块的变量是局部变量和全局变 ...

  7. shell中竖线的作用_如何在 Linux 中安装、配置和使用 Fish Shell?

    每个 Linux 管理员都可能听到过 shell 这个词.你知道什么是 shell 吗? 你知道 shell 在 Linux 中的作用是什么吗? Linux 中有多少个 shell 可用? -- Ma ...

  8. linux中更改用户密码_如何在Linux中更改用户密码

    linux中更改用户密码 In this tutorial, we will focus on how you can change a user's password in Linux. We wi ...

  9. html中看到php代码_如何在HTML中嵌入PHP代码

    如何在HTML中嵌入PHP代码 对于一个有经验的 PHP Web 开发者,在HTML中嵌入PHP代码是一件非常容易的事情.但是对于刚开始接触 PHP 编程语言的新手这就是一个问题.下面是小编为大家带来 ...

最新文章

  1. 20. Valid Parentheses
  2. 提的最多的数据库“索引”,先来简单了解一下
  3. 作家笔下的数学与数学家
  4. hive序列生成_常见的序列化框架及Protobuf原理
  5. MS Server中varchar与nvarchar的区别
  6. 崩溃!还未修复的 Bug,凌晨三点遭到黑客 DDoS 攻击 | 技术头条
  7. Swift - whose view is not in the window hierarchy 问题解决方法
  8. web开发中多线程下载文件
  9. 开放式虚拟仿真实验服务器,润尼尔开放式虚拟仿真实验教学及资源共享平台
  10. python优化网站_利用python做seo优化
  11. python中怎么查看二进制转换的数据_python二进制数据
  12. 广发信用卡联名南航,申卡这样操作
  13. 学习日志-勉励自己-自律
  14. BNUZ自动打卡系统
  15. 【Scratch二次开发】03-构建桌面应用
  16. 数字翻译成英文的小游戏
  17. 阿里云服务器学生有什么优惠?阿里云学生机申请流程
  18. django orm性能优化
  19. 一篇文章带你搞定数学建模中的灰色预测模型(05年长江水质问题示例讲解含代码)
  20. 如何在Windows7下配置ASP服务器IIS

热门文章

  1. 源代码 oa办公系统jsp_【程序源代码】经典的办公系统开发框架
  2. 现代ups电源及电路图集_2020山特UPS电源自动开机200KVA实力
  3. Python: 除matplotlib外还有哪些数据可视化库?
  4. error C2011: “Font”:“struct”类型重定义
  5. 设置Qt直接运行路径
  6. 计算机科学与技术学了会秃头吗,计算机科学与技术vs 信息与计算科学,秃头专业了解一下?...
  7. HTTPS那些事(三)攻击实例与防御(转载)
  8. php json 格式化
  9. linux 混杂设备 miscdevice设备介绍
  10. 导入android工程@Override报错