Keycloak数据库初始化失败
-
原因
docker-compse.yml以及docker-compose-initial.yml定义的keycloak服务配置的是mariadb数据库或者MySQL数据库时,容易在keycloak初始化数据库表格时出现超时。
如果keycloak单独部署时,可以改为手动模式初始化来解决,具体参考:
https://blog.csdn.net/qq_30038111/article/details/83659254
在standalone.xml文件中,修改migrationStrategy属性的value值为manual,后续再手动创建keycloak需要的九十多个表格。
但是Cello以docker-compose脚本启动时,如何修改keycloak为手动模式初始化并不清楚,而且由于后续启动服务会使用keycloak提供的服务,手动初始化会导致启动失败;
此时可以将初始配置的mysql数据库改为postgres数据库,如下是原始配置的mysql数据库:
mysql:
image: mariadb:10.3.10
container_name: cello-keycloak-mysql
environment:
- MYSQL_DATABASE=keycloak
- MYSQL_USER=$KEYCLOAK_DB_USERNAME
- MYSQL_PASSWORD=$KEYCLOAK_DB_PASSWORD
- MYSQL_ROOT_PASSWORD=$KEYCLOAK_MYSQL_ROOT_PASSWORD
volumes:
- /opt/cello/keycloak-mysql:/var/lib/mysql
- 解决办法
将keycloak的支撑数据库修改为postgres数据库:
postgres:
image: postgres:9.6
container_name: cello-keycloak-postgres
ports:
- "5432:5432"
environment:
- POSTGRES_DB=keycloak
- POSTGRES_USER=$KEYCLOAK_DB_USERNAME
- POSTGRES_PASSWORD=$KEYCLOAK_DB_PASSWORD
volumes:
- /opt/cello/keycloak-postgres/data:/var/lib/postgresql/data
同时注意调整keycloak容器的定义,如下片段:
environment:
- DB_ADDR=postgres
links:
- postgres