linux stdout日志,K8S 日志为什么以 stdout 和 stderr 的方式输出?
1. 什么是 stdout 和 stderr ?在linux系统中,当我们创建一个进程,默认会创建3个文件:进程的文件描述符列表文件描述符作用例子(c语言)0(stdin)标准输入fscanf...
1. 什么是 stdout 和 stderr ?
在linux系统中,当我们创建一个进程,默认会创建3个文件:
进程的文件描述符列表
文件描述符 作用 例子(c语言)
0 (stdin) 标准输入 fscanf(stdin,"%s",str);
1 (stdout) 标准输出 fprintf(stdout,"%s\n","hello");
2 (stderror) 标准错误输出 fprintf(stderr,"%s\n","error");
为什么 stderr的打印会在 stdout的前面?
因为stdout有buffer,当遇到\n时,(若将上面的代码改为"hi, \n")才会输出。 而stderr是没有缓存,会直接输出!
2. 为什么日志要直接输出到容器的 stdout 和 stderr里?
其实容器就是一个特殊的进程, 通过Cgroup, Namespace来进行资源的隔离和限制。
来自容器日志收集与管理的官网图片
1. 简单方便,可以直接使用语言自带的标准库,打印出信息(比如c语言的printf, fprintf函数)作为日志的输入源,不用额外的再建立一个文件。
2. 易管理,可以将容器的标准输出stdout, stderr重定向到log-file.log。 比如将上面的test.c文件编译后,执行 ./a.out >> a.log 2>&1,就会将标准输出存放到a.log里
./a.out >> a.log 2>&1
2>$1 将stderr(2) 重定向到 stdout(1), 这样就能把这两种输出都记录到a.log日志
若只执行 ./a.out >> a.log 日志a.log中只会保存stdout输出的信息
更多推荐
所有评论(0)