Centos7下安装-使用K3S

news2024/11/24 7:45:43

本文主要内容:
1.安装k3s
2.在idea中,编辑yml文件创建pod
3.在k3d中pod基本操作
4.在k3d中Labeles标签基本操作
5.在k3d中容器的基本操作

(k3s的操作与k8s操作不同处在于,k3s每次执行命令,前面需要加上k3s)

文章目录

  • K3S安装
  • idea编辑ymal
  • pod基本操作
    • 查看默认命名空间的 pod,可以通过k3s kubectl get pods
    • 创建pod
    • 删除pod
    • 查看pod日志
    • 查看pod描述信息
    • 创建pod.yml,运行多个容器
    • 进入pod中的容器
  • 标签(Labeles)基本操作
    • 查看Labeles标签
    • 添加labeles标签
    • 修改labeles标签
    • #删除labels标签
    • 筛选labels标签
  • 容器基本操作
    • 查看容器生命周期及阶段
    • 容器生命周期回调

K3S简介 与 K3S官方文档链接

K3s是一个轻量级的、专为容器化应用和Kubernetes集群设计的开源Kubernetes发行版。K3s的目标是提供一个更小、更简单、更易于部署和维护的Kubernetes集群。

K3S安装

K3S安装脚本获取,脚本地址:https://get.k3s.io/
在这里插入图片描述

curl -sfL https://get.k3s.io | sh -

如果觉得官方源太慢,可以指定国内源进行安装:

curl -sfL http://rancher-mirror.cnrancher.com/k3s/k3s-install.sh | INSTALL_K3S_MIRROR=cn sh -

修改配置
装好之后根据需要,可以调整下 K3s 的服务配置文件,以将 K3s 的默认容器引擎从 Containerd 切换到 Docker。

修改 K3S 服务的配置文件:

vi /etc/systemd/system/multi-user.target.wants/k3s.service

需要修改 ExecStart 的值:

# 原值
# ExecStart=/usr/local/bin/k3s server

# 新值
ExecStart=/usr/local/bin/k3s server --docker --no-deploy traefik

之后保存退出,执行命令重新加载新的服务配置文件:

systemctl daemon-reload
service k3s restart

最后,可以通过命令确认 K3s 服务是否就绪:

k3s kubectl get node

如果你看到类似下面的输出,表示 K3s 已经安装完成并且正常运行了:
在这里插入图片描述

idea编辑ymal

在idea中编写yaml并发布到kubernetes

idea安装kubernetes插件,首先进入idea->File->Settings->Plugins->搜索kubernetes->安装->重启,
在这里插入图片描述
在项目src下创建一个文件夹命名为k8s,之后创建文件name.yaml,进入输入界面:
在这里插入图片描述
在这里插入图片描述
pod文件自带配置
在这里插入图片描述

pod基本操作

查看默认命名空间的 pod,可以通过k3s kubectl get pods

k3s kubectl get pods

创建pod

#创建pod
[root@localhost tmp]# k3s kubectl run nginx --image=nginx:1.19
pod/nginx created

#查看pod
[root@localhost tmp]# k3s kubectl get pods
NAME    READY   STATUS    RESTARTS   AGE
nginx   1/1     Running   0          16s

通过创建nginx-pod.yml,创建容器

apiVersion: v1
kind: Pod
metadata:
  name: nginx
  labels:
    app: nginx
spec:
  containers:
    - name: nginx
      image: nginx:1.19
      ports:
        - containerPort: 80

将内容复制粘贴到k3s服务器上即可
touch nginx-pod.yml #创建文件

```bash
apiVersion: v1
kind: Pod
metadata:
  name: nginx
  labels:
    app: nginx
spec:
  containers:
    - name: nginx
      image: nginx:1.19
      ports:
        - containerPort: 80
  

通过apply创建pod

k3s kubectl apply -f nginx-pod.yml

删除pod

方式一、k3s kubectl delete  pod pod名称
[root@localhost tmp]# k3s kubectl delete  pod nginx
pod "nginx" deleted


方式二、k3s kubectl delete -f pod.yml
[root@localhost tmp]# k3s kubectl delete -f mypod.yml 
pod "mypod" deleted

查看pod日志

# 注意: 查看 pod 中第一个容器日志
kubectl logs -f(可选,实时) nginx(pod 名称)

# 注意: 查看 pod 中指定容器的日志
kubect logs -f pod名称 -c 容器名称

查看pod描述信息

kubectl describe pod nginx(pod名称)

创建pod.yml,运行多个容器

vi mypod.yaml #创建多个pod的yml文件,包含nginx和reids

apiVersion: v1
kind: Pod
metadata:
  name: mypod
  labels:
    app: mypod
spec:
  containers:
    - name: nginx
      image: nginx:1.19
      imagePullPolicy: IfNotPresent
      ports:
        - containerPort: 80
    - name: redis
      image: redis:5.0.10
      imagePullPolicy: IfNotPresent
      ports:
        - containerPort: 6379
  restartPolicy: Always

  

执行命令k3s kubectl apply -f mypod.yml创建pod

[root@localhost tmp]# k3s kubectl apply -f  mypod.yml 
pod/mypod created

进入pod中的容器

#注意: 这种方式进入容器默认只会进入 pod 中第一个容器
k3s kubectl exec -it pod名称 --(固定写死) bash(执行命令)

# 注意: 进入指定 pod 中指定容器
kubectl exec -it pod名称 -c 容器名称 --(固定写死) bash(执行命令)

例如:
k3s kubectl exec -it mypod -c nginx -- sh

标签(Labeles)基本操作

# 查看标签
kubectl get pods --show-labels

# kubectl label pod pod名称 标签键值对
kubectl label pod myapp env=prod

# 覆盖标签 --overwrite
kubectl label --overwrite pod myapp env=test

# 删除标签 -号代表删除标签
kubectl label pod myapp env-

# 根据标签筛选 env=test/env > = <
kubectl get po -l env=test
kubectl get po -l env
kubectl get po -l '!env' # 不包含的 pod

查看Labeles标签

查看labeles标签:k3s kubectl get pods --show-labels

[root@localhost tmp]# k3s kubectl get pods --show-labels
NAME    READY   STATUS    RESTARTS   AGE     LABELS
nginx   1/1     Running   0          26m     run=nginx
mypod   2/2     Running   0          8m40s   app=mypod

添加labeles标签

添加标签:给mypod 添加 env=dev的标签

#添加标签
[root@localhost tmp]# k3s kubectl label pod mypod env=dev
pod/mypod labeled
[root@localhost tmp]# k3s kubectl get pods --show-labels
NAME    READY   STATUS    RESTARTS   AGE   LABELS
nginx   1/1     Running   0          33m   run=nginx
mypod   2/2     Running   0          15m   app=mypod,env=dev

修改labeles标签

#添加错了,如何修改标签,将dev修改成test
[root@localhost tmp]# k3s kubectl label --overwrite pod mypod env=test
pod/mypod labeled
[root@localhost tmp]# k3s kubectl get pods --show-labels
NAME    READY   STATUS    RESTARTS   AGE   LABELS
nginx   1/1     Running   0          36m   run=nginx
mypod   2/2     Running   0          19m   app=mypod,env=test

#删除labels标签

#删除labels,如env-即可删除
[root@localhost tmp]# k3s kubectl label pod mypod env-
pod/mypod unlabeled
[root@localhost tmp]# k3s kubectl get pods --show-labels
NAME    READY   STATUS    RESTARTS   AGE   LABELS
nginx   1/1     Running   0          38m   run=nginx
mypod   2/2     Running   0          21m   app=mypod

筛选labels标签

[root@localhost tmp]# k3s kubectl get pod -l env=dev
NAME    READY   STATUS    RESTARTS   AGE
mypod   2/2     Running   0          25m

容器基本操作

查看容器生命周期及阶段

在执行k3s kubectl apply -f mypod.yml命令生成容器后,即可命令k3s kubectl describe pod mypod监控该容器生命周期状态

[root@localhost ~]# k3s kubectl describe pod mypod
Name:             mypod
Namespace:        default
Priority:         0
Service Account:  default
Node:             localhost.localdomain/192.168.31.222
Start Time:       Wed, 08 Nov 2023 11:22:59 +0800
Labels:           app=mypod
                  env=dev
Annotations:      <none>
Status:           Running
IP:               10.42.0.11
IPs:
  IP:  10.42.0.11
Containers:
  nginx:
    Container ID:   containerd://9fb499466b68ed9f9d7892b3f073de6b74d9b0d1f3e2ff26b40e69db02d19040
    Image:          nginx:1.19
    Image ID:       docker.io/library/nginx@sha256:df13abe416e37eb3db4722840dd479b00ba193ac6606e7902331dcea50f4f1f2
    Port:           80/TCP
    Host Port:      0/TCP
    State:          Running
      Started:      Wed, 08 Nov 2023 11:23:11 +0800
    Ready:          True
    Restart Count:  0
    Environment:    <none>
    Mounts:
      /var/run/secrets/kubernetes.io/serviceaccount from kube-api-access-qg4m9 (ro)
  redis:
    Container ID:   containerd://50f827458fc848859715c85962814ef6f52b841d20e3cad4b46c7d6abba6db2f
    Image:          redis:5.0.10
    Image ID:       docker.io/library/redis@sha256:2236b827820ab65836a7aa5b494e03c3ede6e8801a853a0e24c9d6afbcfe0461
    Port:           6379/TCP
    Host Port:      0/TCP
    State:          Running
      Started:      Wed, 08 Nov 2023 11:24:50 +0800
    Ready:          True
    Restart Count:  0
    Environment:    <none>
    Mounts:
      /var/run/secrets/kubernetes.io/serviceaccount from kube-api-access-qg4m9 (ro)
Conditions:
  Type              Status
  Initialized       True 
  Ready             True 
  ContainersReady   True 
  PodScheduled      True 
Volumes:
  kube-api-access-qg4m9:
    Type:                    Projected (a volume that contains injected data from multiple sources)
    TokenExpirationSeconds:  3607
    ConfigMapName:           kube-root-ca.crt
    ConfigMapOptional:       <nil>
    DownwardAPI:             true
QoS Class:                   BestEffort
Node-Selectors:              <none>
Tolerations:                 node.kubernetes.io/not-ready:NoExecute op=Exists for 300s
                             node.kubernetes.io/unreachable:NoExecute op=Exists for 300s
Events:                      <none>		#生命周期未显示出来

在这里插入图片描述

容器生命周期回调

执行命令 vi lifecycle.yml 创建yml文件,复制以下内容(注意点: ”command:“后面一定要加空格不然会报错):

apiVersion: v1
kind: Pod
metadata:
  name: lifecycle
  labels:
    app: lifecycle
spec:
  containers:
    - name: nginx
      image: nginx:1.19
      lifecycle:
        postStart:
          exec:
            command: ["/bin/bash","-c","echo postStart >> /start.txt"]
        preStop:
          exec:
            command: ["/bin/bash","-c","echo postStart >> /stop.txt && sleep 30"]
      imagePullPolicy: IfNotPresent
  restartPolicy: Always
  

执行命令 k3s kubectl apply -f lifecycle.yml 创建容器

[root@localhost tmp]# k3s kubectl apply -f lifecycle.yml 
pod/lifecycle created

执行以下命令,验证PostStart回调在容器创建后,是否被立即执行

[root@localhost tmp]# k3s kubectl get pods
NAME        READY   STATUS    RESTARTS   AGE
lifecycle   1/1     Running   0          78s
[root@localhost tmp]# k3s kubectl exec -it lifecycle -c nginx -- bash
root@lifecycle:/# ls
bin   dev                  docker-entrypoint.sh  home  lib64  mnt  proc  run   srv        sys  usr
boot  docker-entrypoint.d  etc                   lib   media  opt  root  sbin  start.txt  tmp  var

执行以下命令查看PreStop 回调被执行之前即开始计数, 所以无论回调函数的执行结果如何,容器最终都会在 Pod 的终止宽限期内被终止

[root@localhost tmp]# k3s kubectl apply -f lifecycle.yml 
pod/lifecycle created


[root@localhost tmp]# k3s kubectl get pods
NAME        READY   STATUS    RESTARTS   AGE
lifecycle   1/1     Running   0          3m8s

#再开一个小窗口,查看删除容器后,是否生成stop文件

[root@localhost tmp]# k3s kubectl delete -f lifecycle.yml
pod "lifecycle" deleted

[root@localhost ~]# k3s kubectl exec -it lifecycle -c nginx -- bash
root@lifecycle:/# ls 
bin   dev                  docker-entrypoint.sh  home  lib64  
mnt  proc  run   srv        stop.txt  tmp  var		#已生成

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1184941.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

猫罐头什么牌子好?2023营养又美味的猫主食罐头推荐!

亲爱的猫咪主人&#xff0c;你是否为你家小猫咪的挑食问题感到困扰&#xff1f;作为一位在宠物店工作了七年&#xff0c;负责喂养三十多只猫咪的店长&#xff0c;我对许多品牌的猫罐头都非常熟悉了。对于猫罐头哪个牌子好这个问题&#xff0c;我想借此机会分享一些见解。 在本…

linux基础:3.linux基础环境开发工具和配置。

linux基础环境开发工具和配置 一.学习yum工具进行软件安装&#xff1a;1.什么是yum&#xff1a;2.查看软件包&#xff1a;3.安装和删除&#xff1a;4.yum生态&#xff1a; 二.vim的使用&#xff1a;一.快速介绍一下vim二.vim正常模式&#xff1a;2-1&#xff1a;命令模式1.光标…

HarmonyOS应用开发-ArkTS基础知识

作者&#xff1a;杨亮Jerry 作为多年的大前端程序开发工作者&#xff0c;就目前的形式&#xff0c;个人浅见&#xff0c;在未来3-5年&#xff0c;移动端依旧是Android系统和iOS系统的天下。不过基于鸿蒙系统的应用开发还是值得我们去花点时间去了解下的&#xff0c;阅读并实践官…

一杯子三变:揭秘vue单页应用(spa)与内容动态加载的奥秘

&#x1f3ac; 江城开朗的豌豆&#xff1a;个人主页 &#x1f525; 个人专栏 :《 VUE 》 《 javaScript 》 &#x1f4dd; 个人网站 :《 江城开朗的豌豆&#x1fadb; 》 ⛺️ 生活的理想&#xff0c;就是为了理想的生活 ! 目录 ⭐ 专栏简介 &#x1f4d8; 文章引言 一、什…

找不到x3daudio1_7.dll怎么办?五种解决方法帮你解决x3daudio1_7.dll问题

在计算机使用过程中&#xff0c;我们经常会遇到一些错误提示&#xff0c;其中之一就是“X3DAudio1_7.dll丢失”。这个错误通常会导致音频播放异常或无法正常工作。为了解决这个问题&#xff0c;本文将介绍5种修复X3DAudio1_7.dll丢失的方法&#xff0c;帮助大家快速恢复X3DAudi…

Redis的三种特殊数据类型

文章目录 一、Redis geospatial 地理位置二、Redis Hyperloglog 基数统计的算法三、Redis Bitmaps 位存储&#xff08;0、1&#xff09;总结 一、Redis geospatial 地理位置 1.geoadd&#xff1a;将指定的地理空间位置&#xff08;纬度、经度、名称&#xff09;添加到指定的ke…

vue中 process.env 对象为空对象问题

问题&#xff1a;今天在处理vue项目环境问题的时候&#xff0c;发现直接打印 process 对象和打印 process.env 时 env 对象输出结果是不一样的&#xff0c;如下图所示&#xff1a; 在网上搜索了一番后发现还是有挺多朋友对此感到疑惑的&#xff0c;询问了同事&#xff0c;同…

VINS-Mono-后端优化 (一:预积分残差计算-IMU预积分约束)

这里先回顾一下预积分是怎么来的 VINS-Mono-IMU预积分 &#xff08;三&#xff1a;为什么要预积分预积分推导&#xff09; 这里贴出预积分的公式 具体含义解释看对对应的文章 整个误差函数如下 预积分 α \alpha α β \beta β γ \gamma γ 是用 IMU 预积分获得的增量&a…

Xtrabackup将本地数据迁移上云

本机和云端服务器安装xtrabackup #为了防止每次yum操作都会自动更新&#xff0c;卸载这个软件 yum -y remove mysql57-community-release-el7-10.noarch#下载XtraBackup yum install -y https://repo.percona.com/yum/percona-release-latest.noarch.rpm#激活该yum仓库 percon…

vue使用Echarts5实现词云图

先上官网 词云图有些特殊&#xff0c;它属于Echarts 的扩展&#xff0c;需要额外安装Echarts-wordcloud包。 Echarts 官网 Echarts-wordcloud 词云图官网 先安装 npm install echarts-wordcloud npm install echarts echarts-wordcloud再引入 echarts选一个引入就行&#xff…

Unity 利用UGUI制作圆形进度条

在Unity中使用Image和Text组件就可以制作简单的进度条。 1、首先准备好一张环状的PNG图&#xff0c;如下图。 2、把该图导入Unity中并转换成精灵。 3、在场景中创建Image和Text组件&#xff0c;并把上图中的精灵拖到Image的Source Image中&#xff0c;其中Image组件中的Image …

出口美国操作要点汇总│走美国海运拼箱的注意事项│箱讯科技

01服务标准 美国的货物需要细致的服务&#xff0c;货物到港后的服务也是非常重要的。如果在货物到港15天内&#xff0c;如果没有报关行进行(PROCEED)&#xff0c;货物就会进入了G.O.仓库&#xff0c;G.O.仓库的收费标准是非常高的。 02代理资格审核 美国航线除了各家船公司&a…

ORA-00257: Archiver error. Connect AS SYSDBA only until resolved错误解决

错误的原因&#xff1a;是因为服务器分配空间不足&#xff0c;数据库归档日志满导致系统数据库登陆失败。 解决办法&#xff1a;1.删除以前的日志 2.增大归档日志的容量 3.关闭归档模式 一、删除以前的容量 1.登录账号后&#xff0c;查看ORACLE_BASE目录 【oraclelocalhost~】$…

搅拌站远程控制系统 | 集中生产 集中调度 集中控制

上海思伟远程控制 集中生产 集中调度 集中管理 安全 整洁 高效 稳定生产 超距离远程控制 无延迟流畅生产 支持一人控制两条生产线 单机双机灵活切换 年省人力成本数十万 绿色生产 远程控制并未降低生产效率 没了噪音&#xff0c;操控更舒适 信息化与自动化的完美结…

若依框架升级(对若依框架进行了升级,升级为Mybatis-plus)

ruoyi-plus: 对若依进行了升级Mybatis-plus版https://gitee.com/xiao--yan/ruoyi-plus.git

11-08 周三 图解机器学习之实现逻辑异或,理解输出层误差和隐藏层误差项和动量因子

11-08 周三 图解机器学习之实现逻辑异或&#xff0c;理解输出层误差和隐藏层误差项 时间版本修改人描述2023年11月8日14:36:36V0.1宋全恒新建文档 简介 最近笔者完成了《图解机器学习》这本书的阅读&#xff0c;由于最近深度学习网络大行其是&#xff0c;所以也想要好好的弄清…

Windows环境下编译OLLVM源码(VS2022)

windows环境下编译OLLVM 13.x VisualStudio配置下载OLLVM13.xollvm的使用 网上关于windows环境编译ollvm信息比较杂乱&#xff0c;在此编译成功的基础上做一下总结&#xff01; VisualStudio配置 1&#xff0c;正常配置C桌面环境 2&#xff0c;在单个组件中选择用于Windows得C…

Go基础知识全面总结

文章目录 go基本数据类型bool类型数值型字符字符串 数据类型的转换运算符和表达式1. 算数运算符2.关系运算符3. 逻辑运算符4. 位运算符5. 赋值运算符6. 其他运算符运算符优先级转义符 go基本数据类型 bool类型 布尔型的值只可以是常量 true 或者 false。⼀个简单的例⼦&#…

Windows系统C++语言环境下通过SDK进行动作捕捉数据传输

NOKOV度量动作捕捉系统可以与市面上主流的操作系统和编程语言实现通信。可以在Windows系统C语言环境下通过SDK进行动作捕捉数据传输。 一、形影软件设置 1、实时模式和后处理模式都可以通过SDK传输数据。以后处理模式为例。将模式切换到后处理模式 2、加载一个刚体数据 3、打…