使用 Docker 快速搭建开发环境

在代码开发中, 除了语言开发环境及 IDE 外, 我们往往还需要依赖其他第三方服务, 如:数据库,服务器,缓存,搜索,MQ 等等. 而这些服务的安装各式各样, 有的极为复杂, 有的对开发机有极大的限制, 甚至有的直接不支持当前开发机. 给我们的开发环境搭建带来了极大的困难. 这时我们可以选择使用 Docker 来快速搭建开发环境, 屏蔽复杂的安装过程, 服务配置.

什么是 Docker

我们参考 Docker 官网中的概述 what-docker

Docker 是世界领先的软件容器平台。** 开发人员使用 Docker 来消除与同事的代码协作时的 “我机器上的工作” 问题 **。运营商使用 Docker 在独立的容器中并行运行和管理应用程序,以获得更好的计算密度。企业使用 Docker 构建灵活的软件传送管道,可以更快,更安全地运行新功能,并且对于 Linux 和 Windows Server 应用程序都有信心。
-- 来自谷歌翻译

在其中的 Docker For Developers 部分中, 我们可以查看对于我们开发者具体有哪些作用

Docker 自动执行设置和配置开发环境的重复任务,以便开发人员可以专注于重要的事情:构建出优秀的软件。

使用 Docker 的开发人员不必安装和配置复杂数据库,也不用担心在不兼容的语言工具链版本之间切换。当应用程序 Docker 化时,这种复杂性被推入容易构建,共享和运行的容器中。将同事加入新的代码库不再意味着安装软件和解释安装程序的时间。Dockerfiles 随附的代码更简单:依赖关系被拉为整齐的 Docker 映像,任何具有 Docker 和编辑器的人都可以在几分钟内构建和调试应用程序。
-- 来自谷歌翻译

** 简单来说, 使用 Docker 我们可以专注于代码的编写, 忽略其他软件复杂的安装, 配置. 同时可以统一线上, 线下环境, 不受服务版本差异的影响 **

安装 Docker

请参考 Docker 官方文档中的 Install Docker
目前 Docker 支持的系统版本如下

Docker 支持的系统版本. png

Docker 最初是在 Ubuntu 12.04 上开发实现的 [1], 另外 Docker 官网文档中的一些操作命令也是基于 Ubuntu 来讲解的, 如果有条件, 推荐使用 Ubuntu
Linux 安装完成后, 请查看 Post-installation steps for Linux 完成一些后续配置
对于 Linux 用户需要特别注意, 如果是以非 root 用户运行, 需要创建 docker 组, 并将当前用户添加到 docker 组中 [2]

$ sudo groupadd docker
$ sudo usermod -aG docker $USER

Docker 中使用的镜像都需要从网站上下载, 因为网络原因, 国内下载速度往往不佳, 此时可以使用国内的一些加速器来加速下载, 如:DaoCloud,阿里云, 具体用法, 请登录后查看网站说明文档

使用 Docker 搭建开发环境

现在以搭建 mysql 为例
首先从 hub.docker.com 网站中搜索你需要的镜像, 如 mysql

hub 搜索镜像. png

其中第一个带有 official 单词的表明为 Dcoker 官方提供的镜像, 下面的三个为个人 / 组织上传的镜像
我们点击右侧 DETAILS 按钮查看镜像详情
hub 镜像说明. png

图中的 8.0.15.5.55 四行表示支持的 mysql 版本, 同时附带镜像构建的 Dockerfile 文件
右侧的 docker pull mysql 是镜像的下载命令, 此时我们可以在命令行中执行该命令进行下载, 默认下载版本为 latest
如果希望指定下载版本, 使用如下命令格式 docker pull mysql:版本号, 如 docker pull mysql:5.6

下载 mysql 镜像

$ docker pull mysql:5.7

运行 mysql 镜像

$ docker run --name mysql --rm -p 3306:3306 -e MYSQL_ROOT_PASSWORD=root mysql:5.7

此时会在命令行中输出该容器运行时的日志, 若要退出, 请按 Ctrl+c
如果希望在后台运行, 加入 -d 参数即可
运行参数说明

--name mysql #镜像运行的容器名称为 mysql
--rm #容器退出后删除该容器
-p 3306:3306 #将本机的 3306 端口映射到该容器的 3306 端口
-e MYSQL_ROOT_PASSWORD=root #为容器配置一个名为 MYSQL_ROOT_PASSWORD, 值为 root 的环境变量, 因 mysql 容器的特殊性, 必须配置该环境变量
-d #在后台运行该容器

测试容器

在后台运行 mysql 容器

$ docker run --name mysql --rm -p 3306:3306 -e MYSQL_ROOT_PASSWORD=root -d mysql:5.7

查看当前运行容器列表

$ docker ps

docker ps.png

我们可以发现 mysql 已在后台运行
此时我们可以使用 Navicat,SQLyog 进行链接测试
ip: 运行容器机器的 ip
端口:3306
用户名:root
密码:root, 即 MYSQL_ROOT_PASSWORD 对应的值
亦可使用如下命令进入 mysql 命令行

$ docker run -it --link mysql:mysql --rm mysql:5.7 sh -c 'exec mysql -h"$MYSQL_PORT_3306_TCP_ADDR"-P"$MYSQL_PORT_3306_TCP_PORT"-uroot -p"$MYSQL_ENV_MYSQL_ROOT_PASSWORD"'

运行参数说明

-it #运行容器后进入一个交互式的终端
--link mysql:mysql #链接一个名称为 mysql 的容器, 并为该容器配置一个名为 mysql 的 hosts
sh -c 'exec mysql -h"$MYSQL_PORT_3306_TCP_ADDR"-P"$MYSQL_PORT_3306_TCP_PORT"-uroot -p"$MYSQL_ENV_MYSQL_ROOT_PASSWORD"' #为运行容器后执行的命令, 其中诸如 $MYSQL_PORT_3306_TCP_ADDR,$MYSQL_PORT_3306_TCP_PORT 环境变量是容器根据 --link mysql:mysql 自动生成

数据保存

mysql 镜像默认使用的配置文件为 /etc/mysql/my.cnf
如果我们需要自定义配置文件可以使用如下命令覆盖原本配置

$ docker run --name mysql --rm -p 3306:3306 -e MYSQL_ROOT_PASSWORD=root -d -v ~/docker/data/mysql/my.cnf:/etc/mysql/my.cnf mysql:5.7

运行参数说明

-v ~/docker/data/mysql/my.cnf:/etc/mysql/my.cnf #使用当前机器下的 ~/docker/data/mysql/my.cnf 文件挂载为容器中的 /etc/mysql/my.cnf 文件

mysql 镜像中默认存储目录为 /var/lib/mysql, 这样存在容器删除后数据丢失的问题
为了防止这一情况产生, 我们需要将外部文件夹挂载到容器的 /var/lib/mysql

$ docker run --name mysql --rm -p 3306:3306 -e MYSQL_ROOT_PASSWORD=root -d -v ~/docker/data/mysql/datadir:/var/lib/mysql mysql:5.7

此时我们查看 ~/docker/data/mysql/datadir 文件夹

ll -h ~/docker/data/mysql/datadir

datadir 文件夹. png

发现已经在该文件夹内生成了一些 mysql 的初始化文件
关于 mysql 镜像的更多信息可在 hub.docker.com 中对应的 镜像详情 查看
关于其他如 redis,nginx,mongo 等镜像的搭建及配置皆可在 hub.docker.com 中搜索查看

** 如果希望更加系统的学习 Docker 信息, 请查看 官网文档**
如果想查看中文文档, 可以去看 Docker —— 从入门到实践

相关资料
Docker 官方文档
Docker —— 从入门到实践
labs


  1. 参考自 Docker — 从入门到实践

  2. 参考自 Manage Docker as a non-root user

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 162,547评论 4 374
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 68,787评论 2 308
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 112,175评论 0 254
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 44,752评论 0 223
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 53,169评论 3 297
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 41,056评论 1 226
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 32,195评论 2 321
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 30,980评论 0 214
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 34,724评论 1 250
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 30,872评论 2 254
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 32,344评论 1 265
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 28,667评论 3 264
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 33,379评论 3 245
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 26,202评论 0 9
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 26,992评论 0 201
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 36,189评论 2 286
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 35,987评论 2 279

推荐阅读更多精彩内容

  • Docker — 云时代的程序分发方式 要说最近一年云计算业界有什么大事件?Google Compute Engi...
    ahohoho阅读 15,426评论 15 147
  • 我在南方的艳阳天里 一夜无梦,眨眼到了第二天。拉开窗帘,迎接我们的是进入雨季以来难得的大晴天。终于可以体验晴空...
    qingyljoy阅读 296评论 0 0
  • 秋分将至。 经云:至则气同,分则气异。是说冬至夏至前后的气温相差不会太多,基本在同一水平上下波动。春分秋分前后的气...
    kbdf阅读 423评论 0 0
  • 文/熠歆 当我亲身经历带小孩时,我才真正知道带孩子是一件不容易的事,再想想我们的母亲又是多么艰难呀! 记得有一次带...
    熠歆阅读 155评论 10 1
  • 最近 发现 我失去了一个很重要的东西。 同时也发展出了一些新的品质。 我看见 我自己 渐渐没有了爱一个人不得不说出...
    贤母堂赵欣柔阅读 475评论 0 0