使用docker运行服务,你可以拥有一致的环境,可以精确控制服务的运行资源(cpu,内存),可以方便的设置端口和网络,可以使用镜像仓储管理和分发代码。现在越来越多的开发者选择将服务运行在docker上。
好多nodejs用户在使用docker时,直接使用了默认的node镜像。但你不觉得它太大了吗?现在
node:6.10.1镜像的体积已经达到666M,其实要实现同样的功能,只需43.5M就够了。尺寸小,意味者更低的资源消耗,更快的下载速度,更小的传输带宽。下面将介绍如何创建极简node镜像。FROM: 设置alpine基础镜像
目前docker下最轻量的操作系统是alpine,一个alpine的体积不到5M。node默认镜像依赖的基础镜像是debian, debian:jessie体积已打123M,所以想减小尺寸,首要就是从基础镜像切换到alpine。
FROM alpine:3.5RUN: 设置node用户
adduser -D -u 1000 node
设置node用户是可选的。添加用户后在运行容器是可以指定已node用户的身份运行服务
RUN: 安装node编译工具
apk add --no-cache
libstdc++
&& apk add --no-cache --virtual .build-deps
binutils-gold
curl
g++
gcc
gnupg
libgcc
linux-headers
make
python
apk add --no-cache不使用本地缓存安装包数据库,直接从远程获取安装包信息安装。这样我们就不必通过apk update获取安装包数据库了
apk add --virtual .build-deps将本次安装的所有包封装成一个名为.build-deps的虚拟包。这样做的好处是可以通过
apk del .build-deps一键清除这些包RUN: 导入node源码包公钥
for key in
9554F04D7259F04124DE6B476D5A82AC7E37093B
94AE36675C464D64BAFA68DD7434390BDBE9B9C5
FD3A5288F042B6850C66B31F09FE44734EB7990E
71DCFD284A79C3B38668286BC97EC7A07EDE3FC1
DD8F2338BAE7501E3DD5AC78C273792F7D83545D
B9AE9905FFD7803F25714661B63B535A4C206CA9
C4F0DFFF4E8C1A8236409D08E73BC641CC11F4C8
56730D5401028683275BD23C23EFEFE93C4CFFFE
; do
gpg --keyserver ha.pool.sks-keyservers.net --recv-keys "$key";
done这些公钥将用来校验我们通过curl下载的nodejs源码文件
RUN: 下载并node校验源码文件
curl -SLO "https://nodejs.org/dist/v$NODE_VERSION/node-v$NODE_VERSION.tar.xz"
&& curl -SLO "https://nodejs.org/dist/v$NODE_VERSION/SHASUMS256.txt.asc"










