com.atlassian.confluence.content.render.xhtml.migration.exceptions.UnknownMacroMigrationException: The macro 'next_previous_links' is unknown.

WSO2 BAM Datasource

The WSO2BAM_DATASOURCE, which is defined in the <PRODUCT_HOME>/repository/conf/bam-datasources.xml file is used to store the results of a Hive analysis job of BAM, to a RDBMS.

To point BAM to a RDBMS, you need to edit the default datasource configuration defined as shown below in the bam-datasources.xml file.

Replace the  url,  username,  password  and  driverClassName settings with your custom values and also the other values accordingly in the  bam-datasources.xml file as shown in the below example.

<datasource>
			<name>WSO2BAM_DATASOURCE</name>
			<description>The datasource used for analyzer data</description>
			<definition type="RDBMS">
				<configuration>
					<url>jdbc:h2:repository/database/samples/BAM_STATS_DB;AUTO_SERVER=TRUE</url>
					<username>wso2carbon</username>
					<password>wso2carbon</password>
					<driverClassName>org.h2.Driver</driverClassName>
					<maxActive>50</maxActive>
					<maxWait>60000</maxWait>
					<testOnBorrow>true</testOnBorrow>
					<validationQuery>SELECT 1</validationQuery>
					<validationInterval>30000</validationInterval>
				</configuration>
			</definition>
		</datasource>

The datasource configuration options are as follows: 

  • url - The URL of the database.
  • username  - The name of the database user.

  • password - The password of the database user.
  • driverClassName  - The class name of the database driver.
  • maxActive - The maximum number of active connections that can be allocated from this pool at the same time, or enter a negative value for no limit.
  • maxWait - The maximum number of milliseconds that the pool will wait (when there are no available connections) for a connection to be returned before throwing an exception. You can enter zero or a negative value to wait indefinitely.
  • testOnBorrow -  The indication of whether objects will be validated before being borrowed from the pool. If the object fails to validate, it will be dropped from the pool, and another attempt will be made to borrow another. 
  • validationQuery - The SQL query that will be used to validate connections from this pool before returning them to the caller.
  • validationInterval -  The indication to avoid excess validation, and only run validation at the most, at this frequency (time in milliseconds). If a connection is due for validation, but has been validated previously within this interval, it will not be validated again. 

Setting up the drivers

Download the driver JAR file of the respective RDBMS type, and copy it to the <PRODUCT_HOME>/repository/components/lib/ directory. Also, include the folder path of the RDBMS driver JAR file within the Hive auxiliary JAR properties in the <PRODUCT_HOME>/repository/conf/advanced/hive-site.xml as shown below and restart the server.

<property>
    <name>hive.aux.jars.path</name>
    <value>file://${CARBON_HOME}/repository/components/plugins/apache-cassandra_1.1.3.wso2v2.jar,
           file://${CARBON_HOME}/repository/components/plugins/guava_12.0.0.wso2v1.jar,
           file://${CARBON_HOME}/repository/components/plugins/json_2.0.0.wso2v1.jar,
           file://${CARBON_HOME}/repository/components/plugins/commons-dbcp_1.4.0.wso2v1.jar,
           file://${CARBON_HOME}/repository/components/plugins/commons-pool_1.5.6.wso2v1.jar,
           file://${CARBON_HOME}/repository/components/lib/mysql-connector-java-5.1.23-bin.jar
   </value>
   </property>


com.atlassian.confluence.content.render.xhtml.migration.exceptions.UnknownMacroMigrationException: The macro 'next_previous_links2' is unknown.