To ensure that the IBM® MQ resource adapter is automatically updated to the latest available maintenance level when you apply WebSphere® Application Server fix packs, you can configure all servers in your environment to use the latest version of the resource adapter contained in the WebSphere Application Server fix pack that you have applied to the installation of each node.
Before you begin
Important:
- WebSphere Application Server traditional does not currently support Jakarta EE. See IBM MQ resource adapter statement of
support.
- If you are using WebSphere Application Server 8.5 or earlier on any
platform, do not install the IBM MQ 8.0 or later resource
adapter into the application server. The IBM MQ 8.0 or
later resource adapter can only be deployed into an application server that supports JMS 2.0. However, WebSphere Application Server 8.5 or earlier only supports JMS 1.1.
About this task
Use this task if any of the following circumstances apply to your configuration, and you want to configure all servers in your environment to use the latest version of the
IBM MQ resource adapter:
The profile_root
directory that the examples refer to is the home directory for the WebSphere Application Server profile, for example C:\Program Files\IBM\WebSphere\AppServer1.
When you have performed the following steps for all cells and single server installations in your environment, your servers automatically receive maintenance to the IBM MQ resource adapter when a new WebSphere Application Server fix pack is applied.
Procedure
-
Start the application server. If the profile is part of a network deployment configuration, start the deployment manager and all node agents. If the profile contains an administrative agent, start the administrative agent.
-
Check the maintenance level of the IBM MQ resource adapter.
-
Open a command prompt window and change to the
profile_root\bin
directory.
For example, enter cd C:\Program Files\IBM\WebSphere\AppServer1\bin.
-
Start the wsadmin tool by entering wsadmin.bat -lang jython, then if prompted to do so, enter your username and password.
-
Type the following command, then press Return twice:
wmqInfoMBeansUnsplit = AdminControl.queryNames("WebSphere:type=WMQInfo,*")
wmqInfoMBeansSplit = AdminUtilities.convertToList(wmqInfoMBeansUnsplit)
for wmqInfoMBean in wmqInfoMBeansSplit: print wmqInfoMBean; print AdminControl.invoke(wmqInfoMBean, 'getInfo', '')
You can also run this command in Jacl. For further information about how to do this, see Ensuring that servers use the latest available IBM MQ resource adapter maintenance level in the WebSphere Application Server product documentation.
-
Find the WMSG1703I message in the displayed output from the command and check the resource adapter level.
For example, for
WebSphere Application Server 7.0.1 Fix Pack 5, the message should be:
WMSG1703I: RAR implementation Version 7.0.1.3-k701-103-100812
This message shows that the version is 7.0.1.3-k701-103-100812, which is
the correct resource adapter level for this fix pack. However, if the
following message is displayed instead, this means that you need to
adjust the resource adapter to the correct level of maintenance for
WebSphere Application Server 7.0.1 Fix Pack 5.
WMSG1703I: RAR implementation Version 7.0.0.0-k700-L080820
-
Copy the following Jython script into a file called
convertWMQRA.py
, then save it into the profile root directory, for example C:\Program Files\IBM\WebSphere\AppServer1\bin.
ras = AdminUtilities.convertToList(AdminConfig.list('J2CResourceAdapter'))
for ra in ras :
desc = AdminConfig.showAttribute(ra, "description")
if (desc == "WAS 7.0 Built In MQ Resource Adapter") or (desc == "WAS 7.0.0.1 Built In MQ Resource Adapter"):
print "Updating archivePath and classpath of " + ra
AdminConfig.modify(ra, [['archivePath', "${WAS_INSTALL_ROOT}/installedConnectors/wmq.jmsra.rar"]])
AdminConfig.unsetAttributes(ra, ['classpath'])
AdminConfig.modify(ra, [['classpath', "${WAS_INSTALL_ROOT}/installedConnectors/wmq.jmsra.rar"]])
AdminConfig.save()
#end if
#end for
Tip: When saving the file, make sure that it is saved as a python file rather than a text file.
-
Use the WebSphere Application Server wsadmin tool to run the Jython script that you have just created.
Open a command prompt and navigate to the
\bin directory in the home directory for the
WebSphere Application Server, for example
C:\Program Files\IBM\WebSphere\AppServer1\bin directory, then type the following command and press Return:
wsadmin -lang jython -f convertWMQRA.py
If
prompted to do so, enter your username and password.
Note: If you run the script against a profile that is part of a network deployment configuration, the script updates all profiles that need updating in that configuration. A full resynchronization might be necessary if you have pre-existing configuration file inconsistencies.
-
If you are running in a network deployment configuration, ensure that the node agents are fully re-synchronized. For more information, see Synchronizing nodes using the wsadmin scripting tool or Adding, managing, and removing nodes.
-
Stop all servers in the profile. If the profile is part of a network deployment configuration, also stop any cluster members in the configuration, stop all node agents in the configuration, and stop the deployment manager. If the profile contains an administrative agent, stop the administrative agent.
-
Run the osgiCfgInit command from the
profile_root/bin
directory.
The osgiCfgInit
command resets the class cache used by the OSGi runtime environment. If the profile is part of a network deployment configuration, run the osgiCfgInit command from the profile_root/bin directory of every profile that is part of the configuration.
-
Restart all servers in the profile. If the profile is part of a network deployment configuration, also restart any cluster members in the configuration, restart all node agents in the configuration, and restart the deployment manager. If the profile contains an administrative agent, restart the administrative agent.
-
Repeat step 2 to check that the resource adapter is now at the correct level.
What to do next
If you continue to experience problems after performing the steps described in this topic, and you have previously used the Update resource adapter button on the JMS Provider Settings panel in the WebSphere Application Server administrative console to update the IBM MQ resource adapter on any nodes in your environment, it is possible that you are experiencing the issue described in APAR PM10308.