Active默认消息持久化为KahaDB(5.4以后至5.12)5.3之前的版本使用AMQ
KahaDB为默认配置。在 {activeMQ}/data/kahadb/ 目录下有5个类型的文件
1. log文件,记录消息内容,是可拆分的
2.data文件是对log的B树索引
3.free文件是记录空闲的位置(这里消费掉的消息要么删了,要么归档了。为了不产生碎片,充分利用空间,这里记录哪些位置空闲)
4.redo是为了在挂了或者重启之后恢复B树索引
5.lock文件是锁文件
ActiveMQ也支持JDBC持久化到Mysql数据库
1.在 {activeMQ}/lib 路径下放入mysql驱动包 官方下载地址(需要ORACLE账号)
2.修改 {activeMQ}/conf 路径下的active.xml配置文件
之前指定kahaDB的位置变成这样(这里指定在连接数据库时自动创建所需要的表)
<persistenceAdapter>
<jdbcPersistenceAdapter dataSource="#mysqlDB" createTablesOnStartup="true" />
</persistenceAdapter>
在下面的<beans>标签中 import 标签之前加如下配置
<bean id="mysqlDB" class="org.apache.commons.dbcp2.BasicDataSource" destroy-method="close" >
<property name="driverClassName" value="com.mysql.cj.jdbc.Driver" />
<property name="url" value="jdbc:mysql://127.0.0.1:3306/activemq?relaxAutoCommit=true&useSSL=false" />
<property name="username" value="root" />
<property name="password" value="root" />
<property name="poolPreparedStatements" value="true"/>
</bean>
保存重启即可