news 2026/6/24 9:05:43

本地部署开源身份和访问管理解决方案 Keycloak 并实现外部访问( Linux 版本)

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
本地部署开源身份和访问管理解决方案 Keycloak 并实现外部访问( Linux 版本)

Keycloak 是一款开源的身份和访问管理( IAM )解决方案,它由 Red Hat 支持和维护,广泛应用于云原生环境、微服务架构以及传统的 Web 和移动应用中,为现代应用程序和服务提供简单且强大的安全功能。本文将详细介绍如何在 Linux 系统局域网内部署 Keycloak 并结合路由侠实现外网访问局域网内部署的 Keycloak 。

第一步,本地部署 Keycloak

1,本教程使用 Linux Ubuntu 系统进行演示,首先输入以下命令更新软件包列表。

sudo apt-get update

2,如果你的系统中还没有安装 Java ,请先安装它。

sudo apt install openjdk-17-jdk -y

3,前往 Keycloak 官网下载最新版 Keycloak for Quarkus ,点此查看,如 https://github.com/keycloak/keycloak/releases/download/26.3.4/keycloak-26.3.4.zip ,下载完成后解压缩并重命名文件,赋予权限。

cd /opt sudo wget https://github.com/keycloak/keycloak/releases/download/v24.0.1/keycloak-26.3.4.zip sudo unzip keycloak-26.3.4.zip sudo mv keycloak-26.3.4 keycloak sudo chown -R $USER:$USER keycloak

4,进入项目目录并启动 Keycloak 服务。

cd /opt/keycloak bin/kc.sh start-dev \ --http-port=8080 \ --hostname=localhost \ --proxy-headers=forwarded

5,打开浏览器访问地址 http://127.0.0.1:8080 或者 http://你的服务器 IP:8080 ,就能看到你部署的 Keycloak 服务界面了。

第二步,外网访问本地 Keycloak

安装路由侠内网穿透。

1,当前未提供网页管理,需要先在任意一台 Windows 机器安装路由侠 Windows 版本,用作跨机器管理。点此下载

2,在路由侠客户端主界面,进入“ 设备管理 ”,点击右下角的“ 添加设备 ”,此时可查看到对应的安装码,此安装码用于将设备添加到对应账号下,可选中后复制。

3,直接下载后导入:

wget https://dl.luyouxia.com:8443/v2/lyx-docker-x86_64.tar docker load -i lyx-docker-x86_64.tar

4,然后使用该镜像启动容器。

docker run --name lyx -it --restart=always --net=host -e code=这里填写安装码luyouxia/lyx

5,此时,需要等待下载和安装的过程,如果一切正常,最终可以看到一些输出,并且可以看到如下提示:

[Device] Logged in. Token: ....

这就表示安装成功了。

当前 Linux 终端这边,如果是使用的上面的命令,Docker 是运行在前台,此时可以按住 Ctrl + C ,退出路由侠,容器也将退出。现在可以使用以下命令将其放入后台持续运行:

docker start lyx

注意如果容器删除,重新 docker run , 将创建为新的设备。

需要注意的是,因为容器参数已经添加了 --restart=always ,这样开机就会自动启动,不需要再手动启动路由侠了。

6,现在回到 Windows 这边设备列表,点击右上角的 × 返回主界面,再次进入,就可以找到这个设备,可以修改名称。

7,回到主界面,点击【内网映射】。

8,注意右上角的设备名称下拉框,这里选中刚刚添加的设备名称,此时在这个界面上添加的映射,就属于刚刚这个设备。添加或修改一般需要等待 30 秒,容器中的路由侠进程就会更新并加载。切换好设备后,点击【添加映射】。

9,选择【原生端口】。

10,在内网地址填写你的服务器 IP 和 Keycloak 端口 8080 后点击【创建】按钮,如下图。

11,创建好后,就可以看到一条映射的公网地址,鼠标右键点击【复制地址】。

12,在外网电脑上,打开浏览器,在地址栏输入从路由侠生成的外网地址,就可以看到内网部署的 Keycloak 页面了。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/24 9:05:21

RT-Thread的内核对象管理,设计比你想的巧妙

你有没有想过,一个嵌入式实时操作系统怎么管理它手里那几十上百个线程、信号量、消息队列、定时器?FreeRTOS的做法是每个内核对象一个结构体,开发者自己维护句柄。RT-Thread走了一条不太一样的路——它把所有内核对象都放进了同一个对象管理体…

作者头像 李华
网站建设 2026/6/24 8:48:20

ssl证书用完了怎么办?推荐看看这个

ssl证书最近发现阿里云的ssl个人免费证书额度用完了。然后看了还需要购买证书。偶然发现,还有这么个平台可以提供三方ssl签发的证书,通过cname转发的。非常的推荐 https://console.letsssl.cn/#/register?ref5E045235

作者头像 李华
网站建设 2026/6/24 8:47:59

为什么说大多数私域都是伪命题?聊聊CRMEB系统下的“信任阶梯”模型

这几年,我观察到一个特别讽刺的现象: 大家嘴上都挂着“私域是未来”,身体却很诚实地把私域做成了“电子传单发放处”。把人从抖音、淘宝捞进微信,然后就是无休止的群发、刷屏、九宫格海报。结果呢?好友列表里的人越来越…

作者头像 李华
网站建设 2026/6/24 8:47:49

微信小程序开发公司推荐,怎么选更靠谱?

小程序开发公司哪家好?专业选择指南一、先判断需求类型:明确要解决什么业务问题企业选型前,应先把目标拆成可执行场景,例如需求梳理、开发交付、上线维护和后续运营。专业术语小提示:可以把需求分成三类:必…

作者头像 李华
网站建设 2026/6/24 8:45:31

莫小琳2547102109

#include<iostream> using namespace std; int main() {char a[100];int i 0, j 0;//i表示长度bool flag 1;cout << "2547102109 莫小琳" << endl;cout << "请输入任何字符串或者数字" << endl;cin >> a;int k i …

作者头像 李华
网站建设 2026/6/24 8:45:24

为什么选 bf16 而不是 fp16,AMD Instinct 架构下的精度与性能权衡

为什么在关键场景下必须放弃 fp16 在做金融风控建模或者科学计算模拟时&#xff0c;我们往往对数值的“微小偏差”零容忍。很多开发者在将模型从 NVIDIA 平台迁移到 AMD Instinct GPU&#xff08;如 MI250、MI300X&#xff09;时&#xff0c;习惯性地沿用了 fp16&#xff08;半…

作者头像 李华