写在前面的话
我们接下来的操作都是 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 算是简单的安装完成了,但是怎么使用,到底有多牛逼,还得看后面。当然,如果你觉得写的还不错,可以先点个 推荐~