docker学习系列7 容器化Node项目
本节我们自己打包一个docker镜像并发布到官方的镜像仓库中。这样任何人只需执行以下命令:docker run -d -p 3000:3000 finleyma/express
就可以访问一个简单的express程序了。
需要你有简单的express使用经验
实现过程非常简单:
- 本地全局安装
npm install express-generator -g
- 初始化一个express项目
express myapp
- cd myapp,然后 npm run start,项目就在本地运行了。
- 我们在项目内建立Dockerfile,内容如下:
FROM node:10.8.0-alpine MAINTAINER www.mafeifan.com # 设置工作目录,下面的RUN命令会在工作目录执行 WORKDIR /app # 先拷贝本地的 package.json 和 package-lock 到容器内 # 这样是利用docker的镜像分层机制 COPY package*.json ./ # 安装项目依赖包 # 生产环境可以运行 RUN npm install --only=production 只按照 package.json 中dependencies定义的模块 RUN npm install # 将根目录下的文件都copy到container(运行此镜像的容器)文件系统的app文件夹下 ADD . /app/ # 暴露容器内的3000端口 EXPOSE 3000 # 容器启动时执行的命令,类似npm run start CMD ["npm", "start"]
- 构建镜像
docker build -t finleyma/express .
别忘了最后的点,表示当前目录 - 启动容器
docker run -d -p 3000:3000 finleyma/express
- 可选,登录docker hub, 并提交镜像。
docker login
,docker push finleyma/express
- 进入容器
docker run -it --rm finleyma/express:1.0 ash
简要说下参数:
- -it:这是两个参数,一个是 -i:交互式操作,一个是 -t 终端。我们这里打算进入 容器 执行一些命令并查看返回结果,因此我们需要交互式终端。
- --rm:这个参数是说容器退出后随之将其删除。默认情况下,为了排障需求,退出的容器并不会立即删除,除非手动 docker rm。我们这里只是随便执行个命令,看看结果,不需要排障和保留结果,因此使用 --rm 可以避免浪费空间。
- ash:因为我们的Node的基础镜像是10.8.0-alpine, alpine的交互式 Shell是ash不是bash,使用bash会提示not found。注意这个细节。
会发现整个项目文件都在容器内。
简单总结使用Docker的好处:
- 使用版本方便,比如服务器上跑着node6,而你的项目需要node8以上。使用docker因为是隔离的环境
- 部署分享也方便,一行命令完事
问题:容器内的 node_modules 是本来就有还是容器执行 npm install 产生的呢?
答案:是构建的时候打包进镜像内了。我们看一下体积,有20M而且进到容器内, ls -l node_modules 时间也是打包的什么,并不是当前时间。
参考:
https://nodejs.org/en/docs/guides/nodejs-docker-webapp/
https://www.imooc.com/article/19840
https://github.com/nodejs/docker-node/blob/master/docs/BestPractices.md
低调大师中文资讯倾力打造互联网数据资讯、行业资源、电子商务、移动互联网、网络营销平台。
持续更新报道IT业界、互联网、市场资讯、驱动更新,是最及时权威的产业资讯及硬件资讯报道平台。
转载内容版权归作者及来源网站所有,本站原创内容转载请注明来源。
- 上一篇
Coding and Paper Letter(十二)
版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/ESA_DSQ/article/details/81750475 资源整理。 1 Coding: 2 Paper: 1 Coding: 1.R语言生成的ppt,GeoStat2018会议报告,时空模式分析的报告。 geostat18 2.欧空局哨兵和SMOS的工具集,关于对地观测数据的处理与分析的docker容器。 docker esa snap 3.R语言包ggmapstyles,一个R包可以切换各种不同风格的地图。 ggmapstyles 4.地理空间的docker镜像并且打包成AWS(亚马逊云服务器)的linux系统。 geolamda 5.R语言包ggrastr,ggplot2的拓展包,专门针对栅格几何图形。 ggrastr 6.一系列关于使用Google Earth Engine(GEE)的工具(javascript)。 geetools code editor 7.R语言教程展示如何构建一个简单的ABM模型。 cultural evolution ABM tutorial 8....
- 下一篇
混合云存储跨云灾备方案之跨云容灾
前面两篇文章介绍了基于阿里云备份的跨云备份和云存储网关的跨云复制,两者主要是解决文件粒度的备份与恢复问题。如果用户需要保护一个云上的数据库应用,而不仅仅是数据库的数据文件;如果用户需要保护整个云主机,而不止一些文件和目录;且用户对于保护同样是有实时性要求的。那么,混合云容灾就是为这些用户需求量身打造的拳头产品。 基于混合云容灾的跨云容灾架构 下图描述了从云厂商T的一台Oracle服务器,通过混合云容灾恢复网关,备份到阿里云上的云灾备库中,再恢复(fail-over)到阿里云ECS的过程。混合云容灾恢复网关同时还支持将在云灾备库的最新数据恢复回(fail-back)到云厂商T的Oracle主机中。通过这张架构图,用户可以了解到,容灾的部署在源端和目的端是对称的。需要用户注意的一点是,图中云灾备库是虚线画的。不同于云备份库和OSS,云灾备
相关文章
文章评论
共有0条评论来说两句吧...
文章二维码
点击排行
推荐阅读
最新文章
- CentOS关闭SELinux安全模块
- SpringBoot2整合Redis,开启缓存,提高访问速度
- Windows10,CentOS7,CentOS8安装Nodejs环境
- Red5直播服务器,属于Java语言的直播服务器
- CentOS6,CentOS7官方镜像安装Oracle11G
- Springboot2将连接池hikari替换为druid,体验最强大的数据库连接池
- CentOS7编译安装Gcc9.2.0,解决mysql等软件编译问题
- SpringBoot2整合Thymeleaf,官方推荐html解决方案
- CentOS7安装Docker,走上虚拟化容器引擎之路
- Jdk安装(Linux,MacOS,Windows),包含三大操作系统的最全安装