aiologfields:将任务上下文字段注入记录器

aiologfields的Python项目详细描述


https://travis-ci.org/cjrh/aiologfields.svg?branch=masterhttps://coveralls.io/repos/github/cjrh/aiologfields/badge.svg?branch=masterhttps://img.shields.io/pypi/pyversions/aiologfields.svghttps://img.shields.io/github/tag/cjrh/aiologfields.svghttps://img.shields.io/badge/install-pip%20install%20aiologfields-ff69b4.svghttps://img.shields.io/pypi/v/aiologfields.svghttps://img.shields.io/badge/calver-YYYY.MM.MINOR-22bfda.svg

aiologfields

aiologfields使包含相关ID也变得简单。 作为日志消息中的其他上下文信息,跨await 调用和loop.create_task()调用。相关ID非常重要 精确遥测在分布式监控调试中的重要作用 微服务。

说明

再简单不过了:

aiologfields.install()

在此之后,创建的每个任务都有一个logging_fields 属性。要将字段添加到LogRecord,只需将其应用于任何任务:

t=loop.create_task(coro)t.logging_fields.correlation_id='12345'

如果使用的是生成json输出的日志处理程序 (就像logjson!),或生成输出的其他格式化程序 在LogRecord中的所有字段中,您将发现 任务的上下文将包含名为^{tt8}的附加字段$ 值为12345

演示

这是根据其中一项测试改编的:

aiologfields.install()correlation_id=str(uuid4())logger=logging.getLogger('blah')asyncdefcf2():logger.info('blah blah')asyncdefcf1():ct=asyncio.Task.current_task()ct.logging_fields.correlation_id=correlation_idawaitcf2()loop.run_until_complete(cf1())

cf2()内部生成的LogRecord中,有一个附加字段 correlation_id包括在内,即使该字段是在 协程函数cf1()

如果cf2()在单独的 任务本身,因为logging_fields命名空间在 嵌套任务。

欢迎加入QQ群-->: 979659372 Python中文网_新手群

推荐PyPI第三方库


热门话题
java Cassandra复制因子大于节点数   java J2EE JTA事务回滚不适用于OSE Glassfish 4.0(Build 89)   java spring安全预认证用户登录   org的java类文件。反应流。从RxJava编译示例时未找到Publisher?   java在使用dataFormat作为POJO通过Camel调用Web服务时无法设置SOAP标头   Javafx类的java静态实例   java如何防止一个部件在关闭时覆盖另一个部件的位置   sql server无法从我的java代码连接到数据库   java在JList(Swing)中显示带有的ArrayList   从Java中的CXF服务获取WSAddressing数据   使用资产文件夹进行java简单json解析(本地)   java LDAPException未绑定的无效凭据   JavaJSFspring部署到weblogic   JAVA中字符数组中的特定元素排列?   如果脚本位于不同的目录中,则ant不会使用exec标记运行Javashell脚本