2.  启动容器:
  1. 启动(docker run)
docker run [OPTIONS] IMAGE [COMMAND] [ARG...]
# 解释:【docker run  设置项   镜像名  】 镜像启动运行的命令(镜像里面默认有的,一般不会写)
# 例:docker run --name=mynginx -d --restart=always -p  88:80 nginx
   # --name=mynginx设置名字
   # -d:后台运行
   # --restart=always: 开机自启
   # -p  88:80 把主机的88端口转到80端口

# 启动nginx应用容器,真正的运行起来;并映射88端口,测试的访问

2.停止运行

# 停止容器
docker stop 容器id/名字
# 再次启动
docker start 容器id/名字

3.查看正在运行的容器

docker ps

4. 查看docker运行的和停止的容器

docker ps -a

5.删除(docker rmdocker )

# 删除停止的容器
docker rm  容器id/名字
# 强制删除正在运行中的
docker rm -f mynginx

6.补充

# 如果才开始没有设置开机自启怎么办?更新一下设置项
docker update 容器id/名字 --restart=always
3. 修改容器内容:修改默认的index.html 页面

方法1:进入到容器里去修改

1.通过公网IP192.168.2.129,88端口去访问nginx

docker基于Django的博客系统_学习

2.  修改默认的index.html 页面

进入容器内部修改

# 进入容器内部的系统,修改容器内容
docker exec -it 容器id  /bin/bash
  # -it表示已交互模式进入容器
  #  /bin/bash 进入容器的bash控制台(相当于linux下的另一个小型linux环境)

cd /usr/share/nginx/html #然后ls,里面有一个index.html
echo "<h1>Welcome to China</h1>"  > index.html #<h1></h1>表示标题
# 改好页面以后,exit就可以退出!

docker基于Django的博客系统_学习_02

通过公网IP192.168.2.129,88端口去访问nginx,就会发现页面修改成功

docker基于Django的博客系统_大数据_03

方法2:命令挂载:在主机外面修改

1.把容器里的目录与当前目录建立起链接

docker run --name=mynginx -d --restart=always -p  88:80 \
-v /data/html:/usr/share/nginx/html :ro nginx
# -v 后面表示把主机的目录挂载到容器里的目录,和端口的方式很相似;
# /data/html主机目录
# /usr/share/nginx/html容器目录 
# ro 表示容器里不能改,只能在容器外进行更改

docker基于Django的博客系统_面试_04

2.此时cd /data/html页面,ls里面什么都没有;因为主机是空的,容器也是空

docker基于Django的博客系统_docker_05

3.然后进行追加修改,生成一个index.html页面

docker基于Django的博客系统_大数据_06

4.此时再去访问,也可以做到修改

docker基于Django的博客系统_面试_07

4.提交改变:将自己修改好的镜像提交
docker commit [OPTIONS] CONTAINER [REPOSITORY[:TAG]]
  1. 通过docker commit --help查看帮助文档

docker基于Django的博客系统_学习_08

2. 提交并设置

docker基于Django的博客系统_大数据_09

3. 生成一个新的镜像zlnginx

docker基于Django的博客系统_大数据_10

4.以后访问页面,要想访问原来的页面,就启动原来的镜像nginx;要想访问新的页面就启动zlnginx镜像

5. 如何把修改好的镜像(zlnginx)传输到一台新的服务器?

方法1:打成压缩包

1.物理传输:打成压缩包

docker save -o zlnginx.tar zlnginx:v1
# -o 表示指定的压缩包名字,名字是以.tar结尾的压缩包文件

docker基于Django的博客系统_大数据_11

2.把压缩包传到机器上后,然后加载

docker load -i zlnginx.tar
# -i 表示后面跟的是要加载的镜像压缩包名

3.此时在docker images就可以看到zlnginx镜像了!

方法2:推送到远程仓库(docker hub),镜像推送

1.需要先注册登录docker hub

docker基于Django的博客系统_面试_12

2. 创建一个仓库(create a Repository)

docker基于Django的博客系统_学习_13

3.creat创建以后得到以下界面

docker基于Django的博客系统_docker基于Django的博客系统_14

4.根据提示,把新的镜像推送到仓库,注意要带上名字

4.1 先把旧镜像的名字,改成仓库要求的新版本名字

docker tag local-image:tagname new-repo:tagname
# local-image:tagname,本地的镜像和标签,这里就是:zlnginx和v1
#  new-repo:tagname,新的名字和版本号,例如:zznginx.v1


![img]()
![img]()