k8s和docker常用命令

一、K8S常用命令:

查看pod: kubectl get pod -n名称空间

进入容器: kubectl exec -it pod名字 -n名称空间 bash

查看类命令:

—— 获取节点和服务版本信息,并查看附加信息

kubectl get nodes -o wide

—— 获取pod信息,默认是default名称空间

kubectl get pod

—— 获取pod信息,默认是default名称空间,并查看附加信息【如:pod的IP及在哪个节点运行】

kubectl get pod -o wide

—— 获取指定名称空间的pod

kubectl get pod -n kube-system

—— 获取指定名称空间中的指定pod

kubectl get pod -n kube-system podName

—— 获取所有名称空间的pod

kubectl get pod -A

—— 查看pod的详细信息,以yaml格式或json格式显示

kubectl get pods -o yaml

kubectl get pods -o json

—— 查看pod的标签信息

kubectl get pod -A --show-labels

—— 根据Selector(label query)来查询pod

kubectl get pod -A --selector=“k8s-app=kube-dns”

—— 查看运行pod的环境变量

kubectl exec podName env

—— 查看指定pod的日志

kubectl logs -f --tail 500 -n kube-system kube-apiserver-k8s-master

—— 查看所有名称空间的service信息

kubectl get svc -A

—— 查看指定名称空间的service信息

kubectl get svc -n kube-system

—— 查看componentstatuses信息

kubectl get cs

—— 查看所有configmaps信息

kubectl get cm -A

—— 查看所有serviceaccounts信息

kubectl get sa -A

—— 查看所有daemonsets信息

kubectl get ds -A

—— 查看所有deployments信息

kubectl get deploy -A

—— 查看所有replicasets信息

kubectl get rs -A

—— 查看所有statefulsets信息

kubectl get sts -A

—— 查看所有jobs信息

kubectl get jobs -A

—— 查看所有ingresses信息

kubectl get ing -A

—— 查看有哪些名称空间

kubectl get ns

—— 查看pod的描述信息

kubectl describe pod podName

kubectl describe pod -n kube-system kube-apiserver-k8s-master

—— 查看指定名称空间中指定deploy的描述信息

kubectl describe deploy -n kube-system coredns

—— 查看node或pod的资源使用情况

—— 需要heapster 或metrics-server支持

kubectl top node

kubectl top pod

—— 查看集群信息

kubectl cluster-info 或 kubectl cluster-info dump

—— 查看各组件信息【172.16.1.110为master机器】

kubectl -s https://172.16.1.110:6443 get componentstatuses

进阶命令操作:

—— kubectl exec:进入pod启动的容器

kubectl exec -it podName -n nsName /bin/sh ——进入容器

kubectl exec -it podName -n nsName /bin/bash ——进入容器

—— kubectl label:添加label值

kubectl label nodes k8s-node01 zone=north ——为指定节点添加标签

kubectl label nodes k8s-node01 zone- ——为指定节点删除标签

kubectl label pod podName -n nsName role-name=test ——为指定pod添加标签

kubectl label pod podName -n nsName role-name=dev --overwrite ——修改lable标签值

kubectl label pod podName -n nsName role-name- ——删除lable标签

—— kubectl滚动升级; 通过 kubectl apply -f myapp-deployment-v1.yaml 启动deploy

kubectl apply -f myapp-deployment-v2.yaml ——通过配置文件滚动升级

kubectl set image deploy/myapp-deployment myapp=“registry.cn-beijing.aliyuncs.com/google_registry/myapp:v3” ——通过命令滚动升级

kubectl rollout undo deploy/myapp-deployment 或者 kubectl rollout undo deploy myapp-deployment ——pod回滚到前一个版本

kubectl rollout undo deploy/myapp-deployment --to-revision=2 ——回滚到指定历史版本

—— kubectl scale:动态伸缩

kubectl scale 类型 名称 -n 命名空间 --replicas=个数

kubectl scale deploy myapp-deployment --replicas=5 —— 动态伸缩

kubectl scale --replicas=8 -f myapp-deployment-v2.yaml ——动态伸缩【根据资源类型和

操作类命令:

—— 创建资源

kubectl create -f xxx.yaml kubectl create

kubectl create deployment test --image=registry.cmcc.com/bigdata/gcr.io/google-samples/xtrabackup

—— 应用资源

kubectl apply -f xxx.yaml

—— 应用资源,该目录下的所有 .yaml, .yml, 或 .json 文件都会被使用

kubectl apply -f

—— 创建test名称空间

kubectl create namespace test

—— 删除资源

kubectl delete 类型 名字 名称空间

kubectl delete -f xxx.yaml

kubectl delete -f

—— 删除指定的pod

kubectl delete pod podName

—— 删除指定名称空间的指定pod

kubectl delete pod -n test podName

—— 删除其他资源

kubectl delete svc svcName

kubectl delete deploy deployName

kubectl delete ns nsName

—— 强制删除

kubectl delete pod podName -n nsName --grace-period=0 --force

kubectl delete pod podName -n nsName --grace-period=1

kubectl delete pod podName -n nsName --now

—— 编辑资源

kubectl edit pod podName

二、docker基础命令

安装docker

yum install docker-ce -y

systemctl enable docker --now

阿里云加速器

编辑 etc/docker/daemon.json

systemctl restart docker

镜像管理

镜像重命名 :docker tag 旧名字 新名字

删除镜像 :docker rmi 镜像名:tag

查看镜像层结构:docker history 镜像名

导出镜像:docker save 镜像名 > file.tar

导入镜像:docker load -i file.tar

创建容器

查看运行容器:docker ps

启动镜像:docker run [参数] 镜像名

常用参数:

1. --name:为容器指定名称

2. -it:启动一个交互型容器,此参 数为我们和容器提供了一个交互shell

3. -d:创建后台型容器

4. --restart=always:容器退出后自动重启

6. -p x:y :主机端口:容器端口

7. -P:随机分配一个49000到49900的端口

8.-v:创建数据卷, 宿主机目录:容器目录

7. -n :指定dns

8. -h : 指定容器的hostname

9. -e :设置环境变量

10. -m :设置容器使用内存最大值

11. --net: 指定容器的网络连接类型,支持 bridge/host/none/container

12. --link=x: 添加链接到另一个容器x

13. --expose=x: 开放端口x

这里docker create和docker run -it创建的容器都是交互型容器

进入容器:docker exec -it 容器名 /bin/bash

进入容器:docker attach 镜像名

在容器里执行指定指令

docker exec 容器名 命令

获取容器bash控制台:docker exec -it 容器名 bash

物理机和容器互相拷贝文件

docker cp /path/file 容器:/path2 把物理机file拷贝到容器/path2里

docker cp 容器:/path2/file /path/ 把容器里file拷贝到/path路径下

关闭 启动 重启容器

docker stop 容器名

docker start 容器名

docker restart 容器名

docker top 容器名 #查看容器里运行的进程

查看容器的输出

docker logs 容器名

docker logs -f 容器名 #查看实时日志

docker inspect 容器名

数据卷的使用

-v /dir2:dir1 :把物理机里目录/dir2映射到容器/dir1目录里

docker网络

docker network list 查看当前网络

docker network inspect birdge 查看名字为bridge网络

docker network create -d 类型(一般写bridge) --subnet=网段 网络名

例子:docker network create -d bridge --subnet=10.0.0.0/24 mynet :创建mynet网络

docker run --net=mynet -it --name=c1 --rm centos :使用mynet网络

三、docker进阶命令

自定义镜像Dockerfile书写

FROM:指定基镜像

MAINTAINER:维护者的信息

RUN:想在零时容器里执行的操作系统命令

ADD file /path/: 把物理机的file拷贝到镜像指定目录/path (压缩文件会减压)

COPY file /path/: 把物理机的file拷贝到镜像指定目录/path (压缩文件不会减压)

ENV:指定变量

USER:指定容器内部以哪个用户运行进程

VOLUME:指定数据卷

EXPOSE:指定镜像容器使用的端口,这只是一个标记

CMD:指定镜像创建出来的容器运行什么进程

例子:创建可以执行ifconfig的centos镜像 Dockerfile内容如下

FROM hub.c.163.com/library/centos

MAINTAINER duan

RUN yum install net-tools -y

CMD ["/bin/bash"]

docker build -t 新镜像名:tag . -f file

例子:docker build -t bcentos:v1 . -f dockerfile

posted @ 2025-11-22 23:35  小蓝莓  阅读(24)  评论(0)    收藏  举报