Docker

一.docker初体验

1.1 docker作用

一款产品从开发到上线,从操作系统,到运行环境,再到应用配置。作为开发+运维

之间的协作我们需要关心很多东西,这也是很多互联网公司都不得不面对的问题,特

别是各种版本的迭代之后,不同版本环境的兼容,对运维人员都是考验 , 这个时候

docker 横空出世,是因为它对此给出了一个标准化的解决方案。

环境配置如此麻烦,换一台机器,就要重来一次,费力费时。能不能从根本上解决问

题,软件可以带环境安装?也就是说,安装的时候,把原始环境一模一样地复制过

来。开发人员利用 docker 可以消除协作编码时"在我的机器上可正常工作"的问题。

1.1.1 应用部署的环境问题

大型项目组件较多,运行环境也较为复杂,部署时会碰到一些问题:

依赖关系复杂,容易出现兼容性问题

开发、测试、生产环境有差异

例如一个项目中,部署时需要依赖于node.js、Redis、MySQL等,这些服务部署时所

需要的函数库、依赖项各不相同,甚至会有冲突。给部署带来了极大的困难。

1.1.2 Docker解决依赖兼容问题

Docker为了解决依赖的兼容问题的,采用了两个手段:

将应用的Libs(函数库)、Deps(依赖)、配置与应用一起打包

将每个应用放到一个隔离容器去运行,避免互相干扰

这样打包好的应用包中,既包含应用本身,也包含应用所需要的Libs、Deps,无需再

操作系统上安装这些,自然就不存在不同应用之间的兼容问题了。

虽然解决了不同应用的兼容问题,但是开发、测试等环境会存在差异,操作系统版本

也会有差异,怎么解决这些问题呢?

1.1.3 Docker解决操作系统环境差异

要解决不同操作系统环境差异问题,必须先了解操作系统结构。以一个Ubuntu操作

系统为例,结构如下:

结构包括

*计算机硬件:例如CPU、内存、磁盘等

*系统内核:所有Linux发行版的内核都是Linux,例如CentOS、Ubuntu、Fedora

*等。内核可以与计算机硬件交互,对外提供内核指令,用于操作计算机硬件。

*系统应用:操作系统本身提供的应用、函数库。这些函数库是对内核指令的封

*装,使用更加方便。

应用于计算机交互的流程如下:

*应用调用操作系统应用(函数库),实现各种功能

*系统函数库是对内核指令集的封装,会调用内核指令

*内核指令操作计算机硬件

此时,如果将一个Ubuntu版本的MySQL应用安装到CentOS系统,MySQL在调用

Ubuntu函数库时,会发现找不到或者不匹配,就会报错了:Ubuntu和CentOS都是

基于Linux内核,提供的函数库有差异:

Docker如何解决不同系统环境的问题?

Docker将用户程序与所需要调用的系统(比如Ubuntu)函数库一起打包

Docker运行到不同操作系统时,直接基于打包的函数库,借助于操作系统的

Linux内核来运行

1.1.4 总结

Docker如何解决大型项目依赖关系复杂,不同组件依赖的兼容性问题?

*Docker允许开发中将应用、依赖、函数库、配置一起打包,形成可移植镜像

*Docker应用运行在容器中,使用沙箱机制,相互隔离

Docker如何解决开发、测试、生产环境有差异的问题?

*Docker镜像中包含完整运行环境,包括系统函数库,仅依赖系统的Linux内核,

*因此可以在任意Linux操作系统上运行

Docker是一个快速交付应用、运行应用的技术,具备下列优势:

*可以将程序及其依赖、运行环境一起打包为一个镜像,可以迁移到任意Linux操

作系统

*运行时利用沙箱机制形成隔离容器,各个应用互不干扰

*启动、移除都可以通过一行命令完成,方便快捷

*总之一句话:只需要一次配置好环境,换到别的机子上就可以一键部署好,大大

简化了操作 。

1.2 Docker简介

*docker 是一个开源的应用容器引擎,基于 Go 语言开发。docker 可以让开发者

打包他们的应用以及依赖包到一个轻量级、可移植的容器中,然后发布到任何流

行的 Linux 机器上,也可以实现虚拟化。容器是完全使用沙箱机制,相互之间不

会有任何接口,更重要的是容器性能开销极低。

*通过对应用组件的封装、分发、部署、运行等生命周期的管理,使用户的APP

(可以是一个WEB应用或数据库应用等等)及其运行环境能够做到"一次封装,

到处运行"。

**1.3 Docker架构

1.3.1 镜像和容器**

Docker中有几个重要的概念:
镜像(Image) :Docker将应用程序及其所需的依赖、函数库、环境、配置等文件

打包在一起,称为镜像。
容器(Container) :镜像中的应用程序运行后形成的进程就是容器,只是Docker

会给容器进程做隔离,对外不可见。

一切应用最终都是代码组成,都是硬盘中的一个个的字节形成的文件。只有运行时,

才会加载到内存,形成进程。

镜像 ,就是把一个应用在硬盘上的文件、及其运行环境、部分系统函数库文件一起

打包形成的文件包。这个文件包是只读的。
容器 呢,就是将这些文件中编写的程序、函数加载到内存中允许,形成进程,只不过

要隔离起来。因此一个镜像可以启动多次,形成多个容器进程。

例如你下载了一个QQ,如果我们将QQ在磁盘上的运行文件及其运行的操作系统依赖

打包,形成QQ镜像。然后你可以启动多次,双开、甚至三开QQ,跟多个妹子聊天。

1.3.2 DockerHub

开源应用程序非常多,打包这些应用往往是重复的劳动。为了避免这些重复劳动,人

们就会将自己打包的应用镜像,例如Redis、MySQL镜像放到网络上,共享使用,就

像GitHub的代码共享一样。

*DockerHub:DockerHub是一个官方的Docker镜像的托管平台。这样的平台称

为Docker Registry。

*国内也有类似于DockerHub 的公开服务,比如 网易云镜像服务、阿里云镜像库

等。

我们一方面可以将自己的镜像共享到DockerHub,另一方面也可以从DockerHub拉

取镜像:

1.3.3 Docker架构

我们要使用Docker来操作镜像、容器,就必须要安装Docker。

Docker是一个CS架构的程序,由两部分组成:

*服务端(server):Docker守护进程,负责处理Docker指令,管理镜像、容器等

*客户端(client):通过命令或RestAPI向Docker服务端发送指令。可以在本地或远

程向服务端发送指令。

二.docker的安装与卸载

docker 从 17.03 版本之后分为 CE(Community Edition: 社区版) 和 EE

(Enterprise Edition: 企业版),CE版本是免费的,EE版本是收费的。

docker的安装和卸载可以参考官方文档:CentOS | Docker Docs

2.1 配置静态IP地址

修改静态IP

|--------------------------------------------------------------------------------------------------------------|
| [root@localhost /]# cd /etc/sysconfig/network-scripts/ [root@localhost network-scripts]# vim ifcfg-ens33 |

文本内容

|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| TYPE="Ethernet" PROXY_METHOD="none" BROWSER_ONLY="no" BOOTPROTO="static" DEFROUTE="yes" IPV4_FAILURE_FATAL="no" IPV6INIT="yes" IPV6_AUTOCONF="yes" IPV6_DEFROUTE="yes" IPV6_FAILURE_FATAL="no" IPV6_ADDR_GEN_MODE="stable-privacy" NAME="ens33" UUID="78d66a02-f2cc-49d6-9357-3e2cf39b9484" DEVICE="ens33" ONBOOT="yes" # 将190改为你的网关号 IPADDR="192.168.190.151" #ip地址 GATEWAY="192.168.190.2" #网关(网络关卡) NETMASK="255.255.255.0" #子网掩码 DNS1="192.168.190.2" |

修改模型:

|------------------------------------------------------------------------------------------------------------|
| IPADDR="192.168.112.100" GATEWAY="192.168.112.2" NETMASK="255.255.255.0" DNS1=114.114.114.114 DNS2=8.8.8.8 |

*重启服务

|---------------------------|
| systemctl restart network |

查看IP地址

查看是否可以联网

2.2 关闭防火墙

|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [root@localhost ~]# systemctl stop firewalld [root@localhost ~]# systemctl disable firewalld Removed symlink /etc/systemd/system/multi- user.target.wants/firewalld.service. Removed symlink /etc/systemd/system/dbus- org.fedoraproject.FirewallD1.service. [root@localhost ~]# systemctl status firewalld |

2.3 IPV4开启(可选)

|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [root@localhost ~]# vim /etc/sysctl.conf net.ipv4.ip_forward=1 #最下方添加这段代码 #重启network服务 systemctl restart network #查看是否修改成功 (备注:返回1,就是成功) [root@localhost ~]# sysctl net.ipv4.ip_forward net.ipv4.ip_forward = 1 |

2.4 卸载docker

如果之前安装过旧版本的Docker,可以使用下面命令卸载:

|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| yum remove docker \ docker-client \ docker-client-latest \ docker-common \ docker-latest \ docker-latest-logrotate \ docker-logrotate \ docker-selinux \ docker-engine-selinux \ docker-engine \ docker-ce |

2.5 安装docker

*第一步 检查系统版本

注意:这里建议安装在CentOS7.x以上的版本,在CentOS6.x的版本中,安装前需要

安装其他很多的环境,而且Docker很多补丁不支持更新。

|----------------------------------------------|
| # 确定是CentOS7.x及其以上版本 cat /etc/redhat-release |

第二步 更换yum源,检查环境,安装gcc和g++

|---------------------------------------------------------|
| gcc --version yum -y install gcc yum -y install gcc-c++ |

第三步 安装必要的一些系统工具

|---------------------------------------------------------------------------------|
| yum install -y yum-utils \ device-mapper-persistent-data \ lvm2 --skip-broken |

第四步 添加软件源信息(设置阿里云镜像地址,提高下载速度)

|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| yum-config-manager \ --add-repo \ https://mirrors.aliyun.com/docker-ce/linux/centos/docker-ce.repo sed -i 's/download.docker.com/mirrors.aliyun.com\/docker-ce/g' /etc/yum.repos.d/docker-ce.repo yum makecache fast |

第五步 安装Docker-CE

|--------------------------|
| yum install -y docker-ce |

2.6 启动docker

Docker应用需要用到各种端口,逐一去修改防火墙设置。非常麻烦,因此建议大家

直接关闭防火墙!

|-----------------------------------------------------------------------|
| # 关闭 systemctl stop firewalld # 禁止开机启动防火墙 systemctl disable firewalld |

通过命令启动docker:

|------------------------------------------------------------------------------------------------------------------------------------------------------|
| systemctl start docker # 启动docker服务 systemctl stop docker # 停止docker服务 systemctl restart docker # 重启docker服务 systemctl enable docker # 设置docker开机自启动 |

输入命令,可以查看docker版本:

|-----------|
| docker -v |

2.7 配置镜像加速器

docker的使用过程中,需要从远程仓库下载镜像,但是默认为国外网站,所以在下载

时可能会出现下载连接超时导致下载失败,因此需要为其配置镜像加速器,以提高下

载速度。目前使用的镜像加速器有很多,比如阿里云,网易云等等。

参考阿里云的镜像加速文档:阿里云登录 - 欢迎登录阿里云,安全稳定的云计算服务平台

阿里云镜像加速器的使用步骤:

*注册和登录

*进入管理后台

*搜索容器镜像服务

*查看示例代码进行配置即可

目前建议可以配置华为的镜像地址:

|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| sudo mkdir -p /etc/docker sudo tee /etc/docker/daemon.json <<-'EOF' { "registry-mirrors": ["https://3fdg7meg.mirror.aliyuncs.com"] } EOF sudo systemctl daemon-reload sudo systemctl restart docker |

三.Docker的基本操作

3.1 镜像操作

3.1.1 镜像名称

镜名称一般分两部分组成:[repository]:[tag]

在没有指定tag时,默认是latest,代表最新版本的镜像

这里的mysql就是repository,5.7就是tag,合一起就是镜像名称,代表5.7版本的

MySQL镜像。

3.1.2 镜像命令

相关推荐
_Eden_1 小时前
Docker技术相关学习二
学习·spring cloud·docker
_Eden_3 小时前
Docker技术相关学习三
java·学习·docker
Future_yzx3 小时前
Docker使用指南(一)——镜像相关操作详解(实战案例教学,适合小白跟学)
java·spring cloud·eureka
大丈夫立于天地间5 小时前
Linux 系统上安装 Docker 并进行配置
linux·运维·docker
赴前尘5 小时前
基于 docker 的mysql 5.7 主备集群搭建
mysql·adb·docker
2的n次方_5 小时前
Nacos 的介绍和使用
java·spring boot·spring cloud·微服务·云原生·nacos
荆州克莱5 小时前
利用Docker简化机器学习应用程序的部署和可扩展性
spring boot·spring·spring cloud·css3·技术
yaoxtao14 小时前
Docker的镜像
运维·docker·容器
不一样的信息安全14 小时前
Docker环境下Nacos的保姆级安装教程
运维·docker·容器