博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
kubernetes log 流式数据处理
阅读量:6437 次
发布时间:2019-06-23

本文共 2119 字,大约阅读时间需要 7 分钟。

PS: 最近在重构公司的业务容器化平台,记录一块。关于容器日志的, kubernetes python API本身提供了日志流式数据,在以前的版本是不会输出新数据的,后续版本进行了改进。

直接上代码

Flask 前端路由块

# Router"""获取项目pod的日志"""@api_cluster_pod.route('/
/
/pod/
/log')@env_rulesdef api_cluster_pod_log(env, cluster_name, pod_name): """查看pod的log""" tail_lines = request.values.get("tail_lines", 1000) namespace = request.values.get("namespace", "") # 生成Config Object try: cluster_config = ClusterConfig( env=env, cluster_name=cluster_name, namespace=namespace ) except Exception as e: return jsonify(dict( code=5000, message='获取集群接口时未找到对应条目, 信息:{0}'.format(str(e)) )) try: poder = Pod( cluster_config) resp = Response(stream_with_context(poder.get_pod_log(pod_name, tail_lines)), mimetype="text/plain") return resp except Exception as e: return jsonify(dict( code=7000, message=str(e) ))

Flask 后端代码块

# 后台功能class Pod:    ...       def get_pod_log(self, pod_name, tail_lines=100):        """        获取pod的日志        :param tail_lines: # 显示最后多少行        :return:        """        try:            # stream pod log            streams = self.cluster.api.read_namespaced_pod_log(                pod_name,                self.cluster_config.namespace,                follow=True,                _preload_content=False,                tail_lines=tail_lines).stream()            return streams        except ApiException as e:            if e.status == 404:                logger.exception("Get Log not fund Podname: {0}".format(pod_name))                raise PodNotFund("获取日志时,未找到此pod: {0}".format(pod_name))            if e.status == 400:                raise PodNotFund("容器并未创建成功,请联系运维人员进行排查。")            raise e        except Exception as e:            logger.exception("Get Log Fail: {0}".format(str(e)))            raise e

HTML

    Flushed ajax test    
    

其它

我们应用是前后端分离的,把html里面的核心代码放置VUE里面就可以了。

效果图

日志是流式的,如果Container有日志,则窗口会运态更新。

kubernetes log 流式数据处理

转载于:https://blog.51cto.com/cwtea/2329270

你可能感兴趣的文章
python
查看>>
ubuntu 常用生产环境部署配置测试调优
查看>>
【JS】//将中文逗号转换为英文逗号
查看>>
在VS2012中实现Ext JS的智能提示太简单了
查看>>
Extnet Direct 提交后台事件文件下载设置
查看>>
邻接矩阵与二叉排序树
查看>>
CSS选择器
查看>>
购物车练习
查看>>
js实现在表格中删除和添加一行
查看>>
SOCKET简单爬虫实现代码和使用方法
查看>>
跨域解决方案汇总
查看>>
In App Purchase
查看>>
js判断对象的类型的四种方式
查看>>
RPC框架的可靠性设计
查看>>
使用自选择创建团队
查看>>
基准测试(Benchmarks)不必消亡
查看>>
ceph 常用命令记录(完善中...)
查看>>
C# 7.3新特性一览
查看>>
用Chrome开发者工具调试一切
查看>>
简易mvvm库的设计实现
查看>>