Docker 简介

Docker在现有云计算虚拟化中是非常火的一个项目,那么他和虚拟化有什么不同呢

Docker 简介

从上图来看,好像和我们之前说到的虚拟化并没有什么不同,但这里需要说明的是在各guest主机上,是没有操作系统的,他们共用Host主机上的内核空间,只对用户空间进行了隔离。

因此在这种环境下我们不把他称为虚拟化而称作容器。

此种方式的实现主要基于了linux内核自带的两项技术,分别是namespace和cgroup,下面解释下它们分别做了什么

 

Namespace

PID NameSpace:PID隔离。
Network NameSpace:网络设备、网络栈、端口等网络资源隔离。
User NameSpace:用户和用户组资源隔离。
IPC NameSpace:信号量、消息队列和共享内存的隔离。
UTS NameSpace:主机名和域名的隔离。
Mount NameSpace:挂载点(文件系统)隔离。

 

Cgroup

Resource limitation:资源限制。
Prioritization:优先级控制。
Accounting:审计和统计,主要为计费。
Control:挂起进程,恢复进程。
依靠上面所提到的技术,我们应该明白已经完全可以隔离用户空间了,甚至还可以进行对各空间的资源限定,当然要想正常使用,还需要依赖下面2样技术,也是内核所带的功能。

UnionFS:把不同的物理位置的目录合并到同一个目录中。(打个比方说就是把一个磁盘挂载至一个目录中,我们知道如果正常情况下挂载点里面所拥有的文件会被隐藏,基于此项技术,可以同时看到,也可以修改,但此种修改并不在原文件上生效,而是相当于在磁盘中新建的数据)

Device mapper:用于在内核中支持逻辑卷管理的通用设备映射机制

Docker就是依靠以上技术进行的一步封装,以便人们可以更方便的使用,就像很久前,我们提到的linux各发行版一样,如果你想学习linux,却只提供给你一个内核,相信没有多少人安装成功。

 

Docker于2013年发布,go语言研发,并遵从apache开原协议,C/S架构。

Docker的重要组件:

registry:主要提供各镜像文件(repository),以及镜像的元数据信息,还包括给各镜像创建索引分类(index)。

container:运行于host主机上的实例。

volume:在容器运行的应用程序,如果关闭,会删除容器中保存的数据,因此volume主要给容器和物理磁盘作一个映射关系,这样每个容器关闭或删除时上面的数据都会存在。

link:各实例的关联关系,类似于定义依赖关系。

docker通常用于运行单个任务,单个任务结束,即会退出实例。

下面就来简单演示下基于docker容器实现的lamp部署wordpress

配置好extras yum源

[root@localhost ~]# yum -y install docker

 

[root@localhost ~]# docker pull centos

直接安装并下载centos的image镜像,

Docker 简介

这里我已经有了两个镜像,一个是官网下的centos镜像,然后自己配置了一下yum源,新生成了一个镜像否则下载太慢。

下面就用两种方式生成image来完成对web和mariadb的部署。

先来web吧

[root@localhost ~]# docker run -it –rm centos:7 /bin/bash

-i:交互式运行

-t:打开一个伪终端

–rm:退出后直接删除实例

centos:7  指明运行的镜像

/bin/bash:运行的程序

[root@feba71b34795 /]# yum -y install httpd php php-mysql 

直接安装PHP HTTPD和php链接mysql所需要的包

Docker 简介

另外打开一个终端。接着使用docker ps 查看启动的容器ID,并使用docker commit 指明容器ID 并给此容器定义一个名字就生成新镜像了,使用docker images可以查看到。我们之前起的实例就可以关闭了~~~。

Docker 简介

重新起一个实例

 

-v:将host主机的/web目录挂载至/var/www/html  因为之前什么都没改,apache默认的根目录就在此,我们直接将此目录挂载出来。

-d:后台运行

-p:将本机的80端口映射为虚拟机的80端口,其实就是docker自己添加一条dnat规则

/sbin/http: 运行此命令 -DFOREGROUND 使其运行至前台,我们前面提到过,docker每个实例的生命周期为一个任务结束,所以要让他一直占据前台。

Docker 简介

接着在映射出的目录里面创建一个测试页,接着就可以尝试访问看能否访问到。

Docker 简介

 

可以看到我们直接访问虚拟机的80端口就能访问到我们提供的测试页了。 我们先不管这台容器了。

接着我们用dockerfile创建一个mariadb的实例出来。

[root@localhost mariadb]# docker build -f ./mariadb.df -t centos7:mariadb ./

-f :指明构建所用到的文件

-t :指明在images里面看到的标签

./:指明工作的目录

这里我是新建一个目录 然后在里面创建的文件

Docker 简介

 

 

注意 这里是两个文件 一个是构建的文件,一个是脚本。

在这里折腾许久,一直想直接一个文件写完,添加授权尝试了很多种方法都不行,会直接报没有mysql命令 ,要不就是语法错误,后来看了mariadb官方提供的镜像,发现他也是通过脚本来执行的,于是自己写了个简单的脚本。这里还有莫名其妙的地方,那就是后台启动了mariadb过后还是需要sleep两秒才能执行成功。最后呢 ,授权完了,任务也就完了,实例还会自己关,就偷了个鸡,tail -f 让他一直在前台刷新mariadb自己的日志。

接着启动实例吧

Docker 简介

启动实例并且查看运行中的实例 确定mariadb和http都在运行状态, 并且也已经看到了mariadb已经把初始化的目录正确的写入到host主机了。

接着去解压wordpress到host主机上的/web目录应该就完成了~

这里需要注意的是,我们不知道mariadb的地址,可以使用下面的命令查看

[root@localhost mariadb]# docker  inspect -f {{.NetworkSettings.IPAddress}} 3b7a7e94bb8e
172.17.0.3

后面的3b7a。。是容器ID

也可以不使用-f 显示容器的所有参数,如果只想看某一项就可以使用上面的格式查看

Docker 简介

接着在wordpress的配置页面里面填上这些就可以了。

Docker 简介

这里可以看到已经可以创建

Docker 简介

 

 

 

原创文章,作者:N24_Ghost,如若转载,请注明出处:http://www.178linux.com/71384

(0)
N24_GhostN24_Ghost
上一篇 2017-03-19
下一篇 2017-03-19

相关推荐

  • 课堂练习及课后作业(0805文本处理工具)

    课堂练习: 1、找出ifconfig命令结果中本机的所有IPv4地址 2、查出分区空间使用率的最大百分比值 3、查出用户UID最大值的用户名、UID及shell类型 4、查出/tmp的权限,以数字方式显示 5、统计当前连接本机的每个远程主机IP的连接数,并按从大到小排序 grep 1、显示/proc/meminfo文件中以大小s开头的行;(要求:使用两种方式…

    Linux干货 2016-08-07
  • 网络接口配置-bonding

    网络接口配置-bonding •Bonding 就是将多块网卡绑定同一IP地址对外提供服务,可以实现高可用或者负载均衡。当然,直接给两块网卡设置同一IP地址是不可能的。通过bonding,虚拟一块网卡对外提供连接,物理网卡的被修改为相同的MAC地址。 Bonding的工作模式 •Mode 0 (balance-rr) 轮转(Round-robin)策略:从头…

    Linux干货 2016-09-05
  • 推荐-LAMP的编译安装

    首先解释一下LAMP,L:Linux;A:apache;M:MariaDB;P:php。Linux+Apache+Mysql/MariaDB+Perl/PHP/Python一组常用来搭建动态网站或者服务器的开源软件。 本文就是介绍编译安装apache2.4,MariaDB5.5,以及php(基于模块化和fpm的这两种方式来配合php提供服务)。 因为php是…

    Linux干货 2016-04-11
  • 优云软件:双态运维下,老司机是怎么玩CMDB的?

    行业内有个科技公司,CMDB前后建设12年,重构了N次,一言不合就重构,我深深的被这种屡拆屡战,初心不改精神所折服。我真心想问下做CMDB的兄弟,各位是怎么熬过来的?请不要回避,其实我们都曾被这样虐过! 近几年我司承建国内很多传统行业的CMDB项目,坦白的说,随着互联网+热潮的冲击,因很多传统企业也慢慢的在转变业务,把很多传统型的业务互联网化,或者开辟新型业…

    2016-08-05
  • linux网络管理之二

     IP 地址由两部分组成:                        网络ID: 最前面连续位                …

    2017-03-18
  • 程序包管理:rpm、yum以及(make)源代码编译安装

    程序包管理:rpm、yum以及(make)源代码编译安装 在Linux上安装程序一般都有三种方法:源代码编译安装,rpm包安装和rpm包的前端安装yum, (rpm,和yum程序包管理器是针对CentOS6平台的) 程序包管理方式都大同小异:  源代码–>目标二进制格式(二进制程序、库文件、配置文件、帮助文件)–&gt…

    Linux干货 2017-01-10

评论列表(1条)

  • 马哥教育
    马哥教育 2017-03-29 17:35

    不错的docker应用,下次可以尝试使用dockerfile来生成镜像,加油。