我想编写一个脚本文件,将队列管理器中到达的 MQ 消息附加到日志文件中。请帮助
1 回答
如果您希望所有消息都到达一个通道,您可以使用 mrmq.dk 的 BlockIP2 页面中的LogIP 出口。诸如SupportPac MA0W 之类的 API 出口可以记录所有放置的消息。API 出口可以捕获来自本地应用程序的消息以及通过通道到达的消息。
如果您想编写脚本,您可以使用诸如 Q(来自SupportPac MA01)之类的程序在消息到达时从队列中删除它们并将它们附加到文件中。
例如,
#!/usr/bin/ksh
q -IMYQMGR/MY.QUEUE >> logfile.txt
通常,脚本会被触发并配置为将新消息附加到文件中。这样做的问题是它破坏性地删除了消息。如果有一个记录应用程序需要使用这些消息,那不是一个很好的解决方案。您可以浏览队列,但不能保证在记录应用程序获取消息之前获取消息 - 并且浏览会定期在队列头部重新启动,因此您可能会记录相同的消息两次。
另一个脚本选项是Perl MQSeries模块。该模块公开了 WMQ API 的所有选项以及面向对象的方法。如果您需要一些快速而肮脏的东西,Q 程序作为可执行文件提供。如果您想要将所有 API 暴露给您的脚本(并且不介意编译它)的强大功能,Perl MQSeries 模块是一个不错的选择。下面是取自模块示例的代码片段,展示了如何获取消息:
while (1) {
$sync_flag = 0;
undef $outcome;
my $request_msg = MQSeries::Message::->new();
my $status = $request_queue->
Get('Message' => $request_msg,
'GetMsgOpts' =>
{
'WaitInterval' => 5000, # 5 seconds
'Options' => (MQSeries::MQGMO_WAIT |
MQSeries::MQGMO_SYNCPOINT_IF_PERSISTENT |
MQSeries::MQGMO_CONVERT |
MQSeries::MQGMO_FAIL_IF_QUIESCING),
},
);
unless ($status) { # Error
my $rc = $request_queue->Reason();
die "Error on 'Get' from queue $qmgr_name/$request_qname:\n" .
"\tReason: $rc (" . MQReasonToText($rc). ")\n";
}
next if ($status < 0); # No message available
人们过去做过的一件事是将队列转换为主题的别名。使用消息的应用程序从新队列重定向到 GET,并且管理订阅将主题连接到新队列。此时,真正的应用程序会获取所有消息,并且可以进行新订阅以记录通过主题的消息。