多云组网部署 k3s 集群的另一种选择Tailscale

本文最后更新于 349 天前, 如有失效请评论区留言.

随着最近帕鲁流行,各大云服务商都推出了类似活动,作为买鸡大户,选择又买了几台。趁着春节决定好好折腾一下。

前因

根据 k3s 官网文档,我本来是基于 wireguard 进行全球组网的,后面经过测试,如果某个节点因为大陆反向墙了或者主动屏蔽了海外流量的话,会导致这个节点流量会异常增加(数据来源自哪吒监控), 所有想探索一下有没有其他方式。

在 k3s v1.27.3v1.26.6 及更高版本中,支持 Tailscale 集成,以便节点使用 Tailscale VPN 服务在节点之间构建网格。

在这之前先简单介绍我之前怎么部署的

嵌入式 k3s 多云解决方案

K3s 使用 wireguard 为集群流量建立 VPN 网格。每个节点都必须有一个唯一的 IP,通过该 IP 可以访问它们, 集群 (CNI) 流量将使用 wireguard 隧道。

  • 控制节点配置参数
# SERVER_EXTERNAL_IP 这个通常是节点的公网ip
--node-external-ip=<SERVER_EXTERNAL_IP> --flannel-backend=wireguard-native --flannel-external-ip
  • 计算节点配置参数
# AGENT_EXTERNAL_IP 这个通常是节点的公网ip
--node-external-ip=<AGENT_EXTERNAL_IP>

改造

安装 tailscale

curl -fsSL https://tailscale.com/install.sh | sh

我的节点基本都已经安装了 tailscale,这步可以跳过。如果你安装比较慢可以考虑试试我的镜像源,但不一定好使哈。

tailscale 镜像使用帮助

已经登录的,或者已经配置了 route 都没关系,不用管。

申请 tailscale 密钥

在 Tailscale 控制台生成一个身份验证密钥 $AUTH-KEY,该密钥可对集群中的所有节点重复使用 Settings > Keys

申请 URL

注意点:

  • 勾选 Reusable, 开启 Key 重复使用
  • 记好 Key, 仅可见一次,key 有效期不用管,注册后可以通过节点的属性设置有效期

开启自动允许路由(可选)

使用 tailscale 组网的话,每个节点会自动发布自己节点的路由

配置路径 Access controls URL

// Example/default ACLs for unrestricted connections.
{
	"autoApprovers": {
		"routes": {
			"10.42.0.0/16": ["ysicing@github"],
		},
	},
	// Declare static groups of users. Use autogroups for all users or users with a specific role.
	// "groups": {
	//  	"group:example": ["alice@example.com", "bob@example.com"],
	// },

节选如上, 具体 podCIDR 根据你的情况确定,后面的用户也根据你实际情况来写,由于我是用 github 登录的,我的账号信息就是 ysicing@github

改造

编辑所有的 /etc/systemd/system/k3s.service, 由于我是手搓的配置,文件名都一样.如果你通过脚本安装的可能是 k3s.service/k3s-agent.service

注释掉所有 --flannel-external-ip,--flannel-backend wireguard-native,--node-external-ip 参数

新增 --vpn-auth="name=tailscale,joinKey=tskey-auth-..." \ 参数,joinKey 的值就是对应的上面步骤申请的密钥

完成上述步骤重启即可

systemctl daemon-reload
systemctl restart k3s

观察生效

kubectl get nodes -o wide

所有节点的 INTERNAL-IP 都是 100 打头开始的就行。

问题 QA

节点 INTERNAL-IP 不变

  • 首先检查有没有开启 ipv6,没有的话开启支持 ipv6

如果不出意外编辑 /etc/sysctl.conf,把 1 改成 0,编辑结果如下

net.ipv6.conf.all.disable_ipv6 = 0
net.ipv6.conf.default.disable_ipv6 = 0
net.ipv6.conf.lo.disable_ipv6 = 0

生效 sysctl -p

然后重启 k3s 看看, 如果还不变的话,可能需要看看 k3s 日志

如果日志如下, 提示没法识别 ipv6

Feb 07 22:23:02 node1 k3s[1448143]: E0207 22:23:02.346550 1448143 kubelet_node_status.go:701] "Failed to set some node status fields" err="failed to validate secondaryNodeIP: node IP: \"fd7a:115c:a1e0:ab12:4843:cd96:6278:6544\" not found in the host's network interfaces" node="node1"

需要给 k3s 新增启动参数

--kubelet-arg "node-ip=0.0.0.0" \

然后重载并重启 k3s 再观察。

调整优势

  • 可以支持 NAT 机器加入组网中
  • 节点如果双栈支持,避免 ipv4 被打,集群节点失联

Chapters

Sponsor

Like this article? $1 reward

Comments

阿达 ·v1 美国 Reply

内网机器无法ping通那台k3s server了。是怎么回事?

ysicing 👨‍💻 ·v1 Reply

@阿达 tailscale跨境组网的?有效信息比较少,有自建derp么,另外看看tailscale控制台节点是否正常或者k3s服务是否正常

阿达 ·v1 美国 Reply

@ysicing 比如内网192.168.100.0/24 k3s是192.168.100.100,使用`--vpn-auth="name=tailscale,joinKey=tskey-auth-..."`安装k3s之后,其他内网机器ping 192.168.100.100就ping不通。 内网有1个机器已经在跑tailscale 的 advertise-routes了。 但是K3s应该是跑的advertise-routes=10.42.0.0/24

ysicing 👨‍💻 ·v1 Reply

@阿达 没遇到你这种情况哎。正常情况下,k3s只会宣告k3s节点的路由。你可以看看两个节点的路由情况`ip route show table 52`

阿达 ·v1 台湾台北 Reply

@ysicing 192.168.100.0/24 dev tailscale0 多了这一笔