Docker概述和安装


typora-root-url: Docker图片

Docker学习

1,Docker简介

1.1什么是虚拟化

​ 在计算机中,虚拟化(英文:Virtualization)是一种资源管理技术,是将计算机的各种实体资源,如服务器、网络及内存等,予以抽象、转换后呈现出来,打破实体结构间的不可切割的障碍,使用户可以比原本的组态更好的方式来应用这些资源。这些资源的新虚拟部分是不受现有资源的架设方式、地域或物理组态所限制。一般所指的虚拟化资源包括计算能力和资料存储。

​ 在实际的生产环境中,虚拟化技术主要用来解决性能的物理硬件产能过剩和老的旧的硬件产能过低的重组重用问题,透明化底层物理硬件,从而最大化的利用物理硬件。对资源充分利用。

​ 虚拟化技术种类很多,如:软件虚拟化、硬件虚拟化、内存虚拟化、网络虚拟化、桌面虚拟化、服务虚拟化、虚拟机等。

1.2什么是Docker

​ Docker是一个开源项目,诞生于2013年,最初是 dotCloud公司内部的一个业余项目。它基于Google公司推出的Go语言实现。项目后来加入了Linux基金会,遵从了Apache2.0协议,项目代码在GitHub上进行维护。

Docker自开源后受到广泛的关注和讨论,以至于dotCloud公司后来改名为Docker Inc。Redhat已经在其RHEL6.5中集中支持Docker;Google也在其Paas产品中广泛应用。

Saas : software as service

Paas : platform as service 平台即服务

Iaas : 基础设施即服务

Baas: 后端即服务(delphi firemonkey)一套后台(c/s)管理àapk,ios 32 64

​ Docker项目的目标是实现轻量级的操作系统虚拟化解决方案。Docker的基础是Linux容器(LXC)等技术。

​ 在LXC的基础上Docker进行了进一步的封装,让用户不需要去关心容器的管理,使得操作更为简便。用户操作Docker的容器就像操作一个快速轻量级的虚拟机一样简单。

为什么选择Docker?

(1)上手快

用户只需要几分钟,就可以把自己的程序“Docker化”。Docker依赖于“写时复制”(copy-on-write)模型,使修改应用程序也非常迅速,可以说达到“随心所至,代码即改”的境界。

​ 随后,就可以创建容器来运行应用程序了。大多数Docker容器只需要不到一秒钟即可启动。由于去除了管理程序的开销,Docker容器拥有很高的性能,同时同一台宿主机中也可以运行更多的容器,使用户尽可能的充分利用系统资源。

(2)职责的逻辑分类

	使用Docker,开发人员只需要关心容器中运的行应用程序,而运维人员只需要关心如何管理容器。Docker设计的目的就是要加强开发人员写代码的开发环境与应用程序要部署的生产环境一致性。从而降低那种“开发时一切正常,肯定是运维的问题(测试环境都正常,上线后出了问题就归结为肯定是运维的问题)”

(3)快速高效的开发生命周期

​ Docker的目标之一就是缩短代码从开发、测试到部署、上线运行的周期,让你的应用程序具备可移植性,易于构建,并易于操作。(通俗的说,Docker就像一个盒子,里面可以装很多物件,如果需要这些物件的可以直接将该大盒子拿走,而不需要从盒子中一件一件的取)

(4)鼓励使用面向服务的架构 SOA

​ Docker还鼓励面向服务的体系结构和微服务架构。Docker推荐单个容器只允许一个应用程序或进程,这样就形成了一个分布式的应用程序模型,在这种模型下,应用程序或者服务都可以表示为一系列内部互联的容器,从而使分布式部署应用程序,扩展或调试应用程序都变得非常简单,同时也提高了程序的内省性。(当然,也可以在一个容器中运行多个应用程序)

1.3容器与虚拟机比较

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-E3iOiDEN-1622808900949)(/1620627153458.png)]

1.4Docker组件

1.41 Docker服务器与客户端

​ Docker是一个客户端-服务器(C/S)架构程序。Docker客户端只需要向Docker服务器或守护进程发出请求,服务器或者守护进程将完成所有工作并返回结果。Docker提供了一个命令行工具docker已经一整套RESTful API。可以在同一台宿主机上运行Docker守护进程和客户端,也可以从本地的Docker客户端连接到运行在另一台宿主机上的远程Docker守护进程。

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-LaYRDCWk-1622808900954)(/1620627289104.png)]

1.4.2 Docker镜像与容器

​ 镜像是构建Docker的基石。用户基于镜像来运行自己的容器。镜像也是Docker生命周期中的“构建”部分。镜像是基于联合文件系统的一种层式结构,由一系列指令一步一步构建出来。例如:

添加一个文件

执行一个命令;

打开一个窗口。

一个镜像可以当做容器的“源代码”。镜像体积很小,非常“便携”,易于分享、存储和更新。

​ Docker可以帮助我们构建和部署容器,我们只需要把自己的应用程序或者服务打包放进容器即可。容器是具有镜像启动起来的,容器中可以运行一个或多个进程。我们可以认为,镜像是Docker生命周期中的构建或者打包阶段,而容器则是启动或者执行阶段。容器基于镜像启动,一旦容器启动完成后,我们就可以登录到容器中安装自己需要的软件或者服务。

所以Docker容器就是:

一个镜像格式;

一系列标准操作;

一个执行环境。

​ Docker借鉴了标准集装箱的概念。标准集装箱将货物运往世界各地,Docker将这个模型运用到自己的设计中,唯一不同的是:集装箱运输货物,而Docker运输软件。

​ 和集装箱一样,Docker在执行上述操作时,并不关心容器中到底装了什么,它不管是web服务器还是数据库,或者是应用程序服务器什么的。所有的容器都按照相同的方式将内容“装载”进去。

​ Docker也不关心你要把容器运到何方:我们可以在自己的笔记本中构建容器,上传到Registry,然后下载到一个物理的或者虚拟的服务器来测试,再把容器部署到具体的主机中。像标准集装箱一样,Docker容器方便替换,可以叠加,易于分发,并且尽量通用。

1.4.3 Registry(注册中心)

​ Docker用Registry来保存用户构建的镜像。Registry分为公共和私有两种。Docker公司运营公共的Registry叫做Docker Hub。用户可以在Docker Hub注册账号,分享并保存自己的镜像(说明:在Docker Hub下载镜像非常慢,可以自己构建私有的Registry)

https://hub.docker.com

2,Docker的安装与启动1.1 安装Docker

​ Docker官方建议在Ubuntu中安装,因为Docker是基于Ubuntu发布的,而且一般Docker出现的问题Ubuntu是最新更新或者打补丁的。在很多版本的CentOS中是不支持更新最新的一些补丁包的。

​ 将Docker安装到CentOS上。注意:必须CentOS7.X以上的版本。CentOS6.X的版本中,安装前需要安装其他很多的环境而且Docker很多补丁不支持更新。

官网链接:https://docker.com

安装流程:

1,克隆空的虚拟机(空间稍微大点)

2,修改ip地址

修改IP地址: vi /etc/sysconfig/network-scripts/ifcfg-ens33

3,重启服务

重启服务:systemctl restart network.service

4,ping查看是否能上网

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-JftSg3XK-1622808900956)(C:\Users\Administrator\AppData/Roaming/Typora/typora-user-images/1620632029847.png)]

5,安装yum插件

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-8mBQhCzg-1622808900961)(/1620633100352.png)]

6,添加yum仓库插件

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-zoEAxZtB-1622808900962)(C:\Users\Administrator\AppData/Roaming/Typora/typora-user-images/1620633979093.png)]

7,安装下载

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-qd8JmOqO-1622808900963)(C:\Users\Administrator\AppData/Roaming/Typora/typora-user-images/1620634448189.png)]

8,安装完毕开机自动启动服务

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-Cuc7fwMt-1622808900964)(C:\Users\Administrator\AppData/Roaming/Typora/typora-user-images/1620635883070.png)]

启动

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-ymlPsP0t-1622808900965)(C:\Users\Administrator\AppData/Roaming/Typora/typora-user-images/1620635905215.png)]

9,查看状态正在启动

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-yDlkZwqg-1622808900968)(C:\Users\Administrator\AppData/Roaming/Typora/typora-user-images/1620636086536.png)]

基本命令:

查看内存:free -hl

2.1设置docker镜像加速器

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-5uY4CvJS-1622808900968)(file:C:\Users\Administrator\AppData\Local\Temp\ksohtml7712\wps2.jpg)]

vim /etc/docker/daemon.json

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-VKCUzUzE-1622808900972)(file:///C:\Users\Administrator\AppData\Local\Temp\ksohtml7712\wps3.jpg)]

更改registry-mirrors地址为复制的地址。

esc回车,按住shift+z+z,保存

加载配置,重启docker

*systemctl daemon-reload*

*systemctl restart docker*

3,命令练习

3.1 搜索镜像

搜索镜像: docker search MysqL

下载镜像 :docker pull MysqL

查询镜像:docker images

查询正在运行的容器:docker ps

3.2 拉取镜像

常用命令:

查看防火墙是否打开:systemectl status firewalld

3.1 搜索镜像

搜索镜像: docker search MysqL

下载镜像 :docker pull MysqL

查询镜像:docker images

查询正在运行的容器:docker ps

3.2 拉取镜像

常用命令:

查看防火墙是否打开:systemectl status firewalld

相关文章

Docker是什么Docker是 Docker.Inc 公司开源的一个基于 LXC技...
本文为原创,原始地址为:http://www.cnblogs.com/fengzheng...
镜像操作列出镜像:$ sudo docker imagesREPOSITORY TAG IMA...
本文原创,原文地址为:http://www.cnblogs.com/fengzheng/p...
在 Docker 中,如果你修改了一个容器的内容并希望将这些更改...
在Docker中,--privileged 参数给予容器内的进程几乎相同的权...