1. 建立一个文件夹
  2. 用管理员身份打开powershell.
  3. 在文件夹下面运行npm init, 根据提示填入信息,以便产生一个package.json文件。
  4. 在文件中加入需要的dependencies,例如:
  5. {
  6. "name":
    "docker_web_app",
  7. "version":
    "1.0.0",
  8. "description":
    "Node.js on Docker",
  9. "author":
    "First Last <first.last@example.com>",
  10. "main":
    "server.js",
  11. "scripts": {
  12. "start":
    "node server.js"
  13. },
  14. "dependencies": {
  15. "express":
    "^4.13.3"
  16. }
  17. }
  18.  

    4. 创建一个app.js文件,例如:

    const express = require('express')

    const app = express()

     

    app.get('/', function (req, res) {

    res.send('Hello World!')

    })

     

    app.listen(3000, function () {

    console.log('Example app listening on port 3000!')

    })

     

    5. 创建一个空文件名字为Dockerfile,填入如下内容:

    FROM node:boron

     

    # Create app directory

    WORKDIR /app

     

    # Install app dependencies

    COPY package.json .

    # For npm@5 or later, copy package-lock.json as well

    # COPY package.json package-lock.json ./

     

    RUN npm install

     

    # Bundle app source

    COPY . .

     

    EXPOSE 3000

    CMD [ "node", "app.js" ]

     

    6. 创建名为.dockerignore的文件,并输入如下的内容:

node_modules

npm-debug.log

 

这是为了防止本地的module和debug log被拷贝进docker image.

(我这一步无法做,因为没有办法创建这样的文件,总是要求必须有文件名。需要进一步调查)

7. Build image

docker build -t nodehello .

 

8. 运行image.

docker run -p 3000:3000 -d nodehello

 

如果运行成功,会出现Example app listening on port 3000的字样。

 

这时访问http://localhhost:3000 就可以访问app.js中定义的内容了。

 

参考文章:

https://nodejs.org/en/docs/guides/nodejs-docker-webapp/

https://www.distelli.com/docs/tutorials/build-and-deploy-nodejs-with-docker/

https://expressjs.com/en/starter/hello-world.html

https://docs.docker.com/get-started/part2/#build-the-app

 

 

 

如何用Docker建立一个Node.js的开发环境的更多相关文章

  1. 《Node.js入门》CentOS 6.5下Node.js Web开发环境搭建笔记

    近期想尝试一下英特尔的基于WebRTC协同通信开发套件,所以须要在本地搭建Node.js Web的开发測试环境. 这里讲的是CentOS 下的搭建方法.使用Windows的小伙伴请參考: <No ...

  2. node.js之开发环境搭建

    一.安装linux系统 (已安装linux可跳此步骤) 虚拟机推荐选择:VirtualBox 或者 Vmware (专业版永久激活码:5A02H-AU243-TZJ49-GTC7K-3C61N) 我这 ...

  3. Ubuntu 14.04下搭建Node.js的开发环境

    最近想找一个轻量级且支持快速开发的服务开发平台,选来选去选择了Node.js,当时有几种选择: Python + Django(用过Django,虽然开发快速,但是感觉性能并不太好). Ruby + ...

  4. Windows 7下Node.js Web开发环境搭建笔记

    Node.js是什么? 我们看看百科里怎么说的?JavaScript是一种运行在浏览器的脚本,它简单,轻巧,易于编辑,这种脚本通常用于浏览器的前端编程,但是一位开发者Ryan有一天发现这种前端式的脚本 ...

  5. 建立一个node.js服务器(使用express搭建第一个Web环境)

    一.官网下载node.js 下载地址:https://nodejs.org/en/download/ 根据向导,下一步安装就可以了! 二.使用express搭建Web环境 express是一个开源的n ...

  6. Docker学习之——Node.js+MongoDB+Nginx环境搭建(一)

    最近在学习Node.js相关知识,在环境搭建上耗费了不少功夫,故此把这个过程写下来同大家分享一下,今天我先来介绍一下Docker,有很多人都写过相关知识,还有一些教程,在此我只想写一下,我的学习过程中 ...

  7. 部署node.js的开发环境

    1.进入Node.js的官方网站下载安装包: http:nodejs.org 2.安装后打开cmd的dos窗口(在path环境变量中查看到有nodejs说明安装成功): 3.运行node.

  8. 搭建Node.js Redis开发环境

    创建项目 初始化为node项目 $npm init   安装redis   安装@types/node, @types/redis, typescript   初始化TypeScript   配置ts ...

  9. node.js vue开发环境搭建

    开发工具安装 1.安装node.js 双击安装程序 node-v8.9.3-x64.msi,进行安装即可 2.设置taobao镜像 npm config set registry https://re ...

随机推荐

  1. CF 222 (DIV 1)

    A: 我是bfs出一颗树,然后删掉树后面的k个结点. 其实也可以直接bfs出一块连通的s - k个点,其余的.打X就可以了. 很水的题目. /* *************************** ...

  2. General PE format layout

  3. [Go] 单元测试/性能测试 (go test)

    特征 Golang 单元测试对文件名和方法名,参数都有很严格的要求.例如: 1.文件名必须以 _test.go 结尾 2.方法名必须是 Test 开头 3.方法参数必须是 t *testing.T 或 ...

  4. 对 Git 分支 master 和 origin/master 的一些认识

    首先要明确一点,对 Git 的操作是围绕 3 个大的步骤来展开的(其实几乎所有的 SCM 都是这样) 从 git 取数据(git clone) 改动代码 将改动传回 git(git push) 这 3 ...

  5. CF 427D Match &amp; Catch 求最短唯一连续LCS

    题目来源:CF 427D Match & Catch 题意:给出2个字符串 求最短的连续的公共字符串 而且该字符串在原串中仅仅出现一次 思路:把2个字符串合并起来求height 后缀数组hei ...

  6. 使用log4jdbc记录SQL信息

    一.log4jdbc的简单介绍 使用log4jdbc在不改变原有代码的情况下,就可以收集执行的SQL文和JDBC执行情况. 平时开发使用的ibatis,hibernate,spring jdbc的sq ...

  7. Android: INSTALL_FAILED_UPDATE_INCOMPATIBLE错误解决措施

    晚上在测一个widget,前面测的好好的,后面再安装的时候发现如下错误:[2009-06-07 02:39:35 - battery] Performing sync[2009-06-07 02:39 ...

  8. DirectX - dds图片格式(DDSURFACEDESC2)

    DDS是DirectDraw Surface的缩写,它是DirectX纹理压缩(DirectX Texture Compression,简称DXTC)的产物. DXTC减少了纹理内存消耗的50%甚至更 ...

  9. Tomcat服务器集群与负载均衡实现

    一.前言 在单一的服务器上执行WEB应用程序有一些重大的问题,当网站成功建成并开始接受大量请求时,单一服务器终究无法满足需要处理的负荷量,所以就有点显得有 点力不从心了.另外一个常见的问题是会产生单点 ...

  10. python测试开发django-21.admin后台表名称和字段显示中文

    前言 admin后台页面表名称(默认会多加一个s)和字段名称是直接显示在后台的,如果我们想设置成中文显示需加verbose_name和verbose_name_plural属性 verbose_nam ...