docker的概述: 用于快速构建,运行,管理应用的工具
回忆大学Linux上课老师教安装mysql
大概的命令有这些:
查看本机是否安装mysql或者mariadb
如果有就先卸载掉,如果没有直接进行下面的安装
安装前还需要到mysql的官网上找到linux对应发行版的mysql安装包文件
上传到虚拟机中,并解压缩,然后下载安装
总的来说就是: 命令太多我记不住,安装步骤太复杂容易出错,安装包太多我不知道咋下载
docker就是终结一切混乱的神兵利器

这只承载了集装箱的鲸鱼将彻底改变传统应用安装管理等的方式
如果在本机已经安装了docker的情况下,只需要一行命令即可成功安装mysql
docker run -d --name mysql -p 3306:3306 -e MYSQL_ROOT_PASSWORD=123 mysql
我们不妨就以虚拟机部署mysql作为案例来引入docker的使用,然后再深入了解其背后的原理
先停掉虚拟机中的mysql(如果有安装的前提下),确保本机已经安装了docker,且网络开通正常工作的前提下,执行下面的命令即可安装mysql
docker run -d \
--name mysql \
-p 3306:3306
-e TZ=Asia/Shanghai \
-e MYSQL_ROOT_PASSWORD=123 \
mysql
当我们利用docker安装应用时,docker会自动帮助我们搜索并下载应用镜像(image). 镜像不仅仅包含应用本身,还包含其运行所需要的运行环境,配置以及依赖和函数库等. docker会在运行镜像时创建一个隔离环境,称之为容器(container)
所谓的镜像仓库就是存储和管理各种各样的镜像的仓库,docker官方维护了一个公共仓库https://hub.docker.com/
可以看到docker具体的工作流程如下

- Docker 是 C/S 架构,客户端发命令,守护进程做实际操作;
docker run的核心流程:客户端请求 → 守护进程查本地镜像 → 无则拉取远程镜像 → 基于镜像创建启动容器 → 容器运行;- 一个镜像对应多个容器,核心是通过端口映射(或其他配置)实现容器间的独立隔离。
-
客户端发起命令
-
守护进程检查本地镜像
-
从远程镜像仓库拉取镜像
-
基于镜像创建并启动容器
-
容器运行与客户端交互
在这里我们解读一下文章最开始使用docker run 命令启动mysql容器的用法
docker run 就是创建并运行一个容器, -d 是让容器在后台运行
--name 给容器起个名字,必须是唯一的
-p 3306:3306 设置端口映射
-e KEY=VALUE 是设置环境变量
mysql 指定运行的镜像的名字
这里的端口映射工作逻辑如下

容器默认有独立的网络命名空间,外部无法直接访问容器内的应用,通过 -p 宿主机端口:容器端口,相当于给容器开了一个 "对外访问的窗口",宿主机的端口会转发到容器的对应端口。