data:image/s3,"s3://crabby-images/01fff/01fffa3cf8d2136ec62eb56d86a46e2403a87884" alt=""
什么是 Teleport ?
Teleport
作为一个开源访问控制系统,设计用于增强现代基础设施的安全性,同时提供易用性和灵活性。Teleport
能够提供安全的远程访问和会话管理,并且支持多因素身份验证。
Teleport
具有以下主要特性:
- 堡垒机:通过
Teleport
,用户可以安全地远程访问服务器和集群。 SSH
代理:Teleport
提供了一个SSH
代理,可以将用户隔离到独立的会话中,并且支持会话录制和审计。- 多因素身份验证:
Teleport
支持多种身份验证方式,包括TOTP
、U2F
和LDAP
等。 Web
界面:Teleport
提供了一个易于使用的Web
界面,方便用户管理和监控远程访问。- 多协议支持:
Teleport
不仅支持SSH
,还理解HTTPS
、RDP
、Kubernetes API
、MySQL
、MongoDB
和PostgreSQL
等多种协议。 - 统一访问控制:
Teleport
提供了一个统一的访问控制系统,可以集中管理各种资源的访问权限。
安装
在群晖上以 Docker 方式安装。
docker
镜像地址:https://gallery.ecr.aws/gravitational
采用命令行安装方式,首先需要用 SSH
客户端登录到群晖主机
创建目录
用于挂载到容器
bash
# 新建文件夹 teleport 和 子目录
mkdir -p /volume1/docker/teleport/{config,data}
# 进入 teleport 目录
cd /volume1/docker/teleport
生成配置文件
将容器的名称设置为
localhost
,以便浏览器可以信任代理服务的自签名TLS
证书
bash
# 生成配置文件
docker run --rm \
--hostname localhost \
--entrypoint=/usr/local/bin/teleport \
public.ecr.aws/gravitational/teleport:14.3.19 configure --roles=proxy,auth > ./config/teleport.yaml
data:image/s3,"s3://crabby-images/a049d/a049d87fff1211ca7cbf3523b29a73260011e0bc" alt=""
打开文件 teleport.yaml
data:image/s3,"s3://crabby-images/ab776/ab776d37188a02fc9523b0d873231d3d55065441" alt=""
需要手动添加对 web
的侦听,否则访问网页会打不开
老苏在局域网使用,所以用的局域网
IP
yaml
proxy_service:
web_listen_addr: 0.0.0.0:3080
public_addr: <您的服务器公网IP>:3080
data:image/s3,"s3://crabby-images/ba8b2/ba8b24eb3e4fe801b775e850719fb39f66a1ac90" alt=""
启动 Teleport
bash
# 运行容器
docker run -d \
--hostname localhost \
--name teleport \
-p 3023:3023 \
-p 3024:3024 \
-p 3025:3025 \
-p 3080:3080 \
-v $(pwd)/config/teleport.yaml:/etc/teleport/teleport.yaml \
-v $(pwd)/data:/var/lib/teleport \
public.ecr.aws/gravitational/teleport:14.3.19
一般来说,Teleport
在 Docker
中主要使用以下端口:
3023
:用于SSH
代理3024
:用于反向隧道(如果需要)3025
:用于Auth
服务3080
:用于Web UI
和HTTPS
代理
更多的端口请参考官方文档:https://goteleport.com/docs/reference/networking/#ports
运行
在浏览器中输入 https://群晖IP:3080
⚠️ 注意:是
https
而不是http
点 高级
data:image/s3,"s3://crabby-images/93dc6/93dc610a2da6d3fb887a118f7a819580266dded7" alt=""
选择 继续前往
data:image/s3,"s3://crabby-images/60813/60813c761bb01834572222bef9ed0c9f3437addd" alt=""
然后就会看到登录界面了
data:image/s3,"s3://crabby-images/86387/8638749e92408f0781d63a56810405bab2939f05" alt=""
但是现在我们还没有账号,所以还需要创建账号
创建用户
执行下面的命令进入容器
bash
# 进入容器
docker exec -it teleport /bin/sh
现在已经在容器内部,可以使用 tctl
命令创建用户。基本的命令格式如下
bash
# 基本命令
tctl users add <username> --roles=<role1,role2> --logins=<login1,login2>
# 示例
tctl users add laosu --roles=access,auditor,editor --logins=laosu,root
示例创建了一个名为
laosu
的用户,具有access、auditor、editor
三个角色,并允许他以laosu
和root
身份登录到服务器
执行此命令后,Teleport
将生成一个注册链接。该链接将允许用户设置他们的密码和二次认证方式。
log
User "laosu" has been created but requires a password. Share this URL with the user to complete user setup, link is valid for 1h:
https://<proxy-address>:3080/web/invite/<token>
data:image/s3,"s3://crabby-images/483d1/483d110f541988579b1fccfb914618cd5b724c0b" alt=""
将此链接发送给用户。用户需要在链接过期之前(默认为1小时)访问此链接来完成账户设置。
data:image/s3,"s3://crabby-images/17c2b/17c2b15294721c0237bd6b5a01dc90267785ff28" alt=""
点 GET STARTED
开始填写密码
data:image/s3,"s3://crabby-images/0d128/0d1282b7c88b081c3dd6faef4a35d720d694bdf6" alt=""
需要用 Authy
作为 opt
设备扫描二维码
Authy
是一款跨平台的、支持多个设备同时使用的两步验证(2FA
)管理工具,基于TOTP
协议,旨在提高账户的安全性。主要功能是生成时间敏感的一次性密码(OTP
),这些密码可以在每次登录时使用,作为双重验证的一部分,能够显著提升用户账户的安全性。
data:image/s3,"s3://crabby-images/045cc/045cc85585d6e4627f2f856c1109a94403412187" alt=""
扫描完成后,输入在 Authy
上生成的 6
位数字
data:image/s3,"s3://crabby-images/d3392/d3392d8a3af1f8e4ab74806b10e0e738d1937e1e" alt=""
验证通过后,就注册成功了。会自动进入首界面,可以点 ADD MY FIRST RESOURCE
添加资源了
data:image/s3,"s3://crabby-images/c9d36/c9d3656d3dea4b7a2da3b3267de0f0252a5877ea" alt=""
之后的登录,除了账号、密码外,还需要 Authy
上生成的身份验证码
data:image/s3,"s3://crabby-images/79262/79262085ef75a984d69550bc3a2b484f07bdd2d2" alt=""
添加资源
可以从左上角切换到 Management
界面
data:image/s3,"s3://crabby-images/679de/679de5b8ff395ff2af1f31a3fe968dd53ac7e310" alt=""
现在你要新增的资源(Resource
)
data:image/s3,"s3://crabby-images/7a2ff/7a2ffc2b0b528dd7189e6a66b898c4ce81781d33" alt=""
以老苏的编译镜像的虚拟机 CentOS 8
为例,选择了 RHEL/CentOS 7+
data:image/s3,"s3://crabby-images/53a00/53a0048646ce51f442860873b7b2915a4f05febc" alt=""
需要在 CentOS
上执行下面的命令
脚本是有时限的,默认是
4
小时
bash
sudo bash -c "$(curl --insecure -fsSL https://192.168.0.197:3080/scripts/ada9610f30751d3f2be8f6059a78e836/install-node.sh)"
data:image/s3,"s3://crabby-images/76ec1/76ec1d102f91a4ade7e45f68f46b6ae946370c52" alt=""
老苏新增了使用
--insecure
标志来信任Teleport
的自签名证书。在生产中,您需要从受信任的CA
(例如Let's Encrypt
)向代理服务提供TLS
凭据。
data:image/s3,"s3://crabby-images/f3c8c/f3c8c691dfcf582cc2189a423694d0ec0b296f94" alt=""
这里我们假设你的网络访问相关资源是没问题,否则你会看到👇这样的内容
安装完成后
data:image/s3,"s3://crabby-images/dd1a6/dd1a683e5302bf3fe746389d38ad94ede25e3be4" alt=""
正常情况下应该会自动检测到 Teleport
实例,但实际上可能会一直处于等待中 We're still looking for your server
data:image/s3,"s3://crabby-images/235eb/235ebfb3b7221811b01194c8a21960dc01c2e7f5" alt=""
因为我们的证书是自签的,而不是受信任的,所以需要禁用证书验证,这可能会带来安全风险。所以下面的步骤应该只作为临时的故障排除措施使用,不建议在生产环境中长期使用。
找到 /etc/systemd/system/multi-user.target.wants/teleport.service
文件,在 ExecStart
中增加 --insecure
参数
从 ExecStart=/usr/local/bin/teleport start --config /etc/teleport.yaml --pid-file=/run/teleport.pid
data:image/s3,"s3://crabby-images/5b8c8/5b8c886f9ccfffc2cf2112507952f254efaf259a" alt=""
改为 ExecStart=/usr/local/bin/teleport start --insecure --config /etc/teleport.yaml --pid-file=/run/teleport.pid
data:image/s3,"s3://crabby-images/144a0/144a028894337a2bfc04cbb98fcf426b4d3870f6" alt=""
保存之后,再需要执行下面👇的命令
bash
# 重新加载 systemd 配置
sudo systemctl daemon-reload
# 重启 Teleport 服务
sudo systemctl restart teleport
# 检查 Teleport 服务状态
sudo systemctl status teleport
# 检测日志
sudo journalctl -fu teleport
如果没问题的话,应该很快就会看到新实例连接成功的信息
data:image/s3,"s3://crabby-images/56505/56505515723160a30e09ca00ba4a3d9ced41ee97" alt=""
点 Next
data:image/s3,"s3://crabby-images/74bbe/74bbe35f7e5d0b9a5463cffef4b9290764ddc5ff" alt=""
选择用户
data:image/s3,"s3://crabby-images/bdb36/bdb360ca2acfd3ebe85bf86ffe3827703ef92168" alt=""
可以测试连接
data:image/s3,"s3://crabby-images/8edb2/8edb298c9323230001a319902555e58d52a1ac44" alt=""
完成后
data:image/s3,"s3://crabby-images/8bc70/8bc708001d45bdb067955a8591724ded734157d2" alt=""
可以查看添加成功的资源
data:image/s3,"s3://crabby-images/c9bf5/c9bf5a6b54a505d88dd4b40a3389ba856ff2a266" alt=""
可以选择不同的身份连接
data:image/s3,"s3://crabby-images/ce567/ce56751f72813421b6fc3d03219444c2eb416a45" alt=""
连接成功后
data:image/s3,"s3://crabby-images/12e4f/12e4fc1366c7f52fed475bd8843d6cde9c71fb36" alt=""
问题处理
在安装过程中遇到任何问题,都可以在官方文档:https://goteleport.com/docs/
data:image/s3,"s3://crabby-images/22cd4/22cd4e0c91985822f374e0241c6a9af28d9e28d1" alt=""
点 Switvh to Ask AI
切换到 AI
模式提问
data:image/s3,"s3://crabby-images/08f11/08f11d052dddcfa0f77fe046a211995b5c39de74" alt=""
例如如何创建账号
data:image/s3,"s3://crabby-images/dfbbc/dfbbc82db9563094554457f1b96fca4a7fe9984a" alt=""
或者亚要不要暴露端口,AI
都能给你满意的答案
参考文档
gravitational/teleport: Certificate authority and access plane for SSH, Kubernetes, web apps, databases and desktops
地址:https://github.com/gravitational/teleport/
Teleport: Easiest, most secure way to access infrastructure | Teleport地址:https://goteleport.com/
Installing Teleport | Teleport Docs地址:https://goteleport.com/docs/installation/#docker
Introduce support for Synology NAS · Issue #4754 · gravitational/teleport