docker常用命令整理

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

删除虚悬镜像:
docker image prune

2、容器操作相关命令

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

# 进入容器内部的系统,修改容器内容
docker exec -it 容器id  /bin/bash

# 拷贝容器中的文件和目录
拷贝单个文件
docker cp dc47:/tmp/1.txt /root/mytmp
拷贝整个目录
docker cp dc47:/tmp/ /root/mytmp

# 备份整个容器并启用备份的容器
备份:
docker export dc47 > ubuntu.tar

导入docker:
[root@docker01 docker-tmp]# cat ubuntu.tar | docker import - myubuntu:1.0
sha256:ca51d4b327c0781974b9aedf6d67077991d991b9dfe126f38060900a16b951a5
[root@docker01 docker-tmp]# docker images
REPOSITORY   TAG       IMAGE ID       CREATED         SIZE
myubuntu     1.0       ca51d4b327c0   5 seconds ago   72.8MB

启用:
docker run -it myubuntu:1.0 /bin/bash

3、容器数据卷相关命令

docker run --name=mynginx   \
-d  --restart=always \
-p  88:80 -v /data/html:/usr/share/nginx/html:ro  \
nginx

# 修改页面只需要去 主机的 /data/html

4、保存自己的容器

docker commit [OPTIONS] CONTAINER [REPOSITORY[:TAG]]

docker commit -a "leifengyang"  -m "首页变化" 341d81f7504f guignginx:v1.0

5、镜像传输

# 将镜像保存成压缩包
docker save -o abc.tar guignginx:v1.0

#  离线安装,别的机器加载这个镜像
docker load -i abc.tar

6、通过dockerfile构建自定义镜像

案例1:
FROM java:8
MAINTAINER itheima	<pzj@qq.com>
ADD springboot-hello-0.0.1-SNAPSHOT.jar app.jar
CMD java -jar app.jar

案例2:
FROM centos:7
MAINTAINER itheima	<pzj@qq.com>

RUN yum install -y vim
WORKDIR	/usr
CMD	/bin/bash

上面是两个dockerfile的内容

然后,构建命令如下:
docker build -f ./centos7_dockerfile -t mycentos7:v1.0 .

7、镜像仓库相关操作

docker tag local-image:tagname new-repo:tagname
docker push new-repo:tagname

# 把旧镜像的名字,改成仓库要求的新版名字
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

# 私服仓库搭建
下载镜像
docker pull registry

启动
docker run -d -p 5000:5000 -v /root/docker-tmp/images:/tmp/registry --privileged=true registry

访问
http://192.168.31.10:5000/v2/_catalog
{repositories: [ ]}

向私服推送自己的镜像
1、tag
docker tag myubuntu:1.2 192.168.31.10:5000/myubuntu:1.2

2、取消docker不允许http方式推送镜像的限制,修改配置后重启
vim /etc/docker/daemon.json
{
  "registry-mirrors": ["https://aa25jngu.mirror.aliyuncs.com"],
  "insecure-registries": ["192.168.31.10:5000"]
}
systemctl restart docker

3、推送自己的镜像
docker push 192.168.31.10:5000/myubuntu:1.2

4、从私服拉取镜像
docker pull 192.168.31.10:5000/myubuntu:1.2

8、容器操作的补充

docker logs 容器名/id   排错

docker exec -it 容器id /bin/bash

# docker 经常修改nginx配置文件
docker run -d -p 80:80 \
-v /data/html:/usr/share/nginx/html:ro \
-v /data/conf/nginx.conf:/etc/nginx/nginx.conf \
--name mynginx-02 \
nginx

#把容器指定位置的东西复制出来 
docker cp 5eff66eec7e1:/etc/nginx/nginx.conf  /data/conf/nginx.conf
#把外面的内容复制到容器里面
docker cp  /data/conf/nginx.conf  5eff66eec7e1:/etc/nginx/nginx.conf

9、实战案例
1、Nginx相关

docker run --name=mynginx -d --restart=always -p 80:80 1e0667b5a7ca
docker exec -it 676c2800bf32  /bin/bash
docker commit -a "hapdog"  -m "首页变化" 676c2800bf32 pzj_nginx:v1.0
docker tag pzj_nginx:v1.0 hapdog/pzj_nginx:v1.0

docker run --name=mynginx   \
-d  --restart=always \
-p  80:80 \
-v /opt/docker/nginx/data/html:/usr/share/nginx/html:ro  \
-v /opt/docker/nginx/nginx.conf:/etc/nginx/nginx.conf:ro  \
1e0667b5a7ca

2、Redis相关

docker run -v /opt/docker/redis/conf/redis.conf:/usr/local/etc/redis/redis.conf \
-v /opt/docker/redis/data:/data \
--name myredis \
-d -p 6379:6379 \
redis:latest \
redis-server /usr/local/etc/redis/redis.conf

redis.conf

# Redis配置文件
# Redis默认不是以守护进程的方式运行,可以通过该配置项修改,使用yes启用守护进程
daemonize no
# 指定Redis监听端口,默认端口为6379
port 6379
# 绑定的主机地址,不要绑定容器的本地127.0.0.1地址,因为这样就无法在容器外部访问
bind 0.0.0.0
#需要密码则打开
requirepass mima
# 持久化
appendonly yes
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值