Docker如何解决依赖的兼容问题?
因为打包程序时,肯定是在同一个系统中打包的,那对于不同环境的操作系统,Dcoker如何解决?
首先看一下操作系统的结构:
那Dcoker如何解决不同系统环境的问题?
虚拟机先启动一个操作系统,然后再操作系统之上再启动应用。
Docker直接启动应用。
总结来说,两者差异如下:
这样可以保证镜像文件不被污染,以供其他容器使用,那镜像文件如何做共享呢?
dockerHub官方网站为:hub.docker.com
因为Docker需要用到各种端口,逐一修改防火墙太麻烦,所以在学习阶段直接关闭防火墙,命令如下:
还可以使用如下命令查看防火墙状态,可以看到,防火墙已经关闭
systemctl status firewalld
启动Docker,可以使用命令查看启动状态,也可以通过查看版本的方式,看docker是否启动成功
systemctl start docker // 启动docker
systemctl status docker // 查看docker状态
docker -v // 查看docker版本
首先来看下镜像的名称组成:
进入帮助文档,使用如下命令:
docker --help // 查看所有命令
docker images --help // 查看镜像的相关命令
docker pull nginx // 默认从官网拉取最新的镜像
docker images // 查看拉取到的镜像,如查看images镜像
(1)利用docker xx --help命令查看docker save和docker load的语法,例如,查看save命令用法,可以输入命令:
docker save --help
docker save -o [保存的目标文件名称] [镜像名称]
(2)导出镜像
运行命令:
docker save -o nginx.tar nginx:latest
结果如图:
(3)加载镜像
先删除本地的nginx镜像:
docker rmi nginx:latest
然后运行命令,加载本地文件:
docker load -i nginx.tar
结果:
容器包括三个状态:
创建并运行nginx容器的命令:
docker run --name containerName -p 80:80 -d nginx
命令解读:
这里的-p
参数,是将容器端口映射到宿主机端口。
默认情况下,容器是隔离环境,我们直接访问宿主机的80端口,肯定访问不到容器中的nginx。
现在,将容器的80与宿主机的80关联起来,当我们访问宿主机的80端口时,就会被映射到容器的80,这样就能访问到nginx了:
docker logs // 可以查看日志
docker logs -f mn // 可以进行日志追踪,其中 mn是容器名称
步骤:
1)进入容器。进入我们刚刚创建的nginx容器的命令为:
docker exec -it mn bash
命令解读:
docker exec :进入容器内部,执行一个命令
-it : 给当前进入的容器创建一个标准输入、输出终端,允许我们与容器交互
mn :要进入的容器的名称
bash:进入容器后执行的命令,bash是一个linux终端交互命令
2)进入nginx的HTML所在目录 /usr/share/nginx/html
容器内部会模拟一个独立的Linux文件系统,看起来如同一个linux服务器一样:
nginx的环境、配置、运行文件全部都在这个文件系统中,包括我们要修改的html文件。
查看DockerHub网站中的nginx页面,可以知道nginx的html目录位置在/usr/share/nginx/html
我们执行命令,进入该目录:
cd /usr/share/nginx/html
查看目录下文件:
3)修改index.html的内容
容器内没有vi命令,无法直接修改,我们用下面的命令来修改:
sed -i -e 's#Welcome to nginx#传智教育欢迎您#g' -e 's###g' index.html
在之前的nginx案例中,修改nginx的html页面时,需要进入nginx内部。并且因为没有编辑器,修改文件也很麻烦。
这就是因为容器与数据(容器内文件)耦合带来的后果。
要解决这个问题,必须将数据与容器解耦,就要用到数据卷。
数据卷(volume)是一个虚拟目录,指向宿主机文件系统中的某个目录。
一旦完成数据卷挂载,对容器的一切操作都会作用在数据卷对应的宿主机目录了。
这样,我们操作宿主机的/var/lib/docker/volumes/html目录,就等于操作容器内的/usr/share/nginx/html目录了
数据卷操作的基本语法如下:
docker volume [COMMAND]
docker volume命令是数据卷操作,根据命令后跟随的command来确定下一步的操作:
① 创建数据卷
docker volume create html
② 查看所有数据
docker volume ls
结果:
③ 查看数据卷详细信息卷
docker volume inspect html
结果:
数据卷的作用:
数据卷操作:
步骤:
① 创建容器并挂载数据卷到容器内的HTML目录
docker run --name mn -v html:/usr/share/nginx/html -p 80:80 -d nginx
② 进入html数据卷所在位置,并修改HTML内容
# 查看html数据卷的位置
docker volume inspect html
# 然后进入该目录
cd /var/lib/docker/volumes/html/_data
# 修改文件
vi index.html
容器不仅仅可以挂载数据卷,也可以直接挂载到宿主机目录上。关联关系如下:
目录挂载与数据卷挂载的语法是类似的:
docker run的命令中通过 -v 参数挂载文件或目录到容器中:
数据卷挂载与目录直接挂载的对比
为什么分层?方便复用,比如部署5.8等
Dockerfile就是一个文本文件,其中包含一个个的指令(Instruction),用指令来说明要执行什么操作来构建镜像。每一个指令都会形成一层Layer。
镜像仓库(Docker Registry)有公共的和私有的两种形式:
●公共仓库:例如Docker官方的Docker Hub,国内也有一些云服务商提供类似于Docker Hub的公开服务,比如网易云镜像服务、Daocloud镜像服务、阿里云镜像服务等。
●除了使用公开仓库外,用户还可以在本地搭建私有Docker Registry。企业自己的镜像最好是采用私有Docker Registry:来实现。
搭建镜像仓库可以基于Docker官方提供的DockerRegistry来实现。
官网地址:https:/hub.docker.com//registry.
systemctl start docker
systemctl stop docker
systemctl restart docker
systemctl status docker
docker version
docker info
6.docker帮助命令
docker --help
比如忘记了拉取命令需要带哪些参数,可以查看用上面的命令查看‘’
docker pull --help
docker images
docker pull 镜像名
docker pull 镜像名:tag
docker run 镜像名
docker run 镜像名:Tag
#删除一个
docker rmi -f 镜像名/镜像ID
#删除多个 其镜像ID或镜像用用空格隔开即可
docker rmi -f 镜像名/镜像ID 镜像名/镜像ID 镜像名/镜像ID
#删除全部镜像 -a 意思为显示全部, -q 意思为只显示ID
docker rmi -f $(docker images -aq)
docker image rm 镜像名称/镜像ID
docker ps
docker ps -a
# -it 表示 与容器进行交互式启动 -d 表示可后台运行容器 (守护式运行) --name 给要运行的容器 起的名字 /bin/bash 交互路径
docker run -it -d --name 要取的别名 镜像名:Tag /bin/bash
# 示例:
docker run -it -d --name redis001 redis:5.0.5 /bin/bash
docker logs -f --tail=要查看末尾多少行 默认all 容器ID
部分docker命令的内容参考自以下链接:https://blog.csdn.net/leilei1366615/article/details/106267225