当前位置: 首页 > news >正文

K8S陈述式资源管理

陈述式

命令行:kubectl命令行工具

优点:90%以上的场景都可以满足,对增,删,查比较方便,对改不是很友好

缺点:命令比较冗长,复杂,难记

声明式

k8s当中的yaml文件来实现资源管理---声明式

Kubernetes kubectl 命令表 _ Kubernetes(K8S)中文文档_Kubernetes中文社区

所有的kubectl的命令行

 kubectl命令详解

可以查看,部署,查看pod的情况(详细的信息,日志,发布和回滚)

查看版本

[root@master01 ~]# kubectl version
Client Version: version.Info{Major:"1", Minor:"20", GitVersion:"v1.20.15", GitCommit:"8f1e5bf0b9729a899b8df86249b56e2c74aebc55", GitTreeState:"clean", BuildDate:"2022-01-19T17:27:39Z", GoVersion:"go1.15.15", Compiler:"gc", Platform:"linux/amd64"}
Server Version: version.Info{Major:"1", Minor:"20", GitVersion:"v1.20.15", GitCommit:"8f1e5bf0b9729a899b8df86249b56e2c74aebc55", GitTreeState:"clean", BuildDate:"2022-01-19T17:23:01Z", GoVersion:"go1.15.15", Compiler:"gc", Platform:"linux/amd64"}

 查看k8s所有资源对象的简写

[root@master01 ~]# kubectl api-resources

 查看k8s的集群信息

[root@master01 ~]# kubectl cluster-info
Kubernetes control plane is running at https://192.168.233.81:6443
KubeDNS is running at https://192.168.233.81:6443/api/v1/namespaces/kube-system/services/kube-dns:dns/proxy
To further debug and diagnose cluster problems, use 'kubectl cluster-info dump'.

 自动补齐命令

[root@master01 ~]# source <(kubectl completion bash)
可以写在脚本里,也可以在命令行执行

查看master节点的状态

[root@master01 ~]# kubectl get cs
Warning: v1 ComponentStatus is deprecated in v1.19+
NAME                 STATUS    MESSAGE             ERROR
controller-manager   Healthy   ok
scheduler            Healthy   ok
etcd-0               Healthy   {"health":"true"}这个是简写[root@master01 ~]# kubectl get componentstatuses
Warning: v1 ComponentStatus is deprecated in v1.19+
NAME                 STATUS    MESSAGE             ERROR
scheduler            Healthy   ok
controller-manager   Healthy   ok
etcd-0               Healthy   {"health":"true"}

 查看默认命名空间pod的信息

[root@master01 ~]# kubectl get pod
NAME                         READY   STATUS        RESTARTS   AGE
myapp-test-5d94dbb4f-9j2fm   1/1     Terminating   1          3d6h
myapp-test-5d94dbb4f-dv65r   0/1     Pending       0          12m
myapp-test-5d94dbb4f-gdwm6   1/1     Terminating   1          3d6h
myapp-test-5d94dbb4f-hjtjv   0/1     Pending       0          12m
myapp-test-5d94dbb4f-hn9wc   0/1     Pending       0          12m
myapp-test-5d94dbb4f-p9zld   1/1     Terminating   1          3d6hpods也可以,一样的效果

 查看命名空间有哪些(所有)

[root@master01 ~]# kubectl get ns
NAME              STATUS   AGE
default           Active   3d7h
kube-node-lease   Active   3d7h
kube-public       Active   3d7h
kube-system       Active   3d7h
查看当前集群所有的命名空间
default就是默认的命名空间

查看指定命名空间的pod

[root@master01 ~]# kubectl get pod -n kube-system
NAME                               READY   STATUS        RESTARTS   AGE
coredns-7f89b7bc75-9ldmr           1/1     Terminating   2          3d7h
coredns-7f89b7bc75-fm5fm           1/1     Running       0          15m
coredns-7f89b7bc75-g4frq           1/1     Running       0          15m
coredns-7f89b7bc75-vz54f           1/1     Terminating   2          3d7h
etcd-master01                      1/1     Running       4          3d7h
kube-apiserver-master01            1/1     Running       4          3d7h
kube-controller-manager-master01   1/1     Running       5          3d7h
kube-flannel-ds-5mcgj              1/1     Running       5          3d7h
kube-flannel-ds-lh8g5              1/1     Running       2          3d7h
kube-flannel-ds-rfxh4              1/1     Running       2          3d7h
kube-proxy-j9pgx                   1/1     Running       2          3d7h
kube-proxy-qwdd2                   1/1     Running       4          3d7h
kube-proxy-v259v                   1/1     Running       2          3d7h
kube-scheduler-master01            1/1     Running       4          3d7h
查看指定命名空间内的pod需要加 -n命名

查看pod的详细部署情况(查看默认命名空间内pod的详细信息)

[root@master01 ~]# kubectl get pod -o wide
NAME                         READY   STATUS        RESTARTS   AGE    IP           NODE     NOMINATED NODE   READINESS GATES
myapp-test-5d94dbb4f-9j2fm   1/1     Terminating   1          3d6h   10.244.1.9   node01   <none>           <none>
myapp-test-5d94dbb4f-dv65r   0/1     Pending       0          17m    <none>       <none>   <none>           <none>
myapp-test-5d94dbb4f-gdwm6   1/1     Terminating   1          3d6h   10.244.2.9   node02   <none>           <none>
myapp-test-5d94dbb4f-hjtjv   0/1     Pending       0          17m    <none>       <none>   <none>           <none>
myapp-test-5d94dbb4f-hn9wc   0/1     Pending       0          17m    <none>       <none>   <none>           <none>
myapp-test-5d94dbb4f-p9zld   1/1     Terminating   1          3d6h   10.244.1.8   node01   <none>           <none>

查看指定命名空间的详细信息

[root@master01 ~]# kubectl get pod -n kube-system -o wide
NAME                               READY   STATUS        RESTARTS   AGE    IP               NODE       NOMINATED NODE   READINESS GATES
coredns-7f89b7bc75-9ldmr           1/1     Terminating   2          3d7h   10.244.1.10      node01     <none>           <none>
coredns-7f89b7bc75-fm5fm           1/1     Running       0          22m    10.244.0.2       master01   <none>           <none>
coredns-7f89b7bc75-g4frq           1/1     Running       0          22m    10.244.0.3       master01   <none>           <none>
coredns-7f89b7bc75-vz54f           1/1     Terminating   2          3d7h   10.244.2.8       node02     <none>           <none>
etcd-master01                      1/1     Running       4          3d7h   192.168.233.81   master01   <none>           <none>
kube-apiserver-master01            1/1     Running       4          3d7h   192.168.233.81   master01   <none>           <none>
kube-controller-manager-master01   1/1     Running       5          3d7h   192.168.233.81   master01   <none>           <none>
kube-flannel-ds-5mcgj              1/1     Running       5          3d7h   192.168.233.81   master01   <none>           <none>
kube-flannel-ds-lh8g5              1/1     Running       2          3d7h   192.168.233.83   node02     <none>           <none>

查看节点信息和状态

[root@master01 ~]# kubectl get node
NAME       STATUS     ROLES                  AGE    VERSION
master01   Ready      control-plane,master   3d8h   v1.20.15
node01     NotReady   <none>                 3d7h   v1.20.15
node02     NotReady   <none>                 3d7h   v1.20.15[root@master01 ~]# kubectl get node -o wide
NAME       STATUS     ROLES                  AGE    VERSION    INTERNAL-IP      EXTERNAL-IP   OS-IMAGE                KERNEL-VERSION          CONTAINER-RUNTIME
master01   Ready      control-plane,master   3d8h   v1.20.15   192.168.233.81   <none>        CentOS Linux 7 (Core)   3.10.0-693.el7.x86_64   docker://24.0.7
node01     NotReady   <none>                 3d7h   v1.20.15   192.168.233.82   <none>        CentOS Linux 7 (Core)   3.10.0-693.el7.x86_64   docker://24.0.7
node02     NotReady   <none>                 3d7h   v1.20.15   192.168.233.83   <none>        CentOS Linux 7 (Core)   3.10.0-693.el7.x86_64   docker://24.0.7
查看node节点的详细信息

 查看pod的详细信息

[root@master01 ~]# kubectl describe pod myapp-test-5d94dbb4f-9j2fm
加上name名字

 指定查看pod的详细信息

[root@master01 ~]# kubectl get ns
[root@master01 ~]# kubectl get pod -n kube-system
[root@master01 ~]# kubectl describe pod -n kube-system etcd-master01
要-n指定命名空间,不指定就是查看默认的

 查看pod的输出日志

[root@master01 ~]# kubectl logs myapp-test-5d94dbb4f-9j2fm
[root@master01 ~]# kubectl logs -f myapp-test-5d94dbb4f-9j2fm
-f表示动态查看日志查看指定命名空间的日志输出信息
[root@master01 ~]# kubectl get pod -n kube-system
[root@master01 ~]# kubectl logs -f etcd-master01 -n kube-system
必须要-n指定申明命名空间,否则就是查看默认命名空间

 创建命名空间

[root@master01 ~]# kubectl create ns chen
namespace/chen created
[root@master01 ~]# kubectl get ns
NAME              STATUS   AGE
chen              Active   10s
default           Active   3d8h
kube-node-lease   Active   3d8h
kube-public       Active   3d8h
kube-system       Active   3d8h

删除命名空间

[root@master01 ~]# kubectl delete ns chen
namespace "chen" deleted
[root@master01 ~]# kubectl get ns
NAME              STATUS   AGE
default           Active   3d8h
kube-node-lease   Active   3d8h
kube-public       Active   3d8h
kube-system       Active   3d8h要先声明动作delete删除指定的组件ns命名空间,chen是要删除命名空间的名称,基于副本控制器创建的pod,delete实际上是重新构建,也可以理解为重启,如果不是控制器创建的,如run那就是删除删除pod
[root@master01 ~]# kubectl get pod
NAME                         READY   STATUS        RESTARTS   AGE
myapp-test-5d94dbb4f-9j2fm   1/1     Terminating   1          3d7h
myapp-test-5d94dbb4f-dv65r   0/1     Pending       0          57m
myapp-test-5d94dbb4f-gdwm6   1/1     Terminating   1          3d7h
myapp-test-5d94dbb4f-hjtjv   0/1     Pending       0          58m
myapp-test-5d94dbb4f-hn9wc   0/1     Pending       0          58m
myapp-test-5d94dbb4f-p9zld   1/1     Terminating   1          3d7h
[root@master01 ~]# kubectl delete pod myapp-test-5d94dbb4f-9j2fm先声明动作:create , delete ,get , desvribe 指定对象:如 ns,pod,service 指定对象的名称 chen等的名称,如果不是默认命名空间需要 -n 指定命名空间

deployment的创建方式部署pod

特点以及两种方式部署

陈述式部署:命令行

声明式:yaml文件部署

滚动更新:不是一次性的吧所有pod全部部署,而是一个个来,pod的更新时使用,逐步的引入新的pod,逐步的减少旧的pod

自我修复:如果有pod节点发生故障,deployment会自动启动新的pod来进行代替

回滚:如果更新有问题,deployment会提供一个还原点,可以手动还原到未更新前的状态

扩容和缩容:deployment可以随时调整pod的数量,以适应流量的变化

上述的功能需要实现必须要基于deployment创建的服务才可以,绝大多数的pod都是使用deployment创建的

[root@master01 ~]# kubectl get deployments
NAME         READY   UP-TO-DATE   AVAILABLE   AGE
myapp-test   0/3     3            0           3d7h
查看默认命名空间使用deployment创建的pod数量[root@master01 ~]# kubectl get deployments -n kube-system
NAME      READY   UP-TO-DATE   AVAILABLE   AGE
coredns   2/2     2            2           3d8h
指定命名空间查看

daemonset创建方式

daemonset:不能通过命令行创建,只能通过yaml文件中点定义的方式创建

daemonset是后台运行创建,会在每个节点上都创建一个相同方式,相同版本的容器运行pod

daemonset一般都是依赖环境和重要组件。一般不会对这些资源进行操作。

[root@master01 ~]# kubectl get daemonsets
No resources found in default namespace.
[root@master01 ~]# kubectl get daemonsets -n kube-system
NAME              DESIRED   CURRENT   READY   UP-TO-DATE   AVAILABLE   NODE SELECTOR            AGE
kube-flannel-ds   3         3         1       3            1           <none>                   3d8h
kube-proxy        3         3         1       3            1           kubernetes.io/os=linux   3d8h
#daemonset不能通过命令行创建,只能通过yaml文件中点定义的方式创建

deployment部署pod

[root@master01 ~]# kubectl create deployment nginx-chen --image=nginx
deployment.apps/nginx-chen created
[root@master01 ~]# kubectl get pod
NAME                          READY   STATUS        RESTARTS   AGE
myapp-test-5d94dbb4f-9j2fm    1/1     Terminating   1          3d7h
myapp-test-5d94dbb4f-dv65r    0/1     Pending       0          73m
myapp-test-5d94dbb4f-gdwm6    1/1     Terminating   1          3d7h
myapp-test-5d94dbb4f-hjtjv    0/1     Pending       0          74m
myapp-test-5d94dbb4f-hn9wc    0/1     Pending       0          74m
myapp-test-5d94dbb4f-p9zld    1/1     Terminating   1          3d7h
nginx-chen-699bd94c4f-g667s   0/1     Pending       0          24s[root@master01 ~]# kubectl create deployment nginx-chen --image=nginx --replicas=3
# --replicas=3表示指定运行容器的数量是3,不加默认是1指定命名空间创建
[root@master01 ~]# kubectl create ns chen
namespace/chen created
[root@master01 ~]# kubectl create deployment nginx-chen --image=nginx -n chen
deployment.apps/nginx-chen created在指定命名空间创建deployment[root@master01 ~]# kubectl get pod
NAME                          READY   STATUS        RESTARTS   AGE
myapp-test-5d94dbb4f-9j2fm    1/1     Terminating   1          3d7h
myapp-test-5d94dbb4f-dv65r    0/1     Pending       0          77m
myapp-test-5d94dbb4f-gdwm6    1/1     Terminating   1          3d7h
myapp-test-5d94dbb4f-hjtjv    0/1     Pending       0          77m
myapp-test-5d94dbb4f-hn9wc    0/1     Pending       0          77m
myapp-test-5d94dbb4f-p9zld    1/1     Terminating   1          3d7h
nginx-chen-699bd94c4f-g667s   0/1     Pending       0          3m38s
[root@master01 ~]# kubectl get pod -n chen
NAME                          READY   STATUS    RESTARTS   AGE
nginx-chen-699bd94c4f-phbc6   0/1     Pending   0          15s[root@master01 ~]# kubectl delete pod nginx-chen-699bd94c4f-g667s
pod "nginx-chen-699bd94c4f-g667s" deleted
删除掉
[root@master01 ~]# kubectl delete pod nginx-chen-699bd94c4f-phbc6 -n chen
pod "nginx-chen-699bd94c4f-phbc6" deleted
删除掉指定的命名空间里的pod如果是基于deployment方式创建的pod,或者是daemonset方式创建的pod,是由控制器创建的pod,使用delete删除pod是删不掉的,相当于重启pod基于deployment方式创建的pod,一旦删除deployment,基于这个deployment创建的pod都会被删除,慎用
[root@master01 ~]# kubectl run nginx1 --image=nginx
pod/nginx1 created
[root@master01 ~]# kubectl get pod
NAME                          READY   STATUS        RESTARTS   AGE
myapp-test-5d94dbb4f-9j2fm    1/1     Terminating   1          3d7h
myapp-test-5d94dbb4f-dv65r    0/1     Pending       0          86m
myapp-test-5d94dbb4f-gdwm6    1/1     Terminating   1          3d7h
myapp-test-5d94dbb4f-hjtjv    0/1     Pending       0          86m
myapp-test-5d94dbb4f-hn9wc    0/1     Pending       0          86m
myapp-test-5d94dbb4f-p9zld    1/1     Terminating   1          3d7h
nginx-chen-699bd94c4f-j86vn   0/1     Pending       0          6m27s
nginx1                        0/1     Pending       0          5s
[root@master01 ~]# kubectl delete pod nginx1
pod "nginx1" deleted
[root@master01 ~]# kubectl get pod
NAME                          READY   STATUS        RESTARTS   AGE
myapp-test-5d94dbb4f-9j2fm    1/1     Terminating   1          3d7h
myapp-test-5d94dbb4f-dv65r    0/1     Pending       0          87m
myapp-test-5d94dbb4f-gdwm6    1/1     Terminating   1          3d7h
myapp-test-5d94dbb4f-hjtjv    0/1     Pending       0          87m
myapp-test-5d94dbb4f-hn9wc    0/1     Pending       0          87m
myapp-test-5d94dbb4f-p9zld    1/1     Terminating   1          3d7h
nginx-chen-699bd94c4f-j86vn   0/1     Pending       0          7m10s不是基于控制器创建,会被直接删除

远程进入节点容器

[root@master01 ~]# kubectl exec -it nginx-chen-699bd94c4f-j86vn bash
docker的exec只能在本机内部使用,不能跨主机,kubectl exec可以跨主机进入容器[root@master01 ~]# kubectl create deployment nginx --image=nginx -n chen
[root@master01 ~]# kubectl get pod -n chen
NAME                          READY   STATUS    RESTARTS   AGE
nginx-6799fc88d8-kkq5r        0/1     Pending   0          14s
nginx-chen-699bd94c4f-bd6kk   0/1     Pending   0          13m
[root@master01 ~]# kubectl exec -it nginx-chen-699bd94c4f-bd6kk bash -n chen

快速的让容器结束

[root@master01 ~]# kubectl delete pod nginx-chen-699bd94c4f-j86vn --force --grace-period=0
warning: Immediate deletion does not wait for confirmation that the running resource has been terminated. The resource may continue to run on the cluster indefinitely.
pod "nginx-chen-699bd94c4f-j86vn" force deleted#--grace-period:过度的存活期。默认是30秒。可以让pod优雅的结束容器内的进程,然后退出pod
#=0:表示立即停止pod。必须要force实现
#主要是用于结束卡在销毁状态的pod

对deployment创建的pod进行扩缩容

[root@master01 ~]# kubectl scale deployment nginx-chen --replicas=3
deployment.apps/nginx-chen scaled
[root@master01 ~]# kubectl get pod
NAME                          READY   STATUS        RESTARTS   AGE
myapp-test-5d94dbb4f-9j2fm    1/1     Terminating   1          3d7h
myapp-test-5d94dbb4f-dv65r    0/1     Pending       0          102m
myapp-test-5d94dbb4f-gdwm6    1/1     Terminating   1          3d7h
myapp-test-5d94dbb4f-hjtjv    0/1     Pending       0          102m
myapp-test-5d94dbb4f-hn9wc    0/1     Pending       0          102m
myapp-test-5d94dbb4f-p9zld    1/1     Terminating   1          3d7h
nginx-chen-699bd94c4f-g4f6k   0/1     Pending       0          11s
nginx-chen-699bd94c4f-rn2l9   0/1     Pending       0          11s
nginx-chen-699bd94c4f-wd266   0/1     Pending       0          2m1s扩容[root@master01 ~]# kubectl scale deployment nginx-chen --replicas=1
deployment.apps/nginx-chen scaled
[root@master01 ~]# kubectl get pod
NAME                          READY   STATUS        RESTARTS   AGE
myapp-test-5d94dbb4f-9j2fm    1/1     Terminating   1          3d7h
myapp-test-5d94dbb4f-dv65r    0/1     Pending       0          102m
myapp-test-5d94dbb4f-gdwm6    1/1     Terminating   1          3d7h
myapp-test-5d94dbb4f-hjtjv    0/1     Pending       0          102m
myapp-test-5d94dbb4f-hn9wc    0/1     Pending       0          102m
myapp-test-5d94dbb4f-p9zld    1/1     Terminating   1          3d7h
nginx-chen-699bd94c4f-wd266   0/1     Pending       0          2m22s缩容
创建pod是并没有指定副本数,后续也可以对它的副本数进行修改,只能是deployment创建的方式才可以,daemonset创建的不行

如何把服务的service进行发布

[root@master01 ~]# kubectl get svc
NAME         TYPE        CLUSTER-IP      EXTERNAL-IP   PORT(S)        AGE
kubernetes   ClusterIP   10.96.0.1       <none>        443/TCP        3d9h
myapp-test   NodePort    10.96.208.213   <none>        80:30096/TCP   3d8h
nginx        NodePort    10.96.22.254    <none>        80:30221/TCP   3d8h
[root@master01 ~]# kubectl get svc -n chen
No resources found in chen namespace.#查看当前命名空间的service的类型
#-n:指定命名空间[root@master01 ~]# kubectl delete svc nginx
service "nginx" deleted
[root@master01 ~]# kubectl get svc
NAME         TYPE        CLUSTER-IP      EXTERNAL-IP   PORT(S)        AGE
kubernetes   ClusterIP   10.96.0.1       <none>        443/TCP        3d9h
myapp-test   NodePort    10.96.208.213   <none>        80:30096/TCP   3d8h
#删除当前命名空间的service
#-n:指定命名空间
ClusterIP类型
ClusterIP:创建service的默认类型,提供一个集群内部的虚拟IP地址,通过这个虚拟IP可以直接访问pod的资源。无法对外提供访问
NodePort类型

NodePort:会在每一个node节点上都开放一个相同对的端口。外部可以通过node的本机IP地址+端口,访问pod资源。集群外部访问service资源的一种方式。四层代理方式。

nodeip:nodeport

会随机指派,也可以指定。

端口会从30000-32767的固定范围随机指派一个端口,或者可以指定一个这个范围内的端口

基于deployment创建的pod可以使用的方式
[root@master01 ~]# kubectl expose deployment nginx-chen --port=80 --target-port=80 --name=nginx-service --type=NodePort
service/nginx-service exposed
[root@master01 ~]# kubectl get svc
NAME            TYPE        CLUSTER-IP      EXTERNAL-IP   PORT(S)        AGE
kubernetes      ClusterIP   10.96.0.1       <none>        443/TCP        3d9h
myapp-test      NodePort    10.96.208.213   <none>        80:30096/TCP   3d8h
nginx-service   NodePort    10.96.214.169   <none>        80:30127/TCP   13s#--port=80:声明service集群的端口
#--target-port=80:声明pod内部容器的端口nginx-service   NodePort    10.96.94.66   <none>        80:30386/TCP      9s
#10.96.94.66:集群内部的IP地址,外部不可以访问这个IP地址
#80:对应的是内部的service的端口
#30386:和内部的service的端口做映射pod内部的容器端口是固定的。
--port是service和容器映射的端口可以自定义
但是--target-port容器内部的端口是固定的不可以自定义
80:30386这里的80是内部容器和service端口做的映射
这里的30386是外部主机和内部的service的端口做的映射
容器内部的端口 --port 先和service做映射。这个端口不能对外访问。如果类型是 NodePort 会在每个node节点上开通一个相同的端口,这个端口就是service和本机端口的映射。所以访问30386就可以访问容器内的服务。

修改service的默认端口
[root@master01 ~]# kubectl edit svc nginx-service
#修改service的默认端口
# Please edit the object below. Lines beginning with a '#' will be ignored,
# and an empty file will abort the edit. If an error occurs while saving this file will be
# reopened with the relevant failures.
#
apiVersion: v1
kind: Service
metadata:creationTimestamp: "2023-12-31T23:49:21Z"labels:app: nginx-chenname: nginx-servicenamespace: defaultresourceVersion: "45708"uid: b91ce2b0-8ee8-451d-80df-b2572ba25539
spec:clusterIP: 10.96.214.169clusterIPs:- 10.96.214.169externalTrafficPolicy: Clusterports:- nodePort: 30127port: 80protocol: TCPtargetPort: 80selector:app: nginx-chensessionAffinity: Nonetype: NodePort
status:loadBalancer: {}pod内部的容器的端口是固定的,--port是service和容器映射的端口,可以是任意

LoadBalancer类型

LoadBalancer:如果service的类型设定为LoadBalancer。地址映射(云平台会提供一个LoadBalancer的地址)这种用法仅用于公有云服务供应商在云平台上设置好的service场景。再通过外部来访问,实现负载均衡访问。(地址需要额外付费)

创建好了service,指定类型为LoadBalancer。

ExternalName类型

ExternalName:DNS映射,给service分配一个域名,通过域名来访问后端pod资源。

使用ExternalName的service的类型,不能提供负载均衡,和 LoadBalancer 类型一样必须要设置一个LoadBalancer的地址才可以实现。

kubectl edit svc nginx1-server
#进入service内直接修改

四个类型

默认类型只对内访问

NodePort类型我配置过可以对外访问

LoadBalancer类型需要花钱

ExternalName类型需要配置域名

更新和回滚以及发布的方式

项目的生命周期:创建 > 发布 > 更新 > 回滚 > 删除
滚动更新
kubectl set image deployment nginx1 nginx=nginx:1.10
#滚动更新服务的版本

回滚

kubectl rollout history deployment nginx1
#查看回滚点信息
#数字的大小决定了距离上次操作的远近。数字越大就是最近的一次操作kubectl set image deployment nginx1 nginx=nginx:1.15 --record 
#滚动更新服务的版本
#--record:可以在回滚点上添加标识kubectl rollout undo deployment nginx1 --to-revision=1
#指定回滚点还原kubectl rollout status deployment nginx1
#查看回滚过程kubectl get pod -w
#动态查看回滚状态kubectl get all
#查看当前命名空间内部的所有信息。
#-o wide:可以查看到详细信息
#-n:指定命名空间查看

相关文章:

K8S陈述式资源管理

陈述式 命令行&#xff1a;kubectl命令行工具 优点&#xff1a;90%以上的场景都可以满足&#xff0c;对增&#xff0c;删&#xff0c;查比较方便&#xff0c;对改不是很友好 缺点&#xff1a;命令比较冗长&#xff0c;复杂&#xff0c;难记 声明式 k8s当中的yaml文件来实现资…...

详解Python内置函数 !!!

内置函数就是Python给你提供的, 拿来直接用的函数&#xff0c;比如print&#xff0c;input等。 文章目录 前言 一、和数字相关 1. 数据类型 2. 进制转换 3. 数学运算 二、和数据结构相关 1. 序列 2. 数据集合 3. 相关内置函数 三、和数据结构相关 四、和迭代器生成器相关 五、字…...

使用Vue3 + Vite创建uni-app项目(Webstorm)

使用Vue3 Vite创建uni-app项目&#xff08;Webstorm&#xff09; 参考&#xff1a;前端VUE3Vite UniAPP-- 框架搭建_uniapp vite-CSDN博客 // 参考github.com的库&#xff1a;https://github.com/dcloudio/uni-preset-vue npx degit dcloudio/uni-preset-vue#vite-ts vite-vu…...

【js】js实现多个视频连续播放:

文章目录 一、效果&#xff1a;二、实现&#xff1a;三、案例&#xff1a; 一、效果&#xff1a; 二、实现&#xff1a; <!DOCTYPE html> <html> <head><title>Video Player</title><style>#progressBar { width: 800px;height: 20px;b…...

使用openssl 生成pfx格式证书时报错:unable to load certificates

问题现象包如下&#xff1a; 之前在centos上使用openssl部署证书服务器以及颁发证书的时候遇到的问题&#xff0c;在进行个人证书生成之后需要形成pfx格式证书&#xff0c;结果过程中报错了。网上类似资料比较少&#xff0c;做个记录。 生成pfx格式证书的命令&#xff1a; o…...

微信小程序 分享按钮 监听用户分享成功

代码 <view><button class"btnLq ed flex justify-center" open-type"share" click"getAward">点击分享</button> </view>export default {data(){return{shareMd:false,//分享埋点}},onShow(){//if(this.shareMd){uni.…...

数据结构-怀化学院期末题

题目&#xff1a; 利用希尔排序算法实现线性表的排序。希尔排序是根据给定的增量序列将线性表分隔成某个“增量”的记录组成一个子序例&#xff0c;在子序列中采用直接插入排序完成。 输入 第一行为元素个数n(1<n<1000)&#xff0c;第二行为n个元素值(整数)&#xff0c;即…...

跟cherno手搓游戏引擎【1】:配置与入口点

环境配置&#xff1a; 编译环境&#xff1a;VS2019 创建两个项目&#xff1a; 设置Sandbox为启动项&#xff1a; 设置sandbox的配置属性-常规-输出目录\中间目录为如下&#xff1a; 预处理定义&#xff1a;为了配置一些只有windows才能用的函数。 设置YOTOEngin&#xff08;我…...

25计算机专业考研经验贴之准备篇

Hello各位小伙伴&#xff0c;大家新年好&#xff01; 马上就要进入寒假假期了&#xff0c;25考研也该提上日程了。今天先跟大家分享一下大家在假期可以先做起来的准备工作。 【选择学校】 择校是个非常重要的内容&#xff0c;因为不同学校的考试内容是不一样的&#xff0c;有些…...

机器人相关知识

机器人学&#xff08;Robotics) 一些基础概念 位姿 位姿位置姿态 位姿的表示 刚体 刚性物体是一组粒子的集合&#xff0c;其中任意两个粒子之间的距离保持固定&#xff0c;不受物体运动或施加在物体上的力的影响。 “完全不可变形”的物体就是刚体。 刚体位置 刚性连杆 …...

八股文打卡day22——操作系统(5)

面试题&#xff1a;什么是死锁&#xff1f;如何避免死锁&#xff1f; 我的回答&#xff1a; 死锁是两个或者多个进程都占有各自的资源&#xff0c;然后都互相请求资源&#xff0c;导致互相都陷入了阻塞状态。 如何避免死锁呢&#xff1f; 首先&#xff0c;造成死锁有四个必要…...

SQL Server 权限管理

CSDN 成就一亿技术人&#xff01; 2024年 第一篇 难度指数&#xff1a;* * CSDN 成就一亿技术人&#xff01; 目录 1. 权限管理 什么是权限管理&#xff1f; SQL server的安全机制 服务器级角色 数据库级角色 对象级角色 2. 创建用户 赋予权限 最重要的一步骤 1. 权限…...

ReentrantLock底层原理学习一

J.U.C 简介 Java.util.concurrent 是在并发编程中比较常用的工具类&#xff0c;里面包含很多用来在并发场景中使用的组件。比如线程池、阻塞队列、计时器、同步器、并发集合等等。并发包的作者是大名鼎鼎的 Doug Lea。我们在接下来的课程中&#xff0c;回去剖析一些经典的比较…...

数字孪生在增强现实(AR)中的应用

数字孪生在增强现实&#xff08;Augmented Reality&#xff0c;AR&#xff09;中的应用可以提供更丰富、交互性更强的现实世界增强体验。以下是数字孪生在AR中的一些应用&#xff0c;希望对大家有所帮助。北京木奇移动技术有限公司&#xff0c;专业的软件外包开发公司&#xff…...

【数据仓库与联机分析处理】多维数据模型

目录 一、数据立方体 二、数据模型 &#xff08;一&#xff09;星形模型 &#xff08;二&#xff09;雪花模式 &#xff08;三&#xff09;事实星座模式 三、多维数据模型中的OLAP操作 &#xff08;一&#xff09;下钻 &#xff08;二&#xff09;上卷 &#xff08;三…...

【网络面试(3)】浏览器委托协议栈完成消息的收发

前面的博客中&#xff0c;提到过很多次&#xff0c;浏览器作为应用程序&#xff0c;本身是不具备向网络中发送网络请求的能力&#xff0c;要委托操作系统的内核协议栈来完成。协议栈再调用网卡驱动&#xff0c;通过网卡将请求消息发送出去&#xff0c;本篇博客就来探讨一下这个…...

Kotlin: Jetpack — ViewModel简单应用

ViewModel 概览 Android Jetpack 的一部分。 ViewModel 类是一种业务逻辑或屏幕级状态容器。它用于将状态公开给界面&#xff0c;以及封装相关的业务逻辑。 它的主要优点是&#xff0c;它可以缓存状态&#xff0c;并可在配置更改后持久保留相应状态。这意味着在 activity 之…...

【Java技术专题】「攻破技术盲区」攻破Java技术盲点之unsafe类的使用指南(打破Java的安全管控— sun.misc.unsafe)

Java后门机制 — sun.misc.unsafe 打破Java的安全管控关于Unsafe的编程建议实例化Unsafe后门对象使用sun.misc.Unsafe创建实例单例模式处理实现浅克隆&#xff08;直接获取内存的方式&#xff09;直接使用copyMemory原理分析 密码安全使用Unsafe类—示例代码 运行时动态创建类超…...

私有云平台搭建openstack和ceph结合搭建手册

OpenStack与云计算 什么是云&#xff1f; 如何正确理解云&#xff0c;可以从以下几个方面。 云的构成。 用户&#xff1a;对用户而言是透明无感知的&#xff0c;不用关心底层构成&#xff0c;只需要知道利用云完成自己任务即可。 云提供商&#xff1a;对云资产管理和运维。 云…...

debug mccl 02 —— 环境搭建及初步调试

1, 搭建nccl 调试环境 下载 nccl 源代码 git clone --recursive https://github.com/NVIDIA/nccl.git 只debug host代码&#xff0c;故将设备代码的编译标志改成 -O3 (base) hipperhipper-G21:~/let_debug_nccl/nccl$ git diff diff --git a/makefiles/common.mk b/makefiles/…...

ros python 接收GPS RTK 串口消息再转发 ros 主题消息

代码是一个ROS(Robot Operating System)节点,用于从GPS设备读取RTK(实时动态)数据并通过ROS主题发布。 步骤: 导入必要的模块: rospy 是ROS的Python库,用于ROS的节点、发布者和订阅者。serial 用于串行通信。NavSatFix 和 NavSatStatus 是从GPS接收的NMEA 0183标准消息…...

2024年网络安全竞赛-页面信息发现任务解析

页面信息发现任务说明: 服务器场景:win20230305(关闭链接)在渗透机中对服务器信息收集,将获取到的服务器网站端口作为Flag值提交;访问服务器网站页面,找到主页面中的Flag值信息,将Flag值提交;访问服务器网站页面,找到主页面中的脚本信息,并将Flag值提交;访问服务器…...

ARM DMA使用整理

Direct Memory Access&#xff0c; 直接存储访问。同SPI,IIC,USART等一样&#xff0c;属于MCU的一个外设&#xff0c;用于在不需要MCU介入的情况下进行数据传输。可以将数据从外设传输到flash&#xff0c;也可以将数据从flash传输到外设&#xff0c;或者flash内部数据移动。 它…...

移动通信原理与关键技术学习(第四代蜂窝移动通信系统)

前言&#xff1a;LTE 标准于2008 年底完成了第一个版本3GPP Release 8的制定工作。另一方面&#xff0c;ITU 于2007 年召开了世界无线电会议WRC07&#xff0c;开始了B3G 频谱的分配&#xff0c;并于2008 年完成了IMT-2000&#xff08;即3G&#xff09;系统的演进——IMT-Advanc…...

光明源@智慧厕所技术:优化生活,提升卫生舒适度

在当今数字科技飞速发展的时代&#xff0c;我们的日常生活正在经历一场革命&#xff0c;而这场革命的其中一个前沿领域就是智慧厕所技术。这项技术不仅仅是对传统卫生间的一次升级&#xff0c;更是对我们生活品质的全方位提升。从智能感应到数据分析&#xff0c;从环保设计到舒…...

【Bootstrap学习 day13】

Bootstrap5 下拉菜单 下拉菜单通常用于导航标题内&#xff0c;在用户鼠标悬停或单击触发元素时显示相关链接列表。 基础的下拉列表 <div class"dropdown"><button type"button" class"btn btn-primary dropdown-toggle" data-bs-toggl…...

Shell:常用命令之dirname与basename

一、介绍 1、dirname命令用于去除文件名中的非目录部分&#xff0c;删除最后一个“\”后面的路径&#xff0c;显示父目录。 语法&#xff1a;dirname [选项] 参数 2、basename命令用于打印目录或者文件的基本名称&#xff0c;显示最后的目录名或文件名。 语法&#xff1a;basen…...

Linux-v4l2框架

框架图 从上图不难看出&#xff0c;v4l2_device作为顶层管理者&#xff0c;一方面通过嵌入到一个video_device中&#xff0c;暴露video设备节点给用户空间进行控制&#xff1b;另一方面&#xff0c;video_device内部会创建一个media_entity作为在media controller中的抽象体&a…...

VPC网络架构下的网络上数据采集

介绍 想象这样一个场景&#xff0c;一开始在公司里&#xff0c;所有的部门的物理机、POD都在一个经典网络内&#xff0c;它们可以通过 IP 访问彼此&#xff0c;没有任何限制。因此有很多系统基于此设计了很多点对点 IP 直连的访问&#xff0c;比如中心控制服务器 S 会主动访问物…...

模拟算法(模拟算法 == 依葫芦画瓢)万字

模拟算法 基本思想引入算法题替换所有的问号提莫攻击Z字形变换外观数列数青蛙 基本思想 模拟算法 依葫芦画瓢解题思维要么通俗易懂&#xff0c;要么就是找规律&#xff0c;主要难度在于将思路转换为代码。 特点&#xff1a;相对于其他算法思维&#xff0c;思路比较简单&#x…...

佛教网站大全免费/企业培训课程有哪些

最近项目需要把几个EXCEL合并成为一个EXCEL的多个SHEET页。经过思考&#xff0c;打算使用JSL&#xff0c;在网上找到了一个JAR包下载&#xff0c;本地调试以后发现没有问题&#xff0c;但是在maven 中央仓库中的版本有问题,空指针异常 if (c.getCellFeatures() ! null & c…...

韩国唯美网站设计/网址推荐

最近在看爬虫相关的东西&#xff0c;一方面是兴趣&#xff0c;另一方面也是借学习爬虫练习python的使用&#xff0c;推荐一个很好的入门教程&#xff1a;中国大学MOOC的《python网络爬虫与信息提取》&#xff0c;是由北京理工的副教授嵩天老师讲的&#xff0c;感觉讲的很清晰&a…...

苏州餐饮 网站建设/html制作网页代码

Beyond Compare 前一段时间&#xff0c;介绍过用Total Commander来完成文件夹同步的时候&#xff0c;一位朋友留言推荐了Beyond Compare——一个强大的超越了文件差异比较的工具。Beyond Compare对于提升工作效率&#xff0c;绝对是一个利器。 文件差异工具 单独的文件差异工具…...

wordpress title背景/竞价推广托管公司介绍

Clickhouse—实用工具obfuscator 其实前面我们已经介绍过Clickhouse的众多实用工具了,为什么我们还要单独介绍obfuscator 呢,其实原因很简单那就是前面的实用工具都太常见了,以至于我们在其他数据库或者其他数据组件都见到过,但是obfuscator 我们却很少见,这就是为什么要…...

网站侧栏软件排行榜怎么做的/网站推广方案策划书2000

遇到异常后要保存设备参数和具体异常信息到SDCard2. 在 Application 中的 onCreate() 方法内实例化在 Application onCreate()方法中调用CrashCatchHandler.getInstance().init(getApplicationContext());1. 新建CrashCatchHandler处理类件在 >Android>data>包名>c…...

做程序界面的网站/seo咨询

一。原理简述&#xff1a; 在Telnet登录中缺少安全的认证&#xff0c;其传输过程采用的是TCP进行明文传输&#xff0c;存在较大的安全隐患。而且&#xff0c;单纯的提供Telnet服务易产生主机IP地址欺骗、路由欺骗等恶意攻击。 STelnet是Secure Telnet的简称。它是在一个传统不安…...