写在前面的话

我们接下来的操作都是 CentOS 7.5 以下完成的,为了避免你我结果不一致,建议你也采用 CentOS 7.5,原因如下:

1. 个人几年工作下来经历的公司,包括身边的运维朋友,90% 以上都采用 CentOS 作为服务器的操作系统。

2. 说到 docker,很多人会想到 Ubuntu,但个人不建议使用 Ubuntu,Ubuntu 更适用于个人用户。

3. 老资料中会看到 docker 在 Ubuntu 的文件存储驱动 AUFS 相比 CentOS devicemapper 强出天际,但已经是过去式。

4. 老资料中会看到需要升级 CentOS 的系统才能支持新的文件存储驱动,这些也是过去式。

5. 从 18 年的某个版本开始,CentOS 已经默认使用新的文件存储驱动 Overlay2,性能比肩 AUFS,且不需要升级内核。

6. 告别 CentOS 6,除非你想给自己挖一个能埋掉自己的坑。

四座大山

在学习 docker 之前,我们必须要翻过这 4 座大山:容器(Container),镜像(Image),仓库(Repository),注册点(Registry

容器:上一篇花了大篇幅来说明它了。

镜像:包含系统和我们需要的服务的一个包,相当于 windows 的 iso 文件一样。

仓库:存放同种镜像资源的站点。

注册点:多个仓库再加上认证等功能集合在一起。

我们可以通过流程来理解:去注册点的指定仓库下载我们需要的镜像,然后在本地构建成为容器

docker 发展史

再开始讲故事之前,我们需要先明确一个概念:

docker 将容器技术推向了巅峰,但是容器并非起源于 docker,早期还有的 FreeBSD Jails,LXC 等

知道了这个,我们再来看看酱婶儿滴一个故事:

2013 年,docker 公司成立,产品一经发布便迅速占领了市场。但没人知道,Google 内部其实已经使用该技术长达了 10 年之久。

docker 就像一个愣头青,乱拳打死老师傅。此时谷歌再发布自己的产品显然已经来不及了。

但是,那可是谷歌,用了这个技术 10 年之久的谷歌。容器技术被你占了市场没关系,容器编排就别想了,于是 Kubernets,也就是 K8S,开源了,并迅速占领了超过 80% 的市场。

docker 肯定是心有不甘的,于是发布了自己的编排系统 docker swarm,并且整合进 docker 里面,只有你安装 docker,就自带。

然鹅,并没啥卵用,谷歌的 10 年,坑都被人家给踩平了,哪里是你一家年新公司能一朝一夕搞赢的。

之后更是联合了微软等几家巨头成立了 CNCF,一个业内制定容器相关规则规范的机构。

这就是 docker 诞生之后在业内横生的一些波澜,然后我们再看看其自身的改变:

docker 诞生之初,第一个执行环境是 LXC,后在 0.9 版本开始变更为 libcontainer

2015 年,runC 发布,从此  docker 走上了跨平台运行之路。

2016 年,拆分成为社区版(CE)和企业版(EE),并把流量引入了企业版,导致社区版炸锅。也是从这时开始,“一把好牌打得稀烂”~

在 1.13 版本之后,命名规则变更为 <年>.<月> 的格式,如 18.06,并发布前沿版本(Edge)和稳定版(Stable),前者 1 个月发布一次,后者3 个月。我们只需知道后者。

另外,在老的 CentOS 官方源中,docker 包名为 docker,Ubuntu 中为 docker.io,在超级远古的版本叫  lxc-docker,但 17.04 版本之后都统一为 docker-ce~

docker 安装

【1】卸载旧版,安装新版:

# 卸载旧版本
yum remove docker docker-client docker-client-latest docker-common docker-latest docker-latest-logrotate docker-logrotate docker-engine

# 安装依赖
yum install -y yum-utils device-mapper-persistent-data lvm2 bridge-utils bash-completion wget

# 配置阿里 yum 源
cd /etc/yum.repos.d
wget https://mirrors.aliyun.com/docker-ce/linux/centos/docker-ce.repo

# 安装 docker
yum -y install docker-ce

【2】启动并查看:

# 启动和开机自启动
systemctl start docker
systemctl enable docker

# 查看服务端和客户端版本信息
docker version 

# 查看更为详细的关于 docker 的信息
docker info

【3】简单的优化 docker:

我们在使用 docker info 的时候能够注意到两个参数,一个是 Docker Root Dir,另外一个是 Registry Mirrors,前者指的是 docker 的目录,后者则是我们拉取镜像的注册点。

前者修改不修改看个人,为了便于通用理解,我们这里就用当前的目录。后者必须修改,因为我们需要从这里加速拉取镜像,否则在国内访问 docker hub 的速度大家都懂的~

cd /etc/docker/
vim daemon.json

内容如下:

{
    "registry-mirrors": ["https://docker.mirrors.ustc.edu.cn"]
}

在 docker 没有第一次启动的时候,/etc/docker 目录是不存在的,我们可以手动建立或者先启动 docker,daemon.json 则需要手动建立。这里我采用使用最简单的中科大加速器。当然,如果你想用阿里云或者其他的,可以去网上找找,很多~

这个文件就是一个 json 格式的数据,里面可以写各种 docker 的启动运行参数,具体可以参照官方文档或者网上,但值得注意的是,文档的参数一般是命令行参数,我们需要改为配置参数:

https://docs.docker.com/engine/reference/commandline/dockerd/

配置以后记得重启 docker 生效~

# 重启 docker
systemctl restart docker

# 查看修改的效果
docker info

在 docker info 显示的内容中,也可以看到我之前提到的文件存储驱动, Storage Driver: overlay2

另外提醒一个,强烈建议修改自己的本地虚拟机的 hostname 为不一样的,别使用默认的 localhost,否则后面可能会出现心态爆炸的 BUG~

当然这里的配置也可以以参数的形式添加到 /etc/systemd/system/multi-user.target.wants/docker.service 文件的指定位置,这里就不赘述,总之我推荐是写文件~

小结

到这里,docker 算是简单的安装完成了,但是怎么使用,到底有多牛逼,还得看后面。当然,如果你觉得写的还不错,可以先点个 推荐~

【02】循序渐进学 docker:如何安装的更多相关文章

  1. 【01】循序渐进学 docker:到底是啥

    写在前面的话 首先说一下,我本身是做运维的,4 年工作,多家公司.所以可能接下来谈到的更多的是一些在工作过程中积累的个人看法.且有些并不具备普遍性,有不合适的地方,全当我在吹牛逼就行. 一开始我们得谈 ...

  2. 【2】循序渐进学 Zabbix:安装配置 Zabbix Server 服务端

    上一篇 [1]循序渐进学 Zabbix :初识与基础依赖环境搭建( LNMP ) 安装 Zabbix Server 上篇我们在 192.168.200.101 上面安装了 Zabbix 所依赖的 LN ...

  3. 【09】循序渐进学 docker:docker swarm

    写在前面的话 至此,docker 的基础知识已经了解的差不多了,接下来就来谈谈对于 docker 容器,我们如何来管理它. docker swarm 在学习 docker swarm 之前,得先知道容 ...

  4. 【08】循序渐进学 docker:docker compose

    写在前面的话 在之前的操作中,即使是单个容器每次都需要敲很长的命令,当需要多个容器组合着用的时候更加麻烦,此时我们急需找到一种一次配置,随便运行的方法. 这就是这一节重点,单机容器编排工具:docke ...

  5. 【07】循序渐进学 docker:数据持久化

    写在前面的话 学到这里相信有心的朋友都发现问题了,我们每次都会去删掉容器,在创建新的容器.那数据怎么办?岂不删库跑路了? 就算不是数据库,假设公司有日志保留的需求,那每一次发布岂不日志都被干掉了? D ...

  6. 【06】循序渐进学 docker:跨主机通信

    写在前面的话 目前解决容器跨主机通信的方案有很多种,这里给出的只是其中的一种,而且还不是最好的方案,不过归根结底,大同小异.在学习 docker swarm 之前,大家可以先看看这种. 啥是 over ...

  7. 【05】循序渐进学 docker:系统资源和网络

    写在前面的话 在上一篇学习 Dockerfile 的时候其实还有几个相当重要得关键中没有谈到,但没关系,在后面的内容会单独提出来一个一个的学习.这里就先谈谈关于资源的控制个容器的网络~ 资源限制 其实 ...

  8. 【03】循序渐进学 docker:基础命令

    写在前面的话 之前谈了啥是 docker 和怎么安装 docker,这里就谈谈 docker 命令的使用,当然,这里的使用可能只是局限于 docker 的增删查改. 另外需要注意的是,为了图片的美观, ...

  9. 【04】循序渐进学 docker:Dockerfile

    写在前面的话 从前面我们简单的了解了镜像,也运行了容器,各种官方的镜像显然无法满足我们自己的需求,我们目的终究是运行自己的业务. 所以,本章节的 Dockerfile 就主要讲怎么在官方镜像的基础上制 ...

随机推荐

  1. appium控制Android按键

    按键的keycode,如下: KEYCODE_HOME Home键 3 KEYCODE_BACK 返回键 4 KEYCODE_CALL 拨号键 5 KEYCODE_ENDCALL 挂机键 6 KEYC ...

  2. 何时会发生db file sequential read等待事件?

    很多网友对系统内频繁发生的db file sequential read等待事件存有疑问,那么到底在那些场景中会触发该单块读等待事件呢? 在我之前写的一篇博文<SQL调优:Clustering ...

  3. 固定容器内任意个div填充算法

    <!DOCTYPE html> <html> <head> <meta http-equiv="Content-Type" content ...

  4. selenium 对浏览器的操控 java

    driver.navigate().back();     后退 driver.navigate().forward();   前进 driver.navigate().refresh();    刷 ...

  5. Java微信公众平台开发(八)--多媒体消息回复

    转自:http://www.cuiyongzhi.com/post/46.html 之前我们在做消息回复的时候我们对回复的消息简单做了分类,前面也有讲述如何回复[普通消息类型消息],这里将讲述多媒体消 ...

  6. Hibernate XXX.hbm.xml 里的class标签的 schema 属性解释

    转自:https://blog.csdn.net/mym43210/article/details/30230173 1 <?xml version="1.0" encodi ...

  7. PHP 取网页变量

    $_POST["test"]; $_GET["test"];isset();  if(isset($_GET["yyuid"]))

  8. openark对MySQL进行Online_DDL

    1.用oak对表sbtest1做添加字段和增加索引的Online DDL openark kit 提供一组小程序,用来帮助日常的 MySQL 维护任务,可代替繁杂的手工操作. 包括: oak-appl ...

  9. webRTC peerconnection_client demo创建VS工程

    编译了webRTC Windows源码之后,想使用编译出来的库写一个demo出来,但是又不知到怎么下手.就想通过源码中带的示例peerconnection_client和peerconnection_ ...

  10. Leetcode:Two Sum分析和实现

    问题表示提供一个整数数组nums,以及一个目标target,要找到两个下标i与j,使得nums[i] + nums[j] = target. 最简单的思路是两次循环: for a in nums fo ...