keycloak docker compose 导入 realm

本文介绍了如何通过docker-compose将预先导出的Keycloak Realm导入到Docker环境中。首先,你需要导出realm为realms.json。然后,创建一个docker-compose.yml文件,并根据需要选择后台或前台启动Keycloak容器。你可以使用提供的命令来管理容器,如启动、停止、检查运行中的容器等。登录Keycloak管理界面的默认凭据是admin/admin。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

 

 

如果需要提前将已有keycloak的realm导出并通过docker-compose导入,用下图的方式导出,将导出的文件命名为realms.json

 

新建文件夹并创建文件: docker-compose.yml

version: "3"
services:
  keycloak:
    image: jboss/keycloak:7.0.0
    ports:
      - "8080:8080"
    volumes:
      - "./imports:/Users/lucia/workspace/docker-compose/imports/"
    environment:
      - "KEYCLOAK_USER=admin"
      - "KEYCLOAK_PASSWORD=admin"
      - "DB_VENDOR=postgres"
      - "DB_ADDR=postgres"
      - "DB_DATABASE=postgres"
      - "DB_USER=postgres"
      - "DB_PASSWORD=123456"
      - "PROXY_ADDRESS_FORWARDING=true"
    command:
      - "-b 0.0.0.0 -Dkeycloak.import=/Users/lucia/workspace/docker-compose/imports/realms.json"
    depends_on:
      - postgres
  postgres:
    image: postgres
    ports:
      - "5432:5432"
    environment:
      - "POSTGRES_PASSWORD:123456"

 

如果不需要导入realm,可以直接用下面的方式:

version: "3"
services:
  keycloak:
    image: jboss/keycloak:7.0.0
    ports:
      - "8080:8080"
    environment:
      - "KEYCLOAK_USER=admin"
      - "KEYCLOAK_PASSWORD=admin"
      - "DB_VENDOR=postgres"
      - "DB_ADDR=postgres"
      - "DB_DATABASE=postgres"
      - "DB_USER=postgres"
      - "DB_PASSWORD=123456"
      - "PROXY_ADDRESS_FORWARDING=true"
    depends_on:
      - postgres
  postgres:
    image: postgres
    ports:
      - "5432:5432"
    environment:
      - "POSTGRES_PASSWORD:123456"

后台启动: docker-compose up -d

前台启动:docker-compose up

停止:docker-compose stop

 

查看docker启动中的容器:

$ docker ps -a
CONTAINER ID        IMAGE               COMMAND                  CREATED             STATUS              PORTS                              NAMES
71ae958e3ffd        postgres            "docker-entrypoint.s…"   21 minutes ago      Up 21 minutes       0.0.0.0:5432->5432/tcp             docker-compose_postgres_1
4f63a236e573        jboss/keycloak      "/opt/jboss/tools/do…"   21 minutes ago      Up 21 minutes       0.0.0.0:8080->8080/tcp, 8443/tcp   docker-compose_auth_1

删除容器:

docker rm <容器CONTAINER id>

进入容器内部:

$ docker exec -it 71ae958e3ffd bash  (进入postgresql的容器内部)

root@71ae958e3ffd:/# psql postgres -U postgres
psql (12.0 (Debian 12.0-1.pgdg100+1))
Type "help" for help.

postgres=# \c postgres
You are now connected to database "postgres" as user "postgres".

 

 

打开网页,用户名密码就是我们在docker-compose.yml 文件里配置的 admin

KEYCLOAK_USER=admin

KEYCLOAK_PASSWORD=admin

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值