問題が発生しました:
- IBM MQ サーバー v9.1.0.0
- pymqi==1.11.1
サーバーに接続しようとするとエラーが発生しました:
pymqi.MQMIError: MQI Error. Comp: 2, Reason 2035: FAILED: MQRC_NOT_AUTHORIZED
Wireshark でトラフィックを確認すると、次のようになりました。
そして、サーバーでこれをログに記録します:
07/31/2020 10:08:02 AM - Process(27333.5) User(mqm) Program(amqrmppa)
Host(host) Installation(Installation1)
VRMF(9.1.0.0) QMgr(queue_manager)
Time(2020-07-31T07:08:02.253Z)
ArithInsert1(2) ArithInsert2(2035)
CommentInsert1(haha)
AMQ9557E: Queue Manager User ID initialization failed for 'haha'.
EXPLANATION:
The call to initialize the User ID 'haha' failed with CompCode 2 and Reason
2035. If an MQCSP block was used, the User ID in the MQCSP block was ''.
ACTION:
Correct the error and try again.
私のコードサンプル:
import pymqi
host = "host"
port = 1416
conn_info = f"{host}({port})"
channel = "channel"
queue_manager = "queue_manager"
def main():
manager = pymqi.connect(queue_manager=queue_manager, channel=channel, conn_info=conn_info)
if __name__ == '__main__':
main()
他のデバイスからコードを実行しようとしたところ、実行したアカウントが UserID として取得されました。
その後、問題の対処をサポートに依頼したところ、アカウントに接続できました(笑) が、許可されたユーザーのリストを作成するという解決策は私には合いませんでした。から送信された UserID を制御する方法はありますpymqi
か?
更新日 2020 年 4 月 8 日
サポート・チームは、ユーザーphoenix
がパスワードで IBM MQ サーバー上に作成され123456789
、MQSCP を送信しようとしたと述べました。
manager = pymqi.connect(queue_manager=queue_manager, channel=channel,
conn_info=conn_info, user="phoenix", password="123456789")
同様のエラーが発生MQRC_NOT_AUTHORIZED
し、サーバーログには、コードが起動するマシンのユーザー名(ではないphoenix
)で上記のエラーが含まれています。