2

Sun 1.7 JDK で実行されている Linux 64 ビットで Websphere MQ 6 に接続しようとしています。

アプリケーション サーバーが MQ サーバーとは別であるため、LDAP 内のオブジェクトを検索する JNDI 経由で MQ サーバーに接続しようとしています。そのため、ファイル システム JNDI を使用できません。

これはすべて私の開発ボックスで正常に動作しますが、1) Windows があり、2) MQ サーバーがインストールされています。

Websphere MQ Explorer を介して LDAP に接続し、LDAP でバインディング オブジェクトを作成できます。

Java アプリケーションは JNDI オブジェクトにアクセスでき、接続を作成しようとしますが、エラー java.lang.UnsatisfiedLinkError: no mqjbnd in java.library.path が発生します

ここから7.5クライアントをインストールしました

コマンドの実行後、LD_LIBRARY_PATH はデフォルトに設定されます

. /opt/mqm/bin/setmqenv -s -l

実際のパスは

LD_LIBRARY_PATH = /usr/java/default/jre/lib/i386:/opt/mqm/lib64/compat:/opt/mqm/lib/compat

また、JVM で -Djava.library.path=$LD_LIBRARY_PATH を明示的に設定しました。

しかし、パス /opt/mqm/lib64/compat:/opt/mqm/lib/compat を見ると、mqjbnd などは見えません。

多くの投稿や技術的な議論では、クライアントのインストールには mqjbnd がなく、サーバーのインストールのみであると述べています。QueueManager をルックアップし、JNDI 経由でキュー アイテムを使用したいだけなので、混乱しています。サーバーではなくクライアントをインストールする必要がありますか?

LDAP 方式は私が使用するのに適した方式ですか? com.ibm.mq.jms.context.WMQInitialContextFactory を使用しようとしましたが、そのためのセキュリティー権を取得できませんでした。

申し訳ありませんが、これは私の頭の中でやっています - これを ActiveMQ への接続の容易さと比較せずにはいられません - 私はここで何か間違ったことをしているに違いありません.

例外は

[2013-03-13 14:32:41,389] ERROR - ServiceTaskManager Error acquiring a JMS connection to : cn=ConnectionFactoryLdap using JNDI properties : {java.naming.factory.initial=com.sun.jndi.ldap.LdapCtxFactory, java.naming.provider.url=ldap://LDAPSERVER:10389/dc=example,dc=com, transport.jms.ConnectionFactory=ibmMQQueueConnectionFactory, transport.jms.ConnectionFactoryType=queue, serviceType=proxy}
com.ibm.msg.client.jms.DetailedJMSException: JMSFMQ6312: An exception occurred in the Java(tm) MQI.
The Java(tm) MQI has thrown an exception describing the problem.
See the linked exception for further information.
        at sun.reflect.GeneratedConstructorAccessor30.newInstance(Unknown Source)
        at sun.reflect.DelegatingConstructorAccessorImpl.newInstance(DelegatingConstructorAccessorImpl.java:45)
        at java.lang.reflect.Constructor.newInstance(Constructor.java:525)
        at com.ibm.msg.client.commonservices.j2se.NLSServices.createException(NLSServices.java:319)
        at com.ibm.msg.client.commonservices.nls.NLSServices.createException(NLSServices.java:233)
        at com.ibm.msg.client.wmq.factories.WMQConnectionFactory.createV7ProviderConnection(WMQConnectionFactory.java:6863)
        at com.ibm.msg.client.wmq.factories.WMQConnectionFactory.createProviderConnection(WMQConnectionFactory.java:6254)
        at com.ibm.msg.client.jms.admin.JmsConnectionFactoryImpl.createConnection(JmsConnectionFactoryImpl.java:285)
        at com.ibm.mq.jms.MQConnectionFactory.createCommonConnection(MQConnectionFactory.java:6189)
        at com.ibm.mq.jms.MQConnectionFactory.createConnection(MQConnectionFactory.java:6218)
        at org.apache.axis2.transport.jms.JMSUtils.createConnection(JMSUtils.java:555)
        at org.apache.axis2.transport.jms.ServiceTaskManager$MessageListenerTask.createConnection(ServiceTaskManager.java:824)
        at org.apache.axis2.transport.jms.ServiceTaskManager$MessageListenerTask.getConnection(ServiceTaskManager.java:706)
        at org.apache.axis2.transport.jms.ServiceTaskManager$MessageListenerTask.receiveMessage(ServiceTaskManager.java:496)
        at org.apache.axis2.transport.jms.ServiceTaskManager$MessageListenerTask.run(ServiceTaskManager.java:420)
        at org.apache.axis2.transport.base.threads.NativeWorkerPool$1.run(NativeWorkerPool.java:172)
        at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1145)
        at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:615)
        at java.lang.Thread.run(Thread.java:722)
Caused by: com.ibm.mq.jmqi.JmqiException: CC=2;RC=2495;AMQ8568: The native JNI library 'mqjbnd' was not found. For a client installation this is expected. [3=mqjbnd]
        at com.ibm.mq.jmqi.local.LocalMQ$1.run(LocalMQ.java:304)
        at java.security.AccessController.doPrivileged(Native Method)
        at com.ibm.mq.jmqi.local.LocalMQ.initialise_inner(LocalMQ.java:268)
        at com.ibm.mq.jmqi.local.LocalMQ.initialise(LocalMQ.java:231)
        at com.ibm.mq.jmqi.local.LocalMQ.<init>(LocalMQ.java:1194)
        at com.ibm.mq.jmqi.local.LocalServer.<init>(LocalServer.java:206)
        at sun.reflect.GeneratedConstructorAccessor29.newInstance(Unknown Source)
        at sun.reflect.DelegatingConstructorAccessorImpl.newInstance(DelegatingConstructorAccessorImpl.java:45)
        at java.lang.reflect.Constructor.newInstance(Constructor.java:525)
        at com.ibm.mq.jmqi.JmqiEnvironment.getInstance(JmqiEnvironment.java:732)
        at com.ibm.mq.jmqi.JmqiEnvironment.getMQI(JmqiEnvironment.java:666)
        at com.ibm.msg.client.wmq.factories.WMQConnectionFactory.createV7ProviderConnection(WMQConnectionFactory.java:6855)
        ... 13 more
Caused by: java.lang.UnsatisfiedLinkError: no mqjbnd in java.library.path
        at java.lang.ClassLoader.loadLibrary(ClassLoader.java:1860)
        at java.lang.Runtime.loadLibrary0(Runtime.java:845)
        at java.lang.System.loadLibrary(System.java:1084)
        at com.ibm.mq.jmqi.local.LocalMQ.loadLib(LocalMQ.java:1138)
        at com.ibm.mq.jmqi.local.LocalMQ$1.run(LocalMQ.java:279)
        ... 24 more
4

3 に答える 3

0

Tomcat サーバーを開く -> lauch 構成を開く -> 引数タブの下 ->-Djava.library.path="C:\IBM\WebSphere MQ\java\lib64"

それはあなたの例外を解決します、それは基本的にランタイムライブラリを求めています

于 2014-07-22T18:56:48.030 に答える
0

問題は、システム プロパティのパス変数にあります。パス変数で MQInstallation Dir :\Lib の前に MQInstallation Dir :\Lib64 パスを指定して、コードの実行を試みます。

于 2015-06-29T11:24:52.610 に答える