傻瓜式教学: Debian安装k3s(长期维护版本)
本文最后更新于 657 天前, 如有失效请评论区留言.
傻瓜式教学: 如何在 Debian 上手动部署 k3s
要求
仅供参考
Debian 准备
默认已经更新好内核和安装好 docker 了, 如果不会请参考:
初始化 Debian 系统
这是我的一键初始化脚本,如果你有更好的建议,欢迎提出来;
curl https://raw.githubusercontent.com/easysoft/quickon_cli/master/hack/manifests/scripts/init.sh | bash
或者使用你自己的初始化脚本哈,如果使用你自己的初始化脚本需要安装
apt install wireguard -y
部署 k3s
下载二进制文件
wget https://ghproxy.com/https://github.com/k3s-io/k3s/releases/download/v1.24.12%2Bk3s1/k3s
chmod +x k3s
mv k3s /usr/local/bin/k3s
部署控制节点
个性化说明
- 数据存储, 默认是 sqlite(默认即可), 可选其他的如 mysql, 我的示例就是 mysql(多 master 高可用)
- 网络 cni 组件, 默认是
flannel(vxlan)
, 可选其他的,我的示例就是wireguard-native
- 基于 tailscale 跨云配置
node-ip/node-external-ip
, 我的示例就是开启了跨云配置
k3s.service
[Unit]
Description=Lightweight Kubernetes
Documentation=https://k3s.io
Wants=network-online.target
[Install]
WantedBy=multi-user.target
[Service]
Type=notify
EnvironmentFile=-/etc/systemd/system/k3s.service.env
KillMode=process
Delegate=yes
# Having non-zero Limit*s causes performance problems due to accounting overhead
# in the kernel. We recommend using cgroups to do container-local accounting.
LimitNOFILE=1048576
LimitNPROC=infinity
LimitCORE=infinity
TasksMax=infinity
TimeoutStartSec=0
Restart=always
RestartSec=5s
ExecStartPre=-/usr/sbin/modprobe br_netfilter
ExecStartPre=-/usr/sbin/modprobe overlay
ExecStart=/usr/local/bin/k3s server --datastore-endpoint mysql://tidb-region-k3s:athe8AhSheyooPh8Uph0lieJ4Fdeitei2su@tcp(10.10.10.10:3306)/tidbk3s --tls-san kapi.ysicing.net --tls-san kubeapi.ysicing.net --cluster-cidr 10.20.0.0/16 --service-cidr 10.30.0.0/16 --service-node-port-range 30000-60000 --flannel-backend wireguard-native --disable-network-policy --disable-helm-controller --disable servicelb,traefik,local-storage --kube-proxy-arg "proxy-mode=ipvs" "masquerade-all=true" --kube-proxy-arg "metrics-bind-address=0.0.0.0" --docker --node-ip 10.77.0.2 --node-external-ip 10.77.0.2
将上述文件保存后,执行如下:
systemctl enable k3s --now
查看集群状态:
k3s kubectl get nodes
# 自行下载kubectl或者软链接
ln -s /usr/local/bin/k3s /usr/local/bin/kubectl
部署计算节点
k3s.service.env
K3S_URL
: API Server 的 URL,一般格式为:https://:6443。其中 > <master_ip> 是控制节点的 IP 或者 tls-san 对应的域名哈
K3S_TOKEN
: 加入集群所需的 token,可以在控制节点上查看 /var/lib/rancher/k3s/server/node-token
文件
K3S_URL=https://kubeapi.ysicing.net:6443
K3S_TOKEN=KToken
k3s.service
[Unit]
Description=Lightweight Kubernetes
Documentation=https://k3s.io
Wants=network-online.target
[Install]
WantedBy=multi-user.target
[Service]
#Type=notify
Type=exec
EnvironmentFile=-/etc/systemd/system/k3s.service.env
KillMode=process
Delegate=yes
# Having non-zero Limit*s causes performance problems due to accounting overhead
# in the kernel. We recommend using cgroups to do container-local accounting.
LimitNOFILE=1048576
LimitNPROC=infinity
LimitCORE=infinity
TasksMax=infinity
TimeoutStartSec=0
Restart=always
RestartSec=5s
ExecStartPre=-/usr/sbin/modprobe br_netfilter
ExecStartPre=-/usr/sbin/modprobe overlay
ExecStart=/usr/local/bin/k3s agent --kube-proxy-arg "proxy-mode=ipvs" "masquerade-all=true" --kube-proxy-arg "metrics-bind-address=0.0.0.0" --docker --node-external-ip 10.77.0.3 --node-ip 10.77.0.3
开机自启服务
systemctl enable k3s --now
高可用节点说明
需要结合一下, 就是控制节点 service unit 和计算节点 env 两者相结合,简单说就是控制节点 /etc/systemd/system/k3s.service.env
需要和计算节点的配置文件一样
如何验证呢?
查看非第一个节点的任意节点 /var/lib/rancher/k3s/agent/etc/k3s-agent-load-balancer.json
高级操作
基于 tailscale 实现, 其他内网穿透类似
打通内网和 k3s service 路由
tailscale up --login-server=https://headscale.ysicing.net --accept-routes=true --accept-dns=false --advertise-routes=10.30.0.0/16
部署 lb 组件
跨云可能不太行哈,我仅在未跨云环境下使用,没法监听 tailscale 网卡
helm repo add bitnami https://charts.bitnami.com/bitnami
helm repo update
helm upgrade -i lb bitnami/metallb -n kube-system
ip 池
apiVersion: metallb.io/v1beta1
kind: IPAddressPool
metadata:
name: lbpool
namespace: kube-system
spec:
addresses:
- 10.19.49.1/24
部署生效 ip 池
kubectl apply -f ippool.yaml
# 另外一个节点添加转发,也可以是上面一个节点转发哈
tailscale up --login-server=https://headscale.ysicing.net --accept-routes=true --accept-dns=false --advertise-routes=10.19.49.1/24
部署存储
基于nfs实现存储类
helm repo add nfs-subdir-external-provisioner https://kubernetes-sigs.github.io/nfs-subdir-external-provisioner/
helm repo update
helm upgrade -i nfs-subdir-external-provisioner nfs-subdir-external-provisioner/nfs-subdir-external-provisioner \
-n kube-system \
--set image.repository=ccr.ccs.tencentyun.com/k7scn/nfs-subdir-external-provisioner \
--set nfs.server=10.0.8.8 \
--set nfs.path=/k8sshare \
部署ingress 组件
基于nginx-ingress-controller
实现
default-backend
# 部署默认后端,劫持404,503,504
kubectl apply -f https://ghproxy.com/https://raw.githubusercontent.com/ysicing/default-backend/master/deploy.yaml
配置文件
- 默认使用
DaemonSet
,指定节点角色(node-role)是 nginx 的节点部署 - 默认证书是
kube-system/tls-ysicing-cloud
# 添加rule
kubectl label nodes k.t2.ysicing.local node-role.kubernetes.io/nginx=true
# 创建证书
kubectl create secret tls tls-ysicing-cloud --cert=/tmp/fullchain.cer --key=/tmp/privkey.key --dry-run=client -o yaml > /tmp/tls-ysicing-cloud.yaml
kubectl apply -f /tmp/tls-ysicing-cloud.yaml -n kube-system
config:
access-log-path: /var/log/nginxweb/nginx_access.log
compute-full-forwarded-for: "true"
custom-http-errors: 403,503,504
error-log-path: /var/log/nginxweb/nginx_error.log
forwarded-for-header: X-Forwarded-For
generate-request-id: "true"
keep-alive-requests: "10000"
log-format-escape-json: "true"
log-format-upstream: '{ "timestamp": "$time_iso8601", "network": { "x-forward-for":
"$proxy_add_x_forwarded_for", "remote_addr": "$remote_addr"}, "user": { "id":
"$remote_user"},"user-agent": {"original": "$http_user_agent"},"namespace": "$namespace","http":
{ "version": "$server_protocol", "request": {"body": {"bytes":$body_bytes_sent},
"bytes":$request_length, "method": "$request_method", "referrer": "$http_referer",
"request_id": "$request_id"}, "response": {"body": {"bytes":$body_bytes_sent},
"bytes":$bytes_sent, "status_code": "$status", "time":$request_time}, "upstream":
{"name": "$proxy_upstream_name", "bytes": $upstream_response_length, "status_code":"$upstream_status",
"time":$upstream_response_time, "address": "$upstream_addr"}, "url": {"domain":
"$host","path": "$uri", "query": "$args", "original": "$request_uri"}}}'
max-worker-connections: "65536"
proxy-body-size: 500m
upstream-keepalive-connections: "200"
use-forwarded-headers: "true"
gzip-level: "9"
use-gzip: "true"
force-ssl-redirect: "true"
defaultBackendService: "kube-system/custom-default-backend"
reportNodeInternalIp: true
watchIngressWithoutClass: true
ingressClassResource:
name: nginx
enabled: true
default: true
extraArgs:
default-ssl-certificate: "kube-system/tls-ysicing-cloud"
# hostNetwork: true
dnsPolicy: ClusterFirstWithHostNet
nodeSelector:
node-role.kubernetes.io/nginx: "true"
extraVolumes:
- emptyDir: {}
name: log-volume
extraVolumeMounts:
- mountPath: /var/log/nginxweb
name: log-volume
defaultBackend:
enabled: false
metrics:
enabled: true
serviceMonitor:
enabled: true
kind: DaemonSet
daemonset:
useHostPort: true
# strategy:
# type: Recreate
部署ingress
helm repo add bitnami https://charts.bitnami.com/bitnami
helm repo update
helm upgrade -i nginx-ingress-controller bitnami/nginx-ingress-controller -n kube-system -f ./nginx-ingress-controller.yaml