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