位置: 编程技术 - 正文
推荐整理分享在Docker快速部署Node.js应用的详细步骤(docker如何部署环境到生产),希望有所帮助,仅作参考,欢迎阅读内容。
文章相关热门搜索词:docker如何部署环境到生产,docker dockerfile快速部署环境,docker部署kibana,docker快速部署项目,docker部署项目的两种方式,docker快速部署tomcat,docker快速部署项目,docker快速部署项目,内容如对您有帮助,希望把文章链接给更多的朋友!
一、前言
可能还有一些同学不了解docker这个项目,docker是由go语言编写的,一个快速部署的轻量级虚拟技术项目,他允许开发人员将自己的程序和运行环境一起打包,制作成一个docker的image(镜像),这样部署到服务器上,也只需要下载这个image就可以将程序跑起来,免去每次都安装各种依赖和环境的麻烦,还能够做到应用程序之间的隔离
二、实现准备
我会先创建一个简单的Node.js web app,来构建一个镜像。然后基于这个Image运行一个container。从而实现快速部署。
由于网络的原因我的Node.js镜像从国内的镜像库下载,而不是Docker Hub。
先从国内的镜像网站上pull下一下nodejs镜像。
下载完后查看我们的镜像,找到他的名称,等会我们会用到
三、创建Node.js 程序
创建package.json,并写入相关信息和依赖
创建server.js
写一个最简单web 这个web基于express框架,返回Hello word.注意我们监听的是端口
四、创建Dockerfile
接下来主角上场了创建Dockerfile文件 这个文件是创建镜像所必须的文件
Docker会依照Dockerfile的内容来构建一个镜像。我先给出完整的代码,再一行一行的给出解释
我们来一句一句的解释
FROM是构建镜像的基础源镜像,hub.c..com/nce2/nodejs:0..2 这个是镜像的名称,也就是我们一开始从国内服务器上拉下来的那个Image。如果本地没有Docker 会自己pull镜像。
第一句RUN 用于在Image里创建一个文件夹,将来用于保存我们的代码。
第二句WORKDIR是将我们创建的文件夹做为工作目录。
第一句的COPY是把本机当前目录下的所有文件拷贝到Image的/home/Service文件夹下。
第二句的RUN 使用npm 安装我们的app据需要的所有依赖。
由于我们的web app监听的是端口,我们把这个端口暴露给主机,这样我就能从外部访问web了。
这个我相信我不用解释你也能看出来他是做什么的。运行npm start命令,这个命令会运行 node service.js来
启动我们的web app。
五、构建Image
在你Dockerfile文件所在的目录下运行下面的命令来构建一个Image.
别忘了最后的的那个点
构建完后查看一下我们的镜像
六、运行镜像
-d 表明容器会在后台运行,-p 表示端口映射,把本机的商品映射到container的端口这样外网就能通过本机的商品访问我们的web了。
后面的ac5是我们Image的ID因为前3个就已经能定位出这个Image所以我就没有把后边的再写出来。
通过docker ps 查看我们刚运行的Container的ID
打印log 就是我们的Container ID,和Image ID一样,你也可以全写出来,我比较懒就写前4位,已经足够标识出这个Container了
如果你想到Container里可以执行下面的命令,进入到里边后就可以像操作普通的linux 一样。如果想退出可执行exit命令。
七、测试
我们先通过curl 看能不能访问我们的web。
也可以通过浏览器来看一下
八、总结
好了,这个小教程到此就结束了,大家都学会了吗?希望这篇文章能帮助你入门。如果有什么问题或者疑问可以留言交流。谢谢大家对积木网的支持。
解决node.js安装包失败的几种方法 镜像使用方法(三种办法任意一种都能解决问题,建议使用第三种,将配置写死,下次用的时候配置还在):1.通过config命令
Node.js实现兼容IE的文件上传进度条 Nodejs对文件上传的处理在Express4里req.files已经是undefined了;现在用的最多的可能就是formidable了,你知道了它有个progress事件,于是心中大喜,低版本IE的
nodeJs内存泄漏问题详解 之前一次偶然机会发现,react在server渲染时,当NODE_ENV!=production时,会导致内存泄漏。具体issues:
标签: docker如何部署环境到生产
本文链接地址:https://www.jiuchutong.com/biancheng/370789.html 转载请保留说明!友情链接: 武汉网站建设