docker技术是一个容器和虚拟机具有相似的资源隔离和分配优势,但功能有所不同,虚拟机虚拟化的是硬件,而容器虚拟化的是操作系统,因此容器更容易移植,效率也更高。
docker技术的特点:
(1)上手快
用户只需要几分钟,就可以把自己的程序“Docker化”。Docker依赖于“写时复制”(copy-on-write)模型,使修改应用程序也非常迅速,可以说达到“随心所致,代码即改”的境界。
随后,就可以创建容器来运行应用程序了。大多数Docker容器只需要不到1秒中即可启动。由于去除了管理程序的开销,Docker容器拥有很高的性能,同时同一台宿主机中也可以运行更多的容器,使用户尽可能的充分利用系统资源。
(2)职责的逻辑分类
使用Docker,开发人员只需要关心容器中运行的应用程序,而运维人员只需要关心如何管理容器。Docker设计的目的就是要加强开发人员写代码的开发环境与应用程序要部署的生产环境一致性。从而降低那种“开发时一切正常,肯定是运维的问题(测试环境都是正常的,上线后出了问题就归结为肯定是运维的问题)”
(3)快速高效的开发生命周期
Docker的目标之一就是缩短代码从开发、测试到部署、上线运行的周期,让你的应用程序具备可移植性,易于构建,并易于协作。(通俗一点说,Docker就像一个盒子,里面可以装很多物件,如果需要这些物件的可以直接将该大盒子拿走,而不需要从该盒子中一件件的取。)
(4)鼓励使用面向服务的架构
Docker还鼓励面向服务的体系结构和微服务架构。Docker推荐单个容器只运行一个应用程序或进程,这样就形成了一个分布式的应用程序模型,在这种模型下,应用程序或者服务都可以表示为一系列内部互联的容器,从而使分布式部署应用程序,扩展或调试应用程序都变得非常简单,同时也提高了程序的内省性。(当然,可以在一个容器中运行多个应用程序)
39.docekr的常用的指令
操作docker容器集合的指令:
-
l 启动docker:systemctl start docker
-
l 停止docker:systemctl stop docker
-
l 重启docker:systemctl restart docker
-
l 查看docker状态:systemctl status docker
-
l 开机启动:systemctl enable docker
操作docker中的镜像的常用的操作的命令:
-
l 查看本地的镜像:docker images
-
l 查询搜索注册中心中的镜像:docker search 镜像名称
-
l 镜像的拉取与下载:docker pull 镜像的名字
-
l 删除指定的镜像:docker rmi 镜像编号(image id)/镜像名字:版本标记
-
l 删除所有的镜像:docker rmi
docker images -q
Container容器的常用的操作:
-
l 查看正在运行的容器:docker ps
-
l 查看所有的容器(包括运行和关闭的):docker ps -a
-
l 查看最后一次运行的容器信息:docker ps -l
-
l 查看停止了的容器列表:docker ps -f status=exited
-
l 停止一个正在运行的容器(守护式容器):docker stop $CONTAINER_NAME(容器的名称)/ID(编号)
-
| 启动一个已经运行过的容器: docker start $CONTAINER_NAME(容器的名称)/ID(编号)
-
| 重启一个容器:docker restart $CONTAINER_NAME(容器的名称)/ID(编号)
l 创建一个交互式的容器:docker run -it --name=mycentos centos:7.5.1804 /bin/bash
交互式容器的优点:
创建完容器后,自动运行容器,并可以直接进入到子容器系统中操作了。
缺点:
当退出子容器后,该容器会自动停止运行。
| 创建一个守护式的容器: docker run -id --name=mycentos2 centos:7.5.1804 或 docker run -id --name mycentos2 centos:7.5.1804
l 登录守护式容器的方法:docker exec -it container_name (或者 container_id) /bin/bash(exit退出时,容器不会停止)
守护式容器的优点:
从守护式容器中退出,并不影响容器的运行。
缺点:
必须的手动命令进入到容器。