0

問題が発生しました:

  • 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)で上記のエラーが含まれています。

4

0 に答える 0