Keycloak使用mysql数据库

Keycloak使用mysql数据库

  • 下载Mysql驱动
  • 添加module.xml配置文件
  • 修改standalone.xml配置文件
  • 启动Keycloak

keycloak standalone启动后,默认使用的是内部自带的h2数据库,我们暂使用时通常需要修改为本地mysql存储,下面简单介绍如何让keycloak使用外部mysql数据库。

下载Mysql驱动

下载地址:mysql-connector-java-8.0.13.jar

添加module.xml配置文件

  1. 在keycloak根目录下创建目录keycloak/modules/system/layers/base/com/mysql/main/
  2. 将驱动文件copy到此目录下
  3. 新建文件:module.xml,内容如下:

<module name="com.mysql" xmlns="urn:jboss:module:1.5">
    <resources>
        <resource-root path="mysql-connector-java-8.0.13.jar"/>
    resources>
    <dependencies>
        <module name="javax.api"/>
        <module name="javax.transaction.api"/>
        <module name="javax.servlet.api" optional="true"/>
    dependencies>
module>

修改standalone.xml配置文件

找到原文的h2数据库配置

<datasource jndi-name="java:jboss/datasources/KeycloakDS" pool-name="KeycloakDS" enabled="true" use-java-context="true" statistics-enabled="${wildfly.datasources.statistics-enabled:${wildfly.statistics-enabled:false}}">
    <connection-url>jdbc:h2:${jboss.server.data.dir}/keycloak;AUTO_SERVER=TRUEconnection-url>
    <driver>h2driver>
    <security>
        <user-name>sauser-name>
        <password>sapassword>
    security>
datasource>
<drivers>
    <driver name="h2" module="com.h2database.h2">
        <xa-datasource-class>org.h2.jdbcx.JdbcDataSourcexa-datasource-class>
    driver>
drivers>

注释掉,修改为

<datasource jndi-name="java:jboss/datasources/KeycloakDS" pool-name="KeycloakDS" enabled="true" use-java-context="true">
	<connection-url>jdbc:mysql://localhost:3306/keycloak?useSSL=false&serverTimezone=GMT%2B8&characterEncoding=UTF-8connection-url> 
	<driver>mysqldriver>
	<security>
		<user-name>rootuser-name>
		<password>rootpassword>
	security>
datasource>
<drivers>
    <driver name="h2" module="com.h2database.h2">
    	<xa-datasource-class>org.h2.jdbcx.JdbcDataSourcexa-datasource-class>
    driver>
	<driver name="mysql" module="com.mysql">
		<xa-datasource-class>com.mysql.cj.jdbc.MysqlXADataSourcexa-datasource-class>
	driver>
drivers>

注意,不要注释掉上方的ExampleDS配置项,程序启动会报错。

启动Keycloak

在keycloak/bin目录下找到standalone.bat文件,双击运行
进入mysql查看,新增了93个表,修改成功
Keycloak使用mysql数据库_第1张图片

你可能感兴趣的:(环境安装)