首页 > 其他分享 >K8S日常操作手册

K8S日常操作手册

时间:2022-10-03 00:55:23浏览次数:80  
标签:kubectl bx 操作手册 root 日常 pod K8S florence k8smaster1

kubectl 创建对象

  • 创建资源 $ kubectl create -f ./my-manifest.yaml
  • 使用多个文件创建资源 $ kubectl create -f ./my1.yaml -f ./my2.yaml
  • 使用目录下的所有清单文件(yaml)来创建资源 $ kubectl create -f ./dir
  • 使用url创建资源 $ kubectl create -f https://git.io/vPieo
  • 启动一个nginx实例 $ kubectl run nginx --image=nginx
  • 获取pod和svc的文档 $ kubectl explain pods
  1. kubectl Scale 资源
  • 扩展pod下容器数量
root@bx-florencetest-k8smaster1[ K8S-ADMIN ]:~   kubectl scale --replicas=0 -n florence-4qjxvbk2 deployment moddpap
deployment.extensions/moddpap scaled

root@bx-florencetest-k8smaster1[ K8S-ADMIN ]:~   kubectl scale --replicas=1 -n florence-4qjxvbk2 deployment moddpap
deployment.extensions/moddpap scaled
  • 扩展名称为foo的资源到3个,是否使用rs取决于yaml中的编写

$ kubectl scale --replicas=3 rs/foo

例如yaml中kind: Deployment ,则应通过下面方法扩展

$ kubectl scale --replicas=3 deployment/foo

或者直接通过创建资源的yaml文件扩展

$ kubectl scale --replicas=3 -f foo.yaml

kubectl 与运行中的pod交互

  • 查看pod日志, -f 持续查看

kubectl logs -n florence-4qjxvbk2 moddpap-844d4fd9d5-9n2wk

  • 转发pod中的80端口到本地的5000端口
root@bx-florencetest-k8smaster1[ K8S-ADMIN ]:~  kubectl port-forward -n florence-4qjxvbk2 moddpap-844d4fd9d5-9n2wk 5000:80
Forwarding from 127.0.0.1:5000 -> 80
Forwarding from [::1]:5000 -> 80
  • 在已存在的容器中执行命令

kubectl exec -n florence-4qjxvbk2 moddpap-844d4fd9d5-9n2wk -- ls /home/

  • 获取namespace
[root@bx-florence-k8smaster1 ~]*  kubectl get ns
  • 生成ingress配置
[root@bx-florence-k8smaster1 ~]*  kubectl get ingresses -n prod -oyaml > all-prod-ingress.yaml
[root@bx-florence-k8smaster1 ~]*  ll all-prod-ingress.yaml
-rw-r--r-- 1 root root 83 May 23 01:19 all-prod-ingress.yaml
  • 获取线上pod list
[root@bx-florence-k8smaster1 ~]*  kubectl get pods -n florence-8mu2rlvw -o wide
  • 进入指定pod的容器内
[root@bx-florence-k8smaster1 ~]*  kubectl exec -it florence-5cb7ffdf68-77gfb -c florence -n florence-8mu2rlvw bash
  • 获取pod的分配的内部IP
[root@bx-florence-k8smaster1 ~]*  kubectl describe pod florence-5cb7ffdf68-77gfb -n florence-8mu2rlvw|grep IP
IP:                 10.254.58.48
  • 查看k8S某个pod的信息
[root@bx-florence-k8smaster1 ~]*  kubectl get pods florence-5cb7ffdf68-77gfb  -n florence-8mu2rlvw -o wide
NAME                        READY   STATUS    RESTARTS   AGE     IP             NODE          NOMINATED NODE   READINESS GATES
florence-5cb7ffdf68-77gfb   1/1     Running   0          6h36m   10.254.58.48   10.11.22.52   <none>           <none>
 
[root@bx-florence-k8smaster1 ~]*  kubectl get pods florence-5cb7ffdf68-77gfb -n florence-8mu2rlvw
NAME                        READY   STATUS    RESTARTS   AGE
florence-5cb7ffdf68-77gfb   1/1     Running   0          6h58m
  • 详细信息查询
  • JSON格式显示Pod的完整信息
[root@bx-florence-k8smaster1 ~]*  kubectl get pod florence-5cb7ffdf68-77gfb -n florence-8mu2rlvw --output yaml
  • YAML方式显示Pod的完整信息
[root@bx-florence-k8smaster1 ~]*  kubectl get pod  florence-5cb7ffdf68-77gfb -n florence-8mu2rlvw --output json
  • 状态和生命周期查询
[root@bx-florence-k8smaster1 ~]*  kubectl describe pods florence-5cb7ffdf68-77gfb -n florence-8mu2rlvw
Name:               florence-5cb7ffdf68-77gfb
Namespace:          florence-8mu2rlvw
Priority:           0
PriorityClassName:  <none>
Node:               10.11.22.52/10.11.22.52
Start Time:         Fri, 22 May 2020 18:31:52 +0800
Labels:             app=florence
                    department=ihospital
                    group=ihospital
                    pod-template-hash=5cb7ffdf68
                    scene=main
Annotations:        podpreset.admission.kubernetes.io/podpreset-paas-env: 11479649
Status:             Running
IP:                 10.254.58.48
Controlled By:      ReplicaSet/florence-5cb7ffdf68
Containers:
  florence:
    Container ID:   docker://688475bdad4cb9fc293c71e1b0366843521d6986c38f6eb1cf6fadb9b69d52e2
    Image:          insurance-medicine-florence-backend/florence:feature_522-232652
    Image ID:       docker-pullable://insurance-medicine-florence-backend/florence@sha256:e78c88b9ae532b642ad6bc2226643c99bfddda7c96a6560e33956c2092e5ee69
    Port:           <none>
    Host Port:      <none>
    State:          Running
      Started:      Fri, 22 May 2020 18:32:05 +0800
    Ready:          True
    Restart Count:  0
    Limits:
      cpu:     3
      memory:  3200Mi
    Requests:
      cpu:      3
      memory:   3200Mi
    Liveness:   tcp-socket :80 delay=120s timeout=10s period=10s * success=1 * failure=1
    Readiness:  tcp-socket :80 delay=50s timeout=1s period=10s * success=1 * failure=1
    Environment:
      PAAS_CLUSTER:             florence
      PAAS_TARGET:              prod
      PAAS_CLUSTER_KUBERNETES:  1
    Mounts:
      /var/run/secrets/kubernetes.io/serviceaccount from default-token-gpbhp (ro)
Conditions:
  Type              Status
  Initialized       True
  Ready             True
  ContainersReady   True
  PodScheduled      True
Volumes:
  default-token-gpbhp:
    Type:        Secret (a volume populated by a Secret)
    SecretName:  default-token-gpbhp
    Optional:    false
QoS Class:       Guaranteed
Node-Selectors:  <none>
Tolerations:     node.kubernetes.io/not-ready:NoExecute for 300s
                 node.kubernetes.io/unreachable:NoExecute for 300s
Events:          <none>
 
* * * * * * * * * * 
[root@bx-florence-k8smaster1 ~]*  kubectl get pods -n kafka log-kafka-0
NAME          READY   STATUS    RESTARTS   AGE
log-kafka-0   2/2     Running   3          79m
 
[root@bx-florence-k8smaster1 ~]*  kubectl get pods -n kafka log-kafka-0 -o wide
NAME          READY   STATUS    RESTARTS   AGE   IP            NODE          NOMINATED NODE   READINESS GATES
log-kafka-0   2/2     Running   3          79m   10.254.5.59   10.11.22.41   <none>           <none>
  • 查看POD的log
[root@bx-florence-k8smaster1 ~]*  kubectl logs -f -n kafka log-archiver-79bb645dbb-9pvpr
  • 获取florence Deployment部署的服务
[root@bx-florence-k8smaster1 ~]*  kubectl get deployment -n florence-8mu2rlvw | grep florence
florence                      5/5     5            5           102d
florence-agent                1/1     1            1           104d
florence-cms                  1/1     1            1           104d
florence-consult-service      2/2     2            2           74d
florence-doctor               1/1     1            1           103d
florence-messager             3/3     3            3           102d
florence-patient              3/3     3            3           98d
florence-pm-master            3/3     3            3           74d
florence-pm-schedule-master   1/1     1            1           74d
florence-search               2/2     2            2           103d
florence-update               1/1     1            1           102d
florence-wx-accesstoken       3/3     3            3           105d
  • 更改deployment配置
[root@bx-florence-k8smaster1 ~]*  kubectl edit deployments -n kafka log-archiver
  • 更新POD
kubectl replace -f hello-world-pod.yaml
  • 删除POD
kubectl delete pod hello-world
  • 重建POd
kubectl replace --force -f hello-world-pod.yaml

标签:kubectl,bx,操作手册,root,日常,pod,K8S,florence,k8smaster1
From: https://www.cnblogs.com/tengfei520/p/16749857.html

相关文章

  • K8S缩容
    如果你想从Kubernetes集群中删除节点,正确流程如下:1、获取节点列表kubectlgetnode2、设置不可调度kubectlcordon$node_name3、驱逐节点上的Podkubectldrain$n......
  • 【K8S】Kubernetes控制器Controller-RS/Deployment/HPA详解
    一、介绍Pod是kubernetes的最⼩管理单元,在kubernetes中,按照pod的创建方式可以将其分为两类:自主式pod:kubernetes直接创建出来的Pod,这种pod删除后就没有了,也不会重建......
  • 日常-777. 在LR字符串中交换相邻字符
    这题完全是找规律,没学到啥在一个由'L','R'和'X'三个字符组成的字符串(例如"RXXLRXRXL")中进行移动操作。一次移动操作指用一个"LX"替换一个"XL",或者用一个"XR"替换一......
  • 贤鱼的刷题日常-【c++】P7909 [CSP-J 2021] 分糖果
    ✅创作者:贤鱼⏰预计时间:15分钟@​​TOC​​题目题目背景红太阳幼儿园的小朋友们开始分糖果啦!题目描述红太阳幼儿园有n个小朋友,你是其中之一。保证n≥2。有一天你在幼儿园......
  • 【云原生】Hive on k8s 环境部署
    目录一、概述二、开始部署1)构建镜像2)添加Metastore服务编排1、配置2、控制器3、Service3)添加HiveServer2服务编排1、控制器2、Service4)修改values.yaml5)开始部署6)测试......
  • k8s helm方式部署夜莺监控系统
    一、夜莺介绍   Nightingale|夜莺监控,一款先进的开源云原生监控分析系统,采用All-In-One的设计,集数据采集、可视化、监控告警、数据分析于一体,与云原生生态紧密......
  • k8s部署canal-server使用configMap挂载方式报Read Only file System
    k8s部署canal-server使用configMap挂载方式报ReadOnlyfileSystem1.1、问题复现由于部署canal-server时,需要修改主库master的数据库连接信息以及配置zookeeper,所以为了......
  • k8s发布-jenkins流水线构建
    一、需求:使用jenkins流水线构建应用,发布至k8s二、发布流程:从gitlab仓库拉取代码--》代码编译、打包--》制作镜像并上传至镜像仓库--》发布至k8s三、安装所需插件jen......
  • 库存管理的仓库和日常管理使用教程
    首先打开我们的仓库管理小程序进入“ERP| 库存管理”的 “管理” 菜单页面。点击“仓库管理”,然后点击新增仓库。输入仓库名,点击新增 对已有仓库,仓库名右边......
  • k8s ingress实现灰度发布
    一、方案:使用ingress实现应用的灰度发布说明:此灰度发布方法不适用于利用网关转发服务的架构,利用网关转发的架构,需在网关实现灰度。灰度流程:1、服务端:版本v1正常运行,发布......