K3S完美部署

简介: K3S完美部署

👋K3S 部署

⚽️介绍

K3S轻量级Kubernetes。易于安装,仅需要 Kubernetes 内存的一半,所有组件都在一个小于 100 MB 的二进制文件中。

它适用于:

  • Edge
  • IoT
  • CI
  • Development
  • ARM
  • 嵌入 K8s
  • 不去学习那么多的 Kubernetes 高深知识也能上手使用

⚽️架构

本文介绍了高可用(HA)K3s 服务器集群的架构。

  • Server 节点指的是运行 k3s server 命令的主机,control plane数据存储组件由 k3s 管理。
  • Agent 节点指的是运行 k3s agent 命令的主机,不具有任何数据存储或 control plane 组件。
  • Server 和 Agent 都运行 kubelet容器运行时CNI

⚽️1. 安装步骤

  1. 安装系统环境
  1. 配置yum源
  2. 关掉防火墙
  3. 关掉selinux
  4. 设置主机名
  5. 修改hosts文件
  6. 修改resolv.conf
  7. 同步时间
  1. 安装容器
  2. 部署 K3S Server
  3. 部署 K3S Agent
  4. 部署 Dashboard

⚽️2. 安装系统环境(所有节点)

⚾️2.1. 生产环境安装

  • 脚本(主要安装方式)
  • 二进制包

⚾️2.2. 准备环境

  • 硬件要求:
Spec 最低 推荐
CPU 1核 2核
RAM 512MB 1GB
  • 软件环境:
Software Version
Operating System CentOS 7.9-x86_64(DVD)
containerd v1.7.2
k3s v1.26.5+k3s1
  • 服务器规划:
Role IP
k3s-main 192.168.81.131
k3s-node1 192.168.81.132

⚾️2.3. 操作系统初始化配置(所有节点)

# 配置yum源
yum install -y yum-utils
yum-config-manager --add-repo http://mirrors.aliyun.com/docker-ce/linux/centos/docker-ce.repo
# 关闭防火墙
sudo systemctl stop firewalld
sudo systemctl disable firewalld
# 关闭SeLinux
sudo setenforce 0
sudo sed -i 's/^SELINUX=enforcing$/SELINUX=permissive/' /etc/selinux/config
# 设置主机名
hostnamectl set-hostname <hostname>
# 修改hosts文件
cat >> /etc/hosts << EOF
192.168.81.131 k3s-main
192.168.81.132 k3s-node1
EOF
# 修改resolv.conf,解决域名解析失败的问题
cat >> /etc/resolv.conf << EOF
nameserver 8.8.8.8
nameserver 114.114.114.114
EOF
# 同步时间
yum install ntpdate -y
ntpdate time.windows.com

⚽️3. 安装容器(所有节点)

⚾️3.1. 安装 Containerd

yum install containerd -y
systemctl start containerd && systemctl enable containerd

⚽️4. 部署 K3S Server

⚾️4.1. 部署

curl -sfL https://rancher-mirror.rancher.cn/k3s/k3s-install.sh | INSTALL_K3S_MIRROR=cn sh -
kubectl get nodes

⚾️4.2. 检查

  • 检查是否正常安装
k3s check-config
  • 调整启动参数
vim /etc/default/grub
  • 添加 user_namespace.enable=1 参数
# 原始值
GRUB_CMDLINE_LINUX="crashkernel=auto rd.lvm.lv=centos/root rd.lvm.lv=centos/swap rhgb quiet"
# 修改后
GRUB_CMDLINE_LINUX="user_namespace.enable=1 crashkernel=auto rd.lvm.lv=centos/root rd.lvm.lv=centos/swap rhgb quiet"

⚽️5. 部署 K3S Agent

⚾️5.1. 在 server 节点上提取 token

cat /var/lib/rancher/k3s/server/node-token

⚾️5.2. 加入节点

curl -sfL https://rancher-mirror.rancher.cn/k3s/k3s-install.sh | INSTALL_K3S_MIRROR=cn K3S_URL=https://myserver:6443 K3S_TOKEN=mynodetoken sh -

⚽️6. 部署 Dashboard

⚾️6.1. 部署

GITHUB_URL=https://github.com/kubernetes/dashboard/releases
VERSION_KUBE_DASHBOARD=$(curl -w '%{url_effective}' -I -L -s -S ${GITHUB_URL}/latest -o /dev/null | sed -e 's|.*/||')
sudo k3s kubectl create -f https://raw.githubusercontent.com/kubernetes/dashboard/${VERSION_KUBE_DASHBOARD}/aio/deploy/recommended.yaml

⚾️6.2. RBAC 配置

  • 创建 dashboard.admin-user.yml 配置文件
apiVersion: v1
kind: ServiceAccount
metadata:
  name: admin-user
  namespace: kubernetes-dashboard
  • 创建 dashboard.admin-user-role.yml 配置文件
apiVersion: rbac.authorization.k8s.io/v1
kind: ClusterRoleBinding
metadata:
  name: admin-user
roleRef:
  apiGroup: rbac.authorization.k8s.io
  kind: ClusterRole
  name: cluster-admin
subjects:
  - kind: ServiceAccount
    name: admin-user
    namespace: kubernetes-dashboard
  • 部署配置
kubectl create -f dashboard.admin-user.yml -f dashboard.admin-user-role.yml

⚾️6.3. 获取令牌

kubectl -n kubernetes-dashboard create token admin-user

⚾️6.4. 本地访问

kubectl proxy
curl http://localhost:8001/api/v1/namespaces/kubernetes-dashboard/services/https:kubernetes-dashboard:/proxy/

⚾️6.5. 删除 dashboard 和 admin-user 配置

kubectl delete ns kubernetes-dashboard
kubectl delete clusterrolebinding kubernetes-dashboard
kubectl delete clusterrole kubernetes-dashboard

⚽️参考

👬 交友小贴士:

博主GithubGitee同名账号,Follow 一下就可以一起愉快的玩耍了,更多精彩文章请持续关注。

相关实践学习
深入解析Docker容器化技术
Docker是一个开源的应用容器引擎,让开发者可以打包他们的应用以及依赖包到一个可移植的容器中,然后发布到任何流行的Linux机器上,也可以实现虚拟化,容器是完全使用沙箱机制,相互之间不会有任何接口。Docker是世界领先的软件容器平台。开发人员利用Docker可以消除协作编码时“在我的机器上可正常工作”的问题。运维人员利用Docker可以在隔离容器中并行运行和管理应用,获得更好的计算密度。企业利用Docker可以构建敏捷的软件交付管道,以更快的速度、更高的安全性和可靠的信誉为Linux和Windows Server应用发布新功能。 在本套课程中,我们将全面的讲解Docker技术栈,从环境安装到容器、镜像操作以及生产环境如何部署开发的微服务应用。本课程由黑马程序员提供。 &nbsp; &nbsp; 相关的阿里云产品:容器服务 ACK 容器服务 Kubernetes 版(简称 ACK)提供高性能可伸缩的容器应用管理能力,支持企业级容器化应用的全生命周期管理。整合阿里云虚拟化、存储、网络和安全能力,打造云端最佳容器化应用运行环境。 了解产品详情: https://www.aliyun.com/product/kubernetes
目录
相关文章
|
存储 Kubernetes 关系型数据库
|
存储 Prometheus 监控
K3S环境下接入Prometheus,grafana,等监控套件
因为常规的监控都是用K8S做的,而K3S上的监控方案少之又少,如果直接用rancher上的prometheus监控,会消耗至少2G的内存,于是我们就自己做了K3S和pg数据库的监控,并且通过我们自己做的监控,可以减少一些不必要的性能开销。主要监控容器资源消耗,宿主机资源消耗,pg数据库资源消耗
4356 0
K3S环境下接入Prometheus,grafana,等监控套件
|
数据可视化 应用服务中间件 数据安全/隐私保护
轻量应用服务器部署k3s,并搭建可视化高性能网关 apisix
k3s低资源占用集群,apisix 可视化高性能网关。小白教程
2164 0
|
Kubernetes 容器 Perl
【kubernetes】解决: kubelet Failed to create pod sandbox: rpc error: code = Unknown desc = faile...
【kubernetes】解决: kubelet Failed to create pod sandbox: rpc error: code = Unknown desc = faile...
16857 0
|
存储 弹性计算 运维
快速部署 K3s 社区版
K3s 是轻量级的 Kubernetes。K3s 易于安装,仅需要 Kubernetes 内存的一半,所有组件都在一个小于 100 MB 的二进制文件中。K3s 是一个完全兼容的 Kubernetes 发行版。本文向您介绍如何通过计算巢快速部署K3s社区版。
快速部署 K3s 社区版
|
人工智能 算法 物联网
阿里云百炼最新能力升级,你都有哪些期待?
阿里云百炼大模型服务产品全新升级,探索算法和技术创新,共享阿里集团内环业务的模型构建经验。
1513 4
|
7月前
|
Kubernetes 监控 搜索推荐
在Rancher平台上部署K8S集群的方法
以上就是在Rancher平台上部署Kubernetes集群的方法,这个过程就像一次航行,惊险而又充满乐趣。希望这篇导航能够帮助您在容器化的海洋中畅行无阻!
522 13
|
12月前
|
运维 Kubernetes 数据安全/隐私保护
K8S 拉取私有仓库镜像
在Kubernetes中从私有仓库拉取镜像时,需先创建包含认证信息的Secret,然后在Pod或Deployment中引用此Secret。本文通过具体步骤演示了如何创建Secret、更新Kubernetes资源配置文件以引用Secret,并验证了镜像拉取及应用运行的成功。
812 6
|
Kubernetes 网络安全 数据安全/隐私保护
k3s部署全过程
k3s部署全过程
1088 0
k3s部署全过程
|
运维 数据安全/隐私保护 Docker
Docker自建仓库之Docker Registry部署实战
关于如何使用Docker Registry镜像搭建本地私有Docker仓库的实战教程,包括了下载镜像、创建授权目录和用户名密码、启动Registry容器、验证端口和容器、测试登录仓库、上传和下载镜像的详细步骤。
3471 5