Centos7下安装-使用K3S

2023-11-09 04:07
文章标签 安装 使用 centos7 k3s

本文主要是介绍Centos7下安装-使用K3S,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

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

文章目录

  • 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: nginxlabels:app: nginx
spec:containers:- name: nginximage: nginx:1.19ports:- containerPort: 80

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

```bash
apiVersion: v1
kind: Pod
metadata:name: nginxlabels:app: nginx
spec:containers:- name: nginximage: nginx:1.19ports:- 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: mypodlabels:app: mypod
spec:containers:- name: nginximage: nginx:1.19imagePullPolicy: IfNotPresentports:- containerPort: 80- name: redisimage: redis:5.0.10imagePullPolicy: IfNotPresentports:- containerPort: 6379restartPolicy: 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=mypodenv=dev
Annotations:      <none>
Status:           Running
IP:               10.42.0.11
IPs:IP:  10.42.0.11
Containers:nginx:Container ID:   containerd://9fb499466b68ed9f9d7892b3f073de6b74d9b0d1f3e2ff26b40e69db02d19040Image:          nginx:1.19Image ID:       docker.io/library/nginx@sha256:df13abe416e37eb3db4722840dd479b00ba193ac6606e7902331dcea50f4f1f2Port:           80/TCPHost Port:      0/TCPState:          RunningStarted:      Wed, 08 Nov 2023 11:23:11 +0800Ready:          TrueRestart Count:  0Environment:    <none>Mounts:/var/run/secrets/kubernetes.io/serviceaccount from kube-api-access-qg4m9 (ro)redis:Container ID:   containerd://50f827458fc848859715c85962814ef6f52b841d20e3cad4b46c7d6abba6db2fImage:          redis:5.0.10Image ID:       docker.io/library/redis@sha256:2236b827820ab65836a7aa5b494e03c3ede6e8801a853a0e24c9d6afbcfe0461Port:           6379/TCPHost Port:      0/TCPState:          RunningStarted:      Wed, 08 Nov 2023 11:24:50 +0800Ready:          TrueRestart Count:  0Environment:    <none>Mounts:/var/run/secrets/kubernetes.io/serviceaccount from kube-api-access-qg4m9 (ro)
Conditions:Type              StatusInitialized       True Ready             True ContainersReady   True PodScheduled      True 
Volumes:kube-api-access-qg4m9:Type:                    Projected (a volume that contains injected data from multiple sources)TokenExpirationSeconds:  3607ConfigMapName:           kube-root-ca.crtConfigMapOptional:       <nil>DownwardAPI:             true
QoS Class:                   BestEffort
Node-Selectors:              <none>
Tolerations:                 node.kubernetes.io/not-ready:NoExecute op=Exists for 300snode.kubernetes.io/unreachable:NoExecute op=Exists for 300s
Events:                      <none>		#生命周期未显示出来

在这里插入图片描述

容器生命周期回调

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

apiVersion: v1
kind: Pod
metadata:name: lifecyclelabels:app: lifecycle
spec:containers:- name: nginximage: nginx:1.19lifecycle:postStart:exec:command: ["/bin/bash","-c","echo postStart >> /start.txt"]preStop:exec:command: ["/bin/bash","-c","echo postStart >> /stop.txt && sleep 30"]imagePullPolicy: IfNotPresentrestartPolicy: 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		#已生成

这篇关于Centos7下安装-使用K3S的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!


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

相关文章

Python使用openpyxl读取Excel的操作详解

《Python使用openpyxl读取Excel的操作详解》本文介绍了使用Python的openpyxl库进行Excel文件的创建、读写、数据操作、工作簿与工作表管理,包括创建工作簿、加载工作簿、操作... 目录1 概述1.1 图示1.2 安装第三方库2 工作簿 workbook2.1 创建:Workboo

使用Go实现文件复制的完整流程

《使用Go实现文件复制的完整流程》本案例将实现一个实用的文件操作工具:将一个文件的内容完整复制到另一个文件中,这是文件处理中的常见任务,比如配置文件备份、日志迁移、用户上传文件转存等,文中通过代码示例... 目录案例说明涉及China编程知识点示例代码代码解析示例运行练习扩展小结案例说明我们将通过标准库 os

postgresql使用UUID函数的方法

《postgresql使用UUID函数的方法》本文给大家介绍postgresql使用UUID函数的方法,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录PostgreSQL有两种生成uuid的方法。可以先通过sql查看是否已安装扩展函数,和可以安装的扩展函数

如何使用Lombok进行spring 注入

《如何使用Lombok进行spring注入》本文介绍如何用Lombok简化Spring注入,推荐优先使用setter注入,通过注解自动生成getter/setter及构造器,减少冗余代码,提升开发效... Lombok为了开发环境简化代码,好处不用多说。spring 注入方式为2种,构造器注入和setter

MySQL中比较运算符的具体使用

《MySQL中比较运算符的具体使用》本文介绍了SQL中常用的符号类型和非符号类型运算符,符号类型运算符包括等于(=)、安全等于(=)、不等于(/!=)、大小比较(,=,,=)等,感兴趣的可以了解一下... 目录符号类型运算符1. 等于运算符=2. 安全等于运算符<=>3. 不等于运算符<>或!=4. 小于运

虚拟机Centos7安装MySQL数据库实践

《虚拟机Centos7安装MySQL数据库实践》用户分享在虚拟机安装MySQL的全过程及常见问题解决方案,包括处理GPG密钥、修改密码策略、配置远程访问权限及防火墙设置,最终通过关闭防火墙和停止Net... 目录安装mysql数据库下载wget命令下载MySQL安装包安装MySQL安装MySQL服务安装完成

使用zip4j实现Java中的ZIP文件加密压缩的操作方法

《使用zip4j实现Java中的ZIP文件加密压缩的操作方法》本文介绍如何通过Maven集成zip4j1.3.2库创建带密码保护的ZIP文件,涵盖依赖配置、代码示例及加密原理,确保数据安全性,感兴趣的... 目录1. zip4j库介绍和版本1.1 zip4j库概述1.2 zip4j的版本演变1.3 zip4

Python 字典 (Dictionary)使用详解

《Python字典(Dictionary)使用详解》字典是python中最重要,最常用的数据结构之一,它提供了高效的键值对存储和查找能力,:本文主要介绍Python字典(Dictionary)... 目录字典1.基本特性2.创建字典3.访问元素4.修改字典5.删除元素6.字典遍历7.字典的高级特性默认字典

使用Python构建一个高效的日志处理系统

《使用Python构建一个高效的日志处理系统》这篇文章主要为大家详细讲解了如何使用Python开发一个专业的日志分析工具,能够自动化处理、分析和可视化各类日志文件,大幅提升运维效率,需要的可以了解下... 目录环境准备工具功能概述完整代码实现代码深度解析1. 类设计与初始化2. 日志解析核心逻辑3. 文件处

一文详解如何使用Java获取PDF页面信息

《一文详解如何使用Java获取PDF页面信息》了解PDF页面属性是我们在处理文档、内容提取、打印设置或页面重组等任务时不可或缺的一环,下面我们就来看看如何使用Java语言获取这些信息吧... 目录引言一、安装和引入PDF处理库引入依赖二、获取 PDF 页数三、获取页面尺寸(宽高)四、获取页面旋转角度五、判断