如何从 Apache Apex 应用程序内部获取 ApplicationID?
Posted
技术标签:
【中文标题】如何从 Apache Apex 应用程序内部获取 ApplicationID?【英文标题】:How to get ApplicationID from inside Apache Apex application? 【发布时间】:2016-05-21 03:17:17 【问题描述】:是否可以在 Apex 程序中检索 Apex 应用程序 ID:例如 application_1463594017097_0024?例如来自 DAG 对象或其他对象?
【问题讨论】:
【参考方案1】:使用传递给StreamingApplication的conf对象
String appid = dag.getValue(DAGContext.APPLICATION_ID);
在运算符中,使用
字符串 appid = Context.OperatorContext.getValue(Context.DAGContext. APPLICATION_ID);
注意: 它不能在 populateDAG 函数中运行。 APPLICATION_ID 在应用程序启动后分配给它。在 populateDag() 阶段,正在创建逻辑计划,但未创建实际的 YARN 应用程序。尚未创建 APPLICATION_ID,这就是它为空的原因。
【讨论】:
以上是关于如何从 Apache Apex 应用程序内部获取 ApplicationID?的主要内容,如果未能解决你的问题,请参考以下文章
如何在 DAG 中使用 Apache Apex Malhar RabbitMQ 运算符
如何使用 Apache Apex 对 Kafka 0.9 运算符进行单元测试?