开发常用命令合集(Docker、K8s、Linux、Windows等)
1 Docker
详情查看:https://blog.csdn.net/weixin_45565886/article/details/130130361
1.1 基础命令
①拉取、查看、删除镜像
docker pull nginx #下载最新版
镜像名:版本名(标签)
docker pull nginx:1.20.1
docker pull redis #下载最新
docker pull redis:6.2.4
## 下载来的镜像都在本地
docker images #查看所有镜像
redis = redis:latest
docker rmi 镜像名:版本号/镜像id
案例:
# 1. 拉取镜像
docker pull nginx:1.20.1
# 2. 查看本地镜像
docker images
②运行、查看、停止容器
docker run [OPTIONS] IMAGE [COMMAND] [ARG...]
【docker run 设置项 镜像名 】 镜像启动运行的命令(镜像里面默认有的,一般不会写)
# -d:后台运行
# --restart=always: 开机自启
docker run --name=mynginx -d --restart=always -p 88:80 nginx
# 查看正在运行的容器
docker ps
# 查看所有
docker ps -a
# 删除停止的容器
docker rm 容器id/名字
docker rm -f mynginx #强制删除正在运行中的
#停止容器
docker stop 容器id/名字
#再次启动
docker start 容器id/名字
#应用开机自启
docker update 容器id/名字 --restart=always
案例:
# -d 后台启动
# --restart=always 开机自启
# -p 88:80 将宿主机的88端口映射到nginx容器的80端口
# --name=mynginx 指定启动之后的容器名为mynginx
# nginx:1.20.1 启动版本号为1.20.1的nginx
docker run -d --restart=always -p 88:80 --name=mynginx nginx:1.20.1
③进入容器内部
# 进入容器内部修改[有些可能不是bash是sh,需灵活变化]
# -it 表示进入交互页面
#nginx容器可以当做一个小型的linux,然后里面运行了nginx
docker exec -it 容器id /bin/bash
案例:修改nginx的默认首页
docker ps,查看正在运行的nginx镜像,获取容器id
docker exec -it bcb /bin/bash,进入nginx交互页面
进入nginx的首页
cd /usr/share/nginx/html
修改首页内容:
echo "this is ziyi's pages, elcomclear > index.html
查看结果:你的ip+映射端口(宿主机的)
退出交互页面
exit
1.2 进阶操作
①挂载容器数据到外部
docker run --name=mynginx \
-d --restart=always \
-p 88:80 -v /data/html:/usr/share/nginx/html:ro \
nginx
# 修改页面只需要去 主机的 /data/html
# -v 挂载
/*
/data/html:/usr/share/nginx/html:ro
将容器中的/usr/share/nginx/html挂载到宿主机的/data/html目录,ro表示read only只读
nginx代表nginx:latest镜像名
*/
指定nginx版本
docker run -d -p 88:80 -v /data/html:/usr/share/nginx/html --restart=always --name=mynginx nginx:1.20.1
②提交改变
我们修改了容器中的内容之后,想要打包交给其他电脑去运行,此时就需要将我们修改好之后的镜像进行提交
- 提交修改
# docker commit [OPTIONS] CONTAINER [REPOSITORY[:TAG]]
# -a "ziyi" 指明是谁修改的
# -m "首页变化" 指明做了什么
# 341d81f7504f guignginx:v1.0 指明哪个容器的修改了以及新容器的版本号
docker commit -a "ziyi" -m "首页变化" 341d81f7504f guignginx:v1.0
- 压缩镜像并传输
# 将镜像保存成压缩包
docker save -o abc.tar nginx:v1.0
# 可以通过scp命令远程传输到指定服务器的指定文件夹下
# 别的机器加载这个镜像
docker load -i abc.tar
# 离线安装
③推送到远程hub
- 注册并登录自己的dockerhub账号
# 登录docker hub,输入命令然后输入自己用户名与密码
docker login
- 打包本地镜像
# 打包本地镜像
# 把旧镜像的名字,改成仓库要求的新版名字
docker tag nginx:v1.0 ziyigun/nginx:v1.0
综合命令:
# 把旧镜像的名字,改成仓库要求的新版名字
docker tag guignginx:v1.0 leifengyang/guignginx:v1.0
# 登录到docker hub
docker login
docker logout(推送完成镜像后退出)
# 推送
docker push leifengyang/guignginx:v1.0
# 别的机器下载
docker pull leifengyang/guignginx:v1.0
2 K8s
# 查看持续查看workflow的pod日志
kubectl logs workflow-9c6468cb7-f4d6x -n xxx -f --tail=1
# 进入容器内容 -n xxx 指定命名空间
kubectl exec -it -n xxx compression-apk-v1-label-2-66bc688cf4-zgvvr -- sh
# kubectl exec -n ocpf-plugin pod-name -it -- /bin/bash
# -r 支持转义
kubectl logs -n ocpf s3batch-6697bb767f-lr7zx | less -r
# 查询错误,通过/查询包含ERROR
# /ERROR
# 获取xxx命名空间下的deployment【pod、svc同理】
kubectl get deployment -n xxx
# 删除xxx命名空间下名为delpoymentName的deployment【pod、svc同理】
kubectl delete deployment delpoymentName -n xxx
详情见:https://blog.csdn.net/weixin_45565886/article/details/130698024
2.1 基础命令
①deployment根据Pod的标签关联到Pod,是为了管理pod的生命周期
②service根据Pod的标签关联到pod,是为了让外部访问到pod,给pod做负载均衡
- 需要注意:
deployment控制器关联的Pod,Pod的name和hostname(如果不手动指定)就是deployment控制器的Name
StatefulSet控制器关联的Pod,Pod的Name和Hostname(如果不手动指定)就是StatefulSet控制器的Name + 序号
①基础命令(pod等)
命令 | 含义 | 示例 |
---|---|---|
kubectl run 容器名 --image=容器地址:版本 | 通过命令部署容器 | kubectl run testapp --image=ccr.ccs.tencentyun.com/k8s-tutorial/test-k8s:v1 |
kubectl apply -f xxx.yaml | 通过配置文件部署 | kubectl apply -f app.yaml |
kubectl describe pod pod-name | 查看pod详情信息 | kubectl describe pod test-k8s-8598bbb8c6-62c8m |
kubectl logs pod-name | 查看pod日志(-f 持续查看日志) | kubectl logs test-k8s-8598bbb8c6-ngmw9 |
kubectl exec -it pod-name – bash | 进入pod容器内部(-c参数可指定进入哪个容器) | kubectl exec -it test-k8s-8598bbb8c6-knztk – bash |
②Deployment
配置文件:
app.yml:
apiVersion: apps/v1
# 表示类型为Deployment
kind: Deployment
metadata:
# 部署名字
name: test-k8s
spec:
replicas: 5
# 用来查找关联的 Pod,所有标签都匹配才行
selector:
matchLabels:
app: test-k8s
# 定义 Pod 相关数据
template:
metadata:
labels:
# 标签
app: test-k8s
spec:
# 定义容器,可以多个【这一部分就是上面的单个pod】
containers:
- name: test-k8s # 容器名字【需要与labels对应】
image: ccr.ccs.tencentyun.com/k8s-tutorial/test-k8s:v1 # 镜像[上传到了腾讯云]
命令 | 含义 | 示例 |
---|---|---|
kubectl scale deployment deploymentName --replicas=xx | 指定deployment副本数 | kubectl scale deploymnet test-k8s --replicas=5 |
kubectl apply -f xxx.yaml | 修改配置文件来重新部署 | 可修改replicas等参数 |
kubectl port-forward pod-name port:containerPort | 将外面端口映射到容器内部 | kubectl port-forward test-k8s-8598bbb8c6-2ff7w 8090:8080 |
kubectl rollout history deployment deployment-name | 将部署回退到上一个版本 | kubectl rollout history deployment test-k8s |
kubectl rollout undo deployment deployment-name --to-revision=2 | 回退到指定版本 | kubectl rollout undo deployment test-k8s --to-revision=2 |
kubectl delete deployment deployment-name | 删除部署 | kubectl delete deployment test-k8s |
③Service
配置文件:
service.yaml
apiVersion: v1
kind: Service
metadata:
name: test-k8s
spec:
selector:
app: test-k8s
type: ClusterIP # 默认
ports:
- port: 8080 # 本 Service 的端口
targetPort: 8080 # 容器端口
应用配置文件:
# 应用配置
kubectl apply -f service.yaml
命令 | 含义 | 示例 |
---|---|---|
kubectl get svc | 查看service服务 | kubectl get svc test-k8s |
kubectl describe svc service-name | 查看服务详情 | kubectl describe svc test-k8s |
④StatefulSet
StatefulSet是用来管理有状态的应用,例如数据库。
前面我们部署的应用,都是不需要存储数据,不需要记住状态的,可以随意扩充副本,每个副本都是一样的,可以替代的。
- 但是像数据库、Redis这类有状态的,则不能随意扩充副本
- StatefulSet会固定每个Pod的名字,但是Pod的IP不固定
mongo.yaml
apiVersion: apps/v1
kind: StatefulSet
metadata:
name: mongodb
spec:
serviceName: mongodb
replicas: 3
selector:
matchLabels:
app: mongodb
template:
metadata:
labels:
app: mongodb
spec:
containers:
- name: mongo
image: mongo:4.4
# IfNotPresent 仅本地没有镜像时才远程拉,Always 永远都是从远程拉,Never 永远只用本地镜像,本地没有则报错
imagePullPolicy: IfNotPresent
---
apiVersion: v1
kind: Service
metadata:
name: mongodb
spec:
selector:
app: mongodb
type: ClusterIP
# HeadLess
clusterIP: None
ports:
- port: 27017
targetPort: 27017
⑤Configmap & Secret
⑥Helm & namespace
2.2 进阶命令
3 Linux
3.1 创建和编译代码
mkdir myproject
cd myproject
git clone <repository_url>
cd <repository_name>
make
# mkdir myproject:创建一个名为myproject的目录。
# cd myproject:进入myproject目录。
# git clone <repository_url>:从远程仓库克隆代码到当前目录。
# cd <repository_name>:进入克隆的代码仓库目录。
# make:执行Makefile中的编译命令,编译代码。
3.2 安装和管理依赖包
sudo apt-get update
sudo apt-get install <package_name>
#sudo apt-get update:更新可用的软件包列表。
#sudo apt-get install <package_name>:安装指定的软件包。
3.3 运行和调试命令
./myprogram
gdb myprogram
# ./myprogram:运行名为myprogram的可执行文件。
# gdb myprogram:使用GDB调试器来调试myprogram程序。
3.4 查看日志和输出
tail -f <log_file>
grep <pattern> <file>
# tail -f <log_file>:实时查看日志文件的最新内容。
# grep <pattern> <file>:在文件中查找匹配指定模式的行。
3.5 版本控制和代码管理
git init
git add .
git commit -m "Initial commit"
git push origin master
# git init:初始化一个新的Git仓库。
# git add .:将当前目录下的所有文件添加到Git仓库。
# git commit -m "Initial commit":提交代码更改,并添加提交消息。
# git push origin master:将本地代码推送到远程仓库的master分支。
其他高级用法
# 搜索workflow.log中包含2022的字符,并通过管道符转换到more中
grep "2022" workflow.log | more
4 Windows
详情查看:https://editor.csdn.net/md/?articleId=127912183