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