以前要在本地跑一些有意思的工程和实验,都需要通过在本地装上一大堆软件来实现。最近发现有一种更酷的方式:Docker。

用Docker在本地搭建开发环境有一系列显而易见的优势:

  • 不用依赖公司的资源,开发机资源够够的,环境完整可控,想怎么玩怎么玩,不用担心留痕也完全不会影响别人
  • 能够使用标准化的镜像屏蔽掉一切安装过程的坑,不用担心安装过程中出现的各种乱七八糟的报错
  • 虚拟环境想用即用,不想用了随时丢掉,不用操心清理起来很麻烦
  • 镜像的安装方式大大降低了安装门槛,而且在虚拟环境跑服务完全没有任何心理门槛,终于可以在本地把想安装的中间件或者服务跑全了
  • 酷,重点是酷

Docker 搭建的环境为什么能做到以上优势

道理其实很简单,使用Docker Desktop在本地起一个虚拟机,然后在虚拟机里跑Docker。这样所有的安装和启停变更都发生在虚拟环境里,自然而然的就带来了以上优势。

安装基础环境

下载Docker Desktop,安装过程踩了两个雷:

WSL2 Linux 内核更新包

Docker Desktop requires a newer WSL kernel version

这个报错是字面意思,需要更新内核版本。下载WSL2 Linux 内核更新包即可:地址

Docker容器运行需要依赖虚拟化

Hardware assisted virtualization and data execution protection must be enabled in the BIOS

这个报错是因为BIOS里没有把对虚拟化的支持打开,重启进入BIOS,打开虚拟化相关配置即可。另外,如果你近期准备面试跳槽,建议在Java面试库小程序在线刷题,涵盖 2000+ 道 Java 面试题,几乎覆盖了所有主流技术面试题。

运行你的第一个容器

安装完毕之后就可以用了。Docker Desktop的首页非常简洁明了。

dockerfile 打包本地jar docker打包本地环境_docker

Guides里有三个示例,大大的Run,点下去就可以快捷的体验本地服务了。这里我们启动Nginx试试。

dockerfile 打包本地jar docker打包本地环境_Docker_02

切换到Terminal Tab可以对容器发出指令

dockerfile 打包本地jar docker打包本地环境_Docker_03

这种起服务的方式,我觉得比以前挨个安装软件的方式确实爽太多了。

至此Docker所需的环境已经搭建成功了,但是距离我们搭建一个很酷的本地开发环境还差得远。因为还有一连串的问题等着我们。

比如我们再深入玩一下刚才启动的Nginx容器,就会发现有很多指令找不到,这对于我们在本地调试是不可接受的。

dockerfile 打包本地jar docker打包本地环境_容器_04

再比如需要部署到Nginx的制品如何与本地文件映射,本地启动多个依赖服务时网络与端口如何管理。以及针对不同的本地开发所需要依赖的资源和服务,可能需要通过自行build docker file的方式才能让他们在本地用起来更加丝滑和酷炫。这些问题,我们留到后文再续。