手把手提高开发体验:dev-container
之前看过方应杭的一期工作流视频,讲他是如何配置开发环境的。讲真,这期视频给我一丝震撼,原来不用虚拟机也能在 linux 上开发,但是它的配置过于复杂,我想配置一套自己的一套开发环境
视频中的 remote-container 已经更名为 dev-container,而 0.245.2 以上版本的 dev-container 有问题,会报”An error occured setting up the container - Remote Docker”,在 Issues 中有人给出了方法是降级到 0.245.2
当降级到 0.245.2,就可以愉快的使用 dev-container 了
现在我们已经成功了 dev-container 插件
现在我们要做的是,通过 dockerfile 生成一个 linux 容器,并在这个容器中开发
小试牛刀
1 | FROM centos:8 |
我们基于 centos:8 来构建一个镜像,其中,打印系统名和查看系统
点击添加终端,就进入容器中了,这个容器就是我们基于 vscode 的 dev-container 插件
如果只是个裸机,是万万不行的,我们需要安装一些开发环境和应用,提高我们的开发效率
更新所有包
在更新包之前,我们要先修改 centos 的镜像源
1 | RUN cd /etc/yum.repos.d/ |
修改成国内的镜像,再更新包
1 | RUN yum update -y |
下载 vim
先下载 vim
1 | RUN yum install vim -y |
如何配置,怎么配置 vim,介于还处于新手阶段,就常规操作即可,不用配置什么
下载 oh-my-zsh
如果冒冒失用它官网的下载链接,会报错
1 | RUN sh -c "$(curl -fsSL https://raw.github.com/ohmyzsh/ohmyzsh/master/tools/install.sh)" |
意思是说 Github 的 raw.githubusercontent.com 域名解析污染,访问不了
解决方法有不少,如通过修改 hosts 解决此问题,先在 ipaddress查询 raw.githubusercontent.com 的真实 IP,在修改 hosts
1 | vim /etc/hosts |
添加199.232.68.133 raw.githubusercontent.com
重新下载 zsh
1 | sh -c "$(curl -fsSL https://raw.github.com/ohmyzsh/ohmyzsh/master/tools/install.sh)" |
这方法只能在 linux 中使用,如果你要用 dockerfile 中修改 /etc/hosts,就行不通,因为 /etc/hosts 文件是只读的,笔者在这里花了不少时间想解决,但还是没找到解决方法
还有一种方法是修改下载源,换成国内地址
1 | sh -c "$(curl -fsSL https://gitee.com/mirrors/oh-my-zsh/raw/master/tools/install.sh)" |
并将默认命令行修改成 on-my-zsh
1 | RUN chsh -s /bin/zsh |
但这个方法需要两个前提,一是需要下载 git
1 | RUN yum install git -y |
二是因为 centos 8 系统中并未带 chsh 命令工具,会提示 chsh: command not found
,原因是系统没有自带的 util-linux-user
工具包导致,所以在执行 chsh 命令前,先安装它
1 | RUN yum install util-linux-user -y |
如此,我们就配置好了一个基于 centos 的有 vim、on-my-zsh 的 linux 环境
完整的 dockerfile 如下所示:
1 | FROM centos:8 |
光有这些不够,还要下载前端环境、如 node 、pnpm,还有后端环境,笔者最近也对 ruby 很感兴趣,也会在这里安装 ruby 环境
前端环境
我们采用 nvm 来控制 node 版本
安装 nvm 的方式有很多种,像方应杭是下载源码,再拷贝到容器中,如果没有网络限制,也可以用 curl 下载等等,我采用的是 git install
1 | ENV NVM_DIR /root/.nvm |
再通过 nvm 下载最新版本的 node
1 | RUN nvm install stable |
但是这样会报错,说 nvm: command not found
,为什么这样,不求甚解,去找另一种解决方法
笔者选择先安装个默认版本的 node 和 npm,按照这里的包管理安装
1 | RUN dnf module install nodejs:16 |
默认
dnf module install nodejs
会安装 v10 版本,太低了,最高 16,选新不选久
再下载 pnpm ,将其设为包管理器
1 | RUN curl -fsSL https://get.pnpm.io/install.sh | sh - |
如此一来,前端的开发环境以及 node 环境就在这个 dockerfile 中了
ruby 环境
我找的教程是这个,日本人做的,内容很齐全,按照步骤,能运行好环境
1 | RUN dnf module install ruby:3.0 -y |
如此一来,我们的开发环境就初步弄好了,我将它发布到 dockerhub 上,如果有需要,可以以此改造
总结
这篇文章花了我不少时间,主要很多 linux 知识点为涉猎过,之前也没在虚拟机上配置 linux 的经验。不过还好,算完成了,如此一来,开发时就可以用 vscode + linux 开发应用了,剩下的就是熟悉它