【02】循序渐进学 docker:如何安装

写在前面的话

 

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

转载于:https://www.cnblogs.com/Dy1an/p/10595418.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值