Docker
Docker简介
什么是虚拟化
在计算机中,虚拟化(英语:Virtualization)是一种资源管理技术,是将计算机的各种实体资源,如服务器、网络、内存及存储等,予以抽象、转换后呈现出来,打破实体结构间的不可切割的障碍,使用户可以比原本的组态更好的方式来应用这些资源。这些资源的新虚拟部份是不受现有资源的架设方式,地域或物理组态所限制。一般所指的虚拟化资源包括计算能力和资料存储。
在实际的生产环境中,虚拟化技术主要用来解决高性能的物理硬件产能过剩和老的旧的硬件产能过低的重组重用,透明化底层物理硬件,从而最大化的利用物理硬件 对资源充分利用
虚拟化技术种类很多,例如:软件虚拟化、硬件虚拟化、内存虚拟化、网络虚拟化(vip)、桌面虚拟化、服务虚拟化、虚拟机等等。
什么是Docker
Docker 是一个开源项目,诞生于 2013 年初,最初是 dotCloud 公司内部的一个业余项目。它基于 Google 公司推出的 Go 语言实现。 项目后来加入了 Linux 基金会,遵从了 Apache 2.0 协议,项目代码在 GitHub 上进行维护。
为什么选择docker?
(1)上手快。
(2)职责的逻辑分类
(3)快速高效的开发生命周期
(4)鼓励使用面向服务的架构
Docker的目标之一就是缩短代码从开发、测试到部署、上线运行的周期,让你的应用程序具备可移植性,易于构建,并易于协作。(通俗一点说,Docker就像一个盒子,里面可以装很多物件,如果需要这些物件的可以直接将该大盒子拿走,而不需要从该盒子中一件件的取。)
容器与虚拟机比较
下面的图片比较了 Docker 和传统虚拟化方式的不同之处,可见容器是在操作系统层面上实现虚拟化,直接复用本地主机的操作系统,而传统方式则是在硬件层面实现。与传统的虚拟机相比,Docker优势体现为启动速度快、占用体积小。
Docker的优点
1、更快速的交付和部署
对开发和运维人员来说,最希望的就是一次创建或配置,可以在任意地方正常运行。
开发者可以使用一个标准的镜像来构建一套开发容器,开发完成之后,运维人员可以直接使用这个容器来部署代码。 Docker 可以快速创建容器,快速迭代应用程序,并让整个过程全程可见,使团队中的其他成员更容易理解应用程序是如何创建和工作的。 Docker 容器很轻很快!容器的启动时间是秒级的,大量地节约开发、测试、部署的时间。
2、更高效的虚拟化
Docker 容器的运行不需要额外的 hypervisor 支持,它是内核级的虚拟化,因此可以实现更高的性能和效率。
3、更轻松的迁移和扩展
Docker 容器几乎可以在任意的平台上运行,包括物理机、虚拟机、公有云、私有云、个人电脑、服务器等。 这种兼容性可以让用户把一个应用程序从一个平台直接迁移到另外一个。
4、更简单的管理
使用 Docker,只需要小小的修改,就可以替代以往大量的更新工作。所有的修改都以增量的方式被分发和更新,从而实现自动化并且高效的管理。
Docker 组件
Docker服务器与客户端
Docker是一个客户端-服务器(C/S)架构程序。Docker客户端只需要向Docker服务器或者守护进程发出请求,服务器或者守护进程将完成所有工作并返回结果。Docker提供了一个命令行工具Docker以及一整套RESTful API。你可以在同一台宿主机上运行Docker守护进程和客户端,也可以从本地的Docker客户端连接到运行在另一台宿主机上的远程Docker守护进程。
Docker镜像与容器
镜像是构建Docker的基石。用户基于镜像来运行自己的容器。镜像也是Docker生命周期中的“构建”部分。镜像是基于联合文件系统的一种层式结构,由一系列指令一步一步构建出来。例如:
添加一个文件;
执行一个命令;
打开一个窗口。
也可以将镜像当作容器的“源代码”。镜像体积很小,非常“便携”,易于分享、存储和更新。
Docker可以帮助你构建和部署容器,你只需要把自己的应用程序或者服务打包放进容器即可。容器是基于镜像启动起来的,容器中可以运行一个或多个进程。我们可以认为,镜像是Docker生命周期中的构建或者打包阶段,而容器则是启动或者执行阶段。 容器基于镜像启动,一旦容器启动完成后,我们就可以登录到容器中安装自己需要的软件或者服务。
所以Docker容器就是:
一个镜像格式;
一些列标准操作;
一个执行环境。
Docker借鉴了标准集装箱的概念。标准集装箱将货物运往世界各地,Docker将这个模型运用到自己的设计中,唯一不同的是:集装箱运输货物,而Docker运输软件。
和集装箱一样,Docker在执行上述操作时,并不关心容器中到底装了什么,它不管是web服务器,还是数据库,或者是应用程序服务器什么的。所有的容器都按照相同的方式将内容“装载”进去。
Docker也不关心你要把容器运到何方:我们可以在自己的笔记本中构建容器,上传到Registry,然后下载到一个物理的或者虚拟的服务器来测试,在把容器部署到具体的主机中。像标准集装箱一样,Docker容器方便替换,可以叠加,易于分发,并且尽量通用。
简单的理解就是镜像和容器的关系相当于面向对象中类和对象的关系。
Docker的各种操作命令简单总结
-docker安装
-yum install -y yum-utils device-mapper-persistent-data lvm2
-yum install docker-ce
-命令
-docker -v 查看客户端版本号
-docker装完,需要手动吧服务
-启动:systemctl start docker(启动)
-重启:systemctl restart docker
-停止:systemctl stop docker
-镜像相关:
-查看镜像:docker images (记住)
-搜索镜像:docker search 镜像名称 在远程搜
-拉取镜像:docker pull 镜像名称(记住)
-删除镜像:docker rmi 镜像ID
-容器相关:
-查看正在运行的容器:docker ps docker ps -a
-停止容器: docker stop 容器id
-创建与启动容器
-docker run -it --name=容器名称 镜像名称:标签 /bin/bash 创建并进入容器内部
-docker run -di --name=容器名称 镜像名称:标签 创建,不进入容器内部
-docker exec -it 容器名称 (或者容器ID) /bin/bash 进入容器内部
-容器启动停止 docker stop/start 容器名称(或者容器ID)
-文件拷贝:docker cp 需要拷贝的文件或目录 容器名称:容器目录
-目录挂载:
-docker run -di -v /home:/home --name=mycentos3 centos:7
--查看容器信息
-docker inspect 容器名称(容器ID)
-删除容器
-docker rm 容器名字
-应用部署
-部署mysql
-docker run -di --name=mysql1 -p 33306:3306 -e MYSQL_ROOT_PASSWORD=123456 mysql
-迁移
-启动一个python容器
-docker run -di --name=mypython python:3.6.9-alpine
-把容器打包成镜像
-docker commit 容器名字 镜像名字
-dockerfile
FROM python:3.6.9-alpine
MAINTAINER lqz
RUN pip install requests
-私有仓库
-拉取私有仓库镜像
-docker pull registry
-启动私有仓库容器
-docker run -di --name=registry -p 5000:5000 registry
-打开浏览器 输入地址http://192.168.1.12:5000/v2/_catalog看到{"repositories":[]}
表示私有仓库搭建成功并且内容为空
-修改daemon.json
-vi /etc/docker/daemon.json
添加以下内容,保存退出。
-{"insecure-registries":["192.168.1.12:5000"]} #此步用于让 docker信任私有仓库地址
-重启docker 服务
-systemctl restart docker
-镜像上传至私有仓库
- 标记此镜像为私有仓库的镜像
- docker tag django2.0 192.168.1.12:5000/django2.0
- 再次启动私服容器
- docker start registry
- 上传标记的镜像
- docker push 192.168.1.12:5000/django2.0