遇到的问题
不多说,先直接上我完成了的XML
MySQL记得先创建activemq数据库不然也会报错,我下面有
<!-- jdbc持久化配置-->
<persistenceAdapter>
<jdbcPersistenceAdapter dataSource="#mysql-ds"/>
</persistenceAdapter>
<!-- bean一定是在</broker>标签下面的,千万别错了-->
<!-- <property name="driverClassName" value="com.mysql.jdbc.Driver"/> 8以下版本适用 -->
<bean id="mysql-ds" class="org.apache.commons.dbcp2.BasicDataSource" destroy-method="close">
<property name="driverClassName" value="com.mysql.cj.jdbc.Driver"/>
<property name="url" value="jdbc:mysql://192.168.83.130:3306/activemq?relaxAutoCommit=true&useSSL=false&serverTimezone=GMT%2B8"/>
<property name="username" value="root"/>
<property name="password" value="123456"/>
<property name="maxTotal" value="200"/>
<property name="poolPreparedStatements" value="true"/>
</bean>
坑1:无形之坑最为致命,80%的人连不上都是因为这个吧
MYSQL5: class=“org.apache.commons.dbcp
.BasicDataSource”
MYSQL8: class=“org.apache.commons.dbcp2
.BasicDataSource”
官网也是dbcp,误导了我半天
坑1:为什么又是坑1
呢?这的确很坑好吧
我在我们MySQL上没有创建activemq的数据库,然后启动报错,找不到数据库,于是我只能先手动创建数据库,不用建表
手动创建数据库
手动创建数据库
手动创建数据库
坑2:&
符号不行,XML必须使用转译字符,而且还要加上serverTimezone和useSSL
<property name="url" value="jdbc:mysql://192.168.83.130:3306/activemq?relaxAutoCommit=true&useSSL=false&serverTimezone=GMT%2B8"/>
坑3:大小写问题中间的S大写,大写,大写
dataSource–dataSource–dataSource
成功启动
这是我配置完了的日志和XML
再次强调一定要放在broker下面,import上面
其他问题
如果使用了我的配置建了数据库还连不上只能是你的问题了
是不是MySQL远程没开?
activemq的lib下不是或者没有MySQL8的驱动包?
密码没对什么的?自己再仔细看看对比对比