位置: 编程技术 - 正文

基于 Docker 开发 NodeJS 应用(docker 开源项目)

编辑:rootadmin

推荐整理分享基于 Docker 开发 NodeJS 应用(docker 开源项目),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:docker基于什么语言开发,docker应用开发实例,用docker开发,docker应用开发实例,基于docker部署,基于docker开发,使用docker搭建开发环境,基于docker开发,内容如对您有帮助,希望把文章链接给更多的朋友!

有关这个 Node 应用

此应用包含一个 package.json, server.js 以及一个 .gitignore 文件, 它们简单到可以信手拈来.

.gitignore

package.json

server.js

server.js 会拉取所有的依赖并启动一个特定的应用. 这个特定的应用被设定成将会话信息存储到Redis中,并暴露出一个请求端点,其会响应返回一个JSON的状态消息. 这都是非常标准的东西.

需要注意的一件事情就是针对Redis的连接信息可以使用环境变量重写——这将会在稍后从开发环境dev迁移到生产环境prod时起到作用.

Docker file

为了开发的需要,我们将会让Redis和Node在同一个容器中运行。为此,我们将使用一个Dockerfile来配置这个容器。

Dockerfile

我们一行一行的来理解,

FROM dockerfile/ubuntu这回告诉docker要使用Docker Inc. 提供的 dockerfile/ubuntu 镜像. 作为构建的基准镜像.

RUN apt-get -y -qq install python redis-server基准镜像完全没有包含任何东西——因此我们需要使用apt-get来获取应用运行起来所需的所有东西. 这一句会安装python 和 redis-server. Redis 服务器是必须的,因为我们将会把会话信息存储到它之中,而python的必要性则是通过npm可以构建为Redis node模块所需的C扩展.

这会下载并提取位的NodeJS二进制文件.

这句会告诉docker一旦容器已经启动,在执行CMD属性指定的东西之前,要做一次 cd /src.

作为最后一步,运行 /bin/bash.

构建并运行容器

现在docker文件写好了,让我们来构建一个Docker镜像吧.

一旦把镜像构建好了,我们就可以使用下面的语句运行一个容器了:

让我们来看一看docker运行命令中发生了什么.

基于 Docker 开发 NodeJS 应用(docker 开源项目)

-i 会在交互模式下启动容器(对比 -d 是在分离模式下). 这就意味一旦交互会话结束,容器就会退出.

-t 会分配一个pseudo-tty.

--rm 会在退出时移除容器及其文件系统.

-p : 会将主机上的端口 转发到容器上的端口.

-v `pwd`:/src这句将会将当前的工作目录挂载到主机上(例如,我们的项目文件)容器中的 /src 里面. 我们将当前目录作为一个卷挂在,而不是使用Dockerfile中的ADD命令,那样我们在文本编辑器中做的任何修改都可以立即在容器中看到了.

sqldump/docker-dev:0.1 是要运行的docker镜像的名称和版本 ? 这跟我们用来构建docker镜像时使用的名称和版本是相同的.

由于Dockerfile指定了CMD ["/bin/bash"], 容器一启动,我们就会登录到一个bash shell环境中. 如果docker运行命令执行成功了,就会像下面这样:

开始开发

现在容器是运行起来了,在开始写代码之前,我们将需要整理出一些标准的,非docker相关的东西. 首先,要使用下面的语句启动容器里面的redis服务器:

然后,要安装项目依赖和nodemon. Nodemon 会观察项目文件中的变更,并适时重启服务器.

最后,使用如下命令启动服务器:

现在,如果你在浏览器中导航到 你应该会看到像下面这样的东西:

让我们来像Server.js中加入另外一个端点,以模拟开发流程:

你会看到nodemon已经侦测到了你所做的修改,并重启了服务器:

而现在,如果你将浏览器导航到 你会看到如下的响应:

生产环境

当前状态下的容器,还远不能作为产品发布.redis中的数据不会再跨容器重启时仍然保持持久化 , 比方说,如果你重启了容器,所有的会话数据就都灰飞烟灭了. 同样的事情在你销毁容器并开启一个的新的容器时也会发生,明显这不是你想要的。我将会在第二部分的产品化内容中讲到这个问题.

浅析Node在构建超媒体API中的作用 无论是超媒体还是超文本,使用的传输协议都是HTTP,这意味着超媒体可以被所有的浏览器所接受。而描述超媒体的类型我们使用MIME。MIME即MultipurposeInter

教你在heroku云平台上部署Node.js应用 虽然AWS现在也推出了自己的PaaS平台,叫ElasticBeanstalk,但heroku的优势在于它上面有很多第三方的add-on,比如MongoDB,mysql,redis,memcached,还有各种消息队列、s

基于socket.io和node.js搭建即时通信系统 使用socket.io和nodejs搭建websocket服务器端socket.io不仅可以搭建客户端的websocket服务,而且支持nodejs服务器端的websocket。下面让我来介绍一下怎么安装配置no

标签: docker 开源项目

本文链接地址:https://www.jiuchutong.com/biancheng/370841.html 转载请保留说明!

上一篇:Node.js 服务器端应用开发框架 -- Hapi.js(nodejs怎么在服务器运行)

下一篇:浅析Node在构建超媒体API中的作用(node介绍)

  • 不可抵扣进项税额转出
  • 外贸企业进项税不抵扣分录
  • 公益性捐赠税前扣除资格有效期
  • 私车公用如何处理
  • 息税前利润怎么算
  • 个税申报状态失败,如何更正申报
  • 劳务服务有什么
  • 个体户生产经营个人所得税
  • 19年高速公路免费时间
  • 当期处置子公司,当期还纳入合报范围嘛
  • 净收益营运指数大于1说明什么
  • 增值税普通发票需要交税吗
  • 无形资产使用费计入什么科目
  • 无形资产摊销是谨慎性原则吗
  • 是否退还投标文件
  • 多缴所得税返还现金流
  • 小规模纳税人免税会计分录
  • 买车交税怎么算价格
  • 销项税额抵减是怎么回事
  • 专票认证不通过退回
  • 7.1增值税普通发票怎么开?
  • 房屋销售佣金能退回吗
  • 出口企业免抵增值税
  • 专项应付款需要偿还吗
  • 金银首饰的消费税税务处理
  • 1697510703
  • 个税汇算清缴申报错误怎么办
  • 金蝶k3外购入库核算没单据
  • 公司纳税高说明什么
  • win7系统中如何关闭触摸屏声音
  • 电脑如何关闭屏幕还在工作
  • Qq浏览器里的文档怎么以文件形式发送
  • Linux系统中怎么开机自动运行拍摄文件
  • 提前预支工资怎么报税
  • 固定资产财产损失的账务处理
  • 以前年度损益调整借贷方向
  • (二) Vue3 + Element-Plus 实现动态菜单栏
  • 增值税账务处理 一般纳税人
  • 出口企业如何确认增值税收入
  • 爬虫10054
  • 呆账核销分录
  • php新版本特性
  • 免税需要什么条件
  • 物业公司收的物业费用干什么了
  • 前端将base64图片转换成file文件
  • 集团对子公司拨款的规定
  • 预付采购材料款60000元
  • c语言中数组的定义和使用
  • phpsystem函数
  • mongodb简单使用
  • 房产公司业务招待费扣除政策
  • 商业汇票贴现时间轴
  • 营改增后一般纳税人按简易办法计税的规定
  • 回购股票不注销如何发可转债
  • 小规模纳税人免税会计分录
  • 什么是品种法?适用于什么范围?
  • 专利转让费一般是多少
  • 公司报销发票需要查验真假吗
  • 营业执照的注册号怎么查询
  • 会议费报销时应当提供哪些材料
  • 实收资本增加印花税税目怎么填
  • 企业视同销售的情况都有哪些?
  • 公司向个人借款是否合法
  • 物业管理企业应当与居委会共同做好什么工作
  • 生产成本如何设置明细账
  • 安装sql server 2008硬件要求
  • 删除sql server2019
  • 安装并激活navicat
  • ubuntu gnome3
  • centos 怎么用
  • win8外接显示器没反应怎么办
  • ExtJs事件机制基本代码模型和流程解析
  • angular 图片懒加载
  • node.js详解
  • unity3D关于公共安全内容制作
  • unity开发项目
  • 正则化实现
  • 小规模纳税人可以用专票抵扣税吗
  • 无锡国税局电话咨询热线
  • 江苏税务实名认证怎么更改
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设