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

浙公网安备 33010602011771号