Red Hat AMQ 6
As of February 2025, Red Hat is no longer supporting Red Hat AMQ 6. If you are using AMQ 6, please upgrade: Migrating to AMQ 7.Dieser Inhalt ist in der von Ihnen ausgewählten Sprache nicht verfügbar.
6.6. Tutorial: Configuring ActiveMQ JDBC Persistence on Fabric Container with PostgreSQL
Overview
Prerequisites
- You have already installed a PostgreSQL database server.
- The PostgreSQL database server is already running.
- You have root access to the PostgreSQL database server (that is, you have access to the root user account in PostgreSQL, which you can use to administer the database).
- You have access to the internet so that you can install the PostgreSQL JDBC driver bundle and the Apache Commons data source bundle, both of which must be downloaded from the Maven Central repository.
Steps to configure JDBC persistence with PostgreSQL
Procedure 6.1. Configure PostgreSQL database
- Log into the PostgreSQL database. Enter the following command to log on as the root user:su - postgres psql su - postgres psqlCopy to Clipboard Copied! Toggle word wrap Toggle overflow 
- Add the new user accountamqto PostgreSQL with passwordamqPass, by entering the following command:postgres=# create ROLE amq LOGIN PASSWORD 'amqPass' SUPERUSER; CREATE ROLE postgres=# create ROLE amq LOGIN PASSWORD 'amqPass' SUPERUSER; CREATE ROLECopy to Clipboard Copied! Toggle word wrap Toggle overflow 
- Create theactivemqdatabase instance, by entering the following command:postgres=# CREATE DATABASE activemq WITH OWNER = amq; CREATE DATABASE postgres=# CREATE DATABASE activemq WITH OWNER = amq; CREATE DATABASECopy to Clipboard Copied! Toggle word wrap Toggle overflow 
- Grant privileges to theamquser, enabling it to access the activemq database instance (which has yet to be created). Enter the followingGRANTcommand at the postgresql shell prompt:postgres=# GRANT CONNECT ON DATABASE activemq TO amq; GRANT postgres=# GRANT CONNECT ON DATABASE activemq TO amq; GRANTCopy to Clipboard Copied! Toggle word wrap Toggle overflow There is no need to create any database tables at this point. The broker's JDBC persistence will automatically create the necessary tables when it starts up for the first time.
- Stop and restart the PostgreSQL server.Copy to Clipboard Copied! Toggle word wrap Toggle overflow 
Procedure 6.2. Create A-MQ Broker Group
- In JBoss A-MQ, start the local container as follows:cd InstallDir/bin ./amq cd InstallDir/bin ./amqCopy to Clipboard Copied! Toggle word wrap Toggle overflow 
- Create a broker group in a fabric container as follows:JBossA-MQ:karaf@root> fabric:create --clean --wait-for-provisioning JBossA-MQ:karaf@root> fabric:mq-create --kind MasterSlave --group BrokerGroup AMQBroker JBossA-MQ:karaf@root> fabric:create --clean --wait-for-provisioning JBossA-MQ:karaf@root> fabric:mq-create --kind MasterSlave --group BrokerGroup AMQBrokerCopy to Clipboard Copied! Toggle word wrap Toggle overflow 
- Install thePostgreSQL JDBCdriver into the container, as follows:JBossA-MQ:karaf@root> profile-edit --bundle wrap:file:///$DRIVER_PATH/postgresql-9.4-1206-jdbc4.jar mq-broker-BrokerGroup.AMQBroker JBossA-MQ:karaf@root> profile-edit --bundle wrap:file:///$DRIVER_PATH/postgresql-9.4-1206-jdbc4.jar mq-broker-BrokerGroup.AMQBrokerCopy to Clipboard Copied! Toggle word wrap Toggle overflow 
- Install theApache Commonsdata source bundle andosgi.compendiumbundle as follows:JBossA-MQ:karaf@root> profile-edit --bundle mvn:org.apache.servicemix.bundles/org.apache.servicemix.bundles.commons-dbcp/1.4_3 mq-broker-BrokerGroup.AMQBroker JBossA-MQ:karaf@root> profile-edit --bundle mvn:org.osgi/org.osgi.compendium/4.3.1 mq-broker-BrokerGroup.AMQBroker JBossA-MQ:karaf@root> profile-edit --bundle mvn:org.apache.servicemix.bundles/org.apache.servicemix.bundles.commons-dbcp/1.4_3 mq-broker-BrokerGroup.AMQBroker JBossA-MQ:karaf@root> profile-edit --bundle mvn:org.osgi/org.osgi.compendium/4.3.1 mq-broker-BrokerGroup.AMQBrokerCopy to Clipboard Copied! Toggle word wrap Toggle overflow 
- Create a child container:JBossA-MQ:karaf@root> fabric:container-create-child --profile mq-broker-BrokerGroup.AMQBroker root broker-container1 JBossA-MQ:karaf@root> fabric:container-create-child --profile mq-broker-BrokerGroup.AMQBroker root broker-container1Copy to Clipboard Copied! Toggle word wrap Toggle overflow 
- Enter following command to view the newly created container.JBossA-MQ:karaf@root> container-list JBossA-MQ:karaf@root> container-listCopy to Clipboard Copied! Toggle word wrap Toggle overflow 
- Stop the JBoss A-MQ container by entering following command at the console:JBossA-MQ:karaf@root> container-stop broker-container1 JBossA-MQ:karaf@root> container-stop broker-container1Copy to Clipboard Copied! Toggle word wrap Toggle overflow 
Procedure 6.3. Create a custom JDBC broker configuration
mq-create command, it creates a fabric profile which can be assigned to a container to instantiate an A-MQ message broker in that container. However, that profile does not have its own broker configuration file (for example, activemq.xml/broker.xml), but inherits it from the parent profile. Since this is the default configuration file, it assumes KahaDB persistence and also defaults to other settings. Hence it is necessary to create and configure a customized broker, without affecting the fabric defaults. For this, you need to add a customized configuration XML file to this profile and instruct fabric to use it. You can achieve this using Hawtio Web console.
				- Log in to Hawtio console and navigate to the mq-base profile in the console. Open thebroker.xmland copy its contents to a text editor.
- Navigate to newly created profilemq-broker-BrokerGroup.AMQBrokerand click the+ Createbutton in the top right hand corner.
- Select XML document option. Enter the name of the file asjdbc-broker.xmland click Create. An empty xml document opens. Paste the content copied in the step 1. An example code is given below.Copy to Clipboard Copied! Toggle word wrap Toggle overflow 
- Edit the broker/persistenceAdapter element in thejdbc-broker.xmlas follows:Copy to Clipboard Copied! Toggle word wrap Toggle overflow 
- Add a new bean element for the PostgreSQL data source as follows:Copy to Clipboard Copied! Toggle word wrap Toggle overflow 
- Click Save to save the newly createdjdbc-broker.xmldocument.
- Navigate tomq-broker-BrokerGroup.AMQBrokerbroker profile. Edit the configuration properties fileio.fabric8.mq.fabric.server-broker.propertiesto assign newly createdjdbc-broker.xmlfile as shown below.config = profile:jdbc-broker.xml config = profile:jdbc-broker.xmlCopy to Clipboard Copied! Toggle word wrap Toggle overflow 
- Click Save.
Procedure 6.4. Verify Broker configuration and creation of data tables
- Restart the JBoss A-MQ container, as follows:container-start broker-container1 container-start broker-container1Copy to Clipboard Copied! Toggle word wrap Toggle overflow 
- To verify that the requisite tables have been created in the activemq database instance, enter the following commands at the postgres client shell:Copy to Clipboard Copied! Toggle word wrap Toggle overflow