如果是自动以PatternLayout的话,我有几点疑问:
1、logback加载时机的问题,就是①先会运行logback相关类,②再执行你自定义的PatternLayout,③再去执行你的主类,在②的时候,此时还没法确定具体的启动类是啥,这种方式没法根据job动态变化

如果使用env的话
1、配置环境变量的话,如果yarn有10个节点。那么每台是不是都要配置一下
2、因为是每个job都要传递,所以,这个应该是临时的环境变量吧
3、如果是配置的临时环境变量的话,那么在执行bin/flink run的时候,shell中是执行java
-cp的,此时的主类,是org.apache.flink.client.cli.CliFrontend,这种方式,环境变量在传递的时候,会丢吧?

zilong xiao <[email protected]> 于2020年8月25日周二 下午5:32写道:

> 1:想加入跟业务相关的字段,例如jobId,jobName,可以继承PatternLayout,重写doLayout即可,在方法中对日志进行填充
> 2:这些属性有办法可以从环境变量中获取
>
> Jim Chen <[email protected]> 于2020年8月25日周二 下午4:49写道:
>
> > 大家好:
> >     我们在做flink的日志收集到kafak时,使用的logback日志配置文件,目前的pattern是%d{yyyy-MM-dd
> > HH:mm:ss.SSS} [%thread] %-5level %logger{60} -
> > %msg,有没有什么办法在里面加入每个job的id,name或者tasknamanger的主机名之类的信息啊。在做ELK的时候,方便查询。
> >     这个配置文件,是整个项目的,是基于Yarn的per job模式,难道每个主类打包的时候,都要改动不同的logbakc配置文件吗?
> >
>

回复