安装keycloak

虚拟机安装keycloak

  • 下载keycloak,keycloak-8.0.1.zip:https://www.keycloak.org/downloads.html

  • 解压: unzip keycloak-8.0.1.zip

  • 修改配置文件: vim keycloak-8.0.1/standalone/configuration/standalone.xml
    在这里插入图片描述

  • 配置postgres的module,并引入postgre的驱动包
    mkdir -p keycloak-8.0.1/modules/system/layers/base/com/postgres/main/
    touch module.xml
    module内容:<?xml version="1.0" ?>








在这里插入图片描述

  • 初始化keycloak管理员用户:keycloak-8.0.1/bin/add-user-keycloak.sh -r master -u admin -p admin123

  • 设置为系统服务:
    cat > /etc/systemd/system/keycloak.service <<EOF

    [Unit]
    Description=Keycloak

    [Service]
    Type=idle
    ExecStart=/root/Downloads/keycloak-8.0.1/bin/standalone.sh -Djboss.bind.address= 0.0.0.0
    TimeoutStartSec=600
    TimeoutStopSec=600

    [Install]
    WantedBy=multi-user.target
    EOF

  • 设置开机自动启动:
    systemctl daemon-reload
    systemctl enable keycloak
    systemctl start keycloak

  • 访问:http://192.168.1.103:8080/auth/

  • 或者docker镜像启动
    docker run -p 8080:8080 -d --restart=unless-stopped -e DB_VENDOR=POSTGRES -e DB_ADDR=“192.168.1.103:5432” -e DB_DATABASE=iam -e DB_USER=“postgres” -e DB_PASSWORD=“root123” -e KEYCLOAK_USER=“admin” -e KEYCLOAK_PASSWORD=“admin123” --name keycloak jboss/keycloak:8.0.1

docker 安装keycloak

创建开机启动文件

cat > /usr/lib/systemd/system/keycloak.service <<EOF

[Unit]
Description=keycloak
After=docker.service
Requires=docker.service
Requires=dnsmasq.service

[Service]
Restart=always
RestartSec=20
TimeoutStartSec=120m

#ExecStartPre=-/usr/bin/docker load -i {{ dest_keycloak_docker_image }}

ExecStart=/usr/bin/docker run \
    --rm \
    --name keycloak \
    -e KEYCLOAK_USER=admin \
    -e KEYCLOAK_PASSWORD=admin123 \
    -e DB_VENDOR=POSTGRES \
    -e DB_ADDR=192.168.1.103 \
    -e DB_PORT=5432 \
    -e DB_DATABASE=iam \
    -e DB_USER=postgres \
    -e DB_PASSWORD=root123 \
    -p 8080:8080 \
    jboss/keycloak:8.0.1


ExecStop=/bin/bash -c " \
    /usr/bin/docker kill keycloak && \
    /usr/bin/docker rm -f keycloak "

[Install]
WantedBy=multi-user.target

EOF
设置开机启动并启动keycloak

systemctl daemon-reload

systemctl enable keycloak

systemctl start keycloak

systemctl status keycloak

注意事项

在服务命令里面运行docker 命令,传参数的时候不能带有引号
如下参数 DB_USER 带有引号,导致启动服务的时候报错,识别不到,需要去掉引号。

值得注意的是,单独运行该命令,有引号也不会有问题

ExecStart=/usr/bin/docker run \
    --rm \
    --name keycloak \
    -e KEYCLOAK_USER=admin \
    -e KEYCLOAK_PASSWORD=admin123 \
    -e DB_VENDOR=POSTGRES \
    -e DB_ADDR=192.168.1.103 \
    -e DB_PORT=5432 \
    -e DB_DATABASE=iam \
    -e DB_USER="postgres" \
    -e DB_PASSWORD=root123 \
    -p 8080:8080 \
    jboss/keycloak:8.0.1
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值