当前位置: 首页 > news >正文

网站开发中怎么设置快捷键艺术设计招聘网站

网站开发中怎么设置快捷键,艺术设计招聘网站,推荐一个做健身餐的网站,温州市网站制作多少钱Docker部署 本节我们来介绍如何使用 Docker 部署 express 应用 准备工作 linux 系统安装好 Docker一个基础的 evp-express-cli 项目,选上 pkg 工具包Docker 的详细用法本文不做介绍,请先自行查阅了解 在 Docker 中部署源码 一个很简单的部署方法就是…

Docker部署

本节我们来介绍如何使用 Docker 部署 express 应用

准备工作

  • linux 系统
  • 安装好 Docker
  • 一个基础的 evp-express-cli 项目,选上 pkg 工具包
  • Docker 的详细用法本文不做介绍,请先自行查阅了解

在 Docker 中部署源码

一个很简单的部署方法就是,拉取一个 node 基础镜像,直接在里面运行 express 项目:
以下是 .dockerignore 示例:

node_modules
dist

以下是响应的 Dockerfile 示例:

# Build environment
FROM node:16
ENV NODE_ENV=productionWORKDIR /appCOPY . .RUN npm installEXPOSE 8080
CMD ["node src/index.js"]

基本流程就是:

  1. 拉取node镜像
  2. 指定工作目录
  3. 拷贝项目源码及资源文件
  4. 安装依赖
  5. 暴露端口
  6. 设置启动命令

在 Docker 中构建部署

上面采取的是直接部署源代码,当然也可以先对源码进行构建再部署。这里又可以分为两种,一种仍然需要 node 运行时,仅仅借助 rollup 之类的工具将源码打包为单个 .js 文件,然后部署时只需拷贝这单个文件即可,具体过程无需再做介绍

另一种是脱离 node 运行时,使用 pkg 构建 express 项目,最终部署构建产物到纯净的 linux 镜像即可。如果你在进行 docker 部署前,事先构建好再部署,那具体做法也不需介绍,本文介绍的是在 docker 中阶段的从零构建到部署的过程:

编写 Dockerfile:

  1. 拉取合适的 node 镜像作为构建环境,builder 是构建镜像别名,可以随便取(后面有用):
# Build environment
FROM node:16 AS builder
ENV NODE_ENV=production
  1. 拷贝依赖配置文件(package.jsonpackage-lock.json*)到指定目录(后面有用)
WORKDIR /appCOPY ["package.json", "package-lock.json*", "./"]
  1. 安装依赖包
RUN npm install
  1. 拷贝源码以其它要一并被打包进可执行程序的文件
ADD src src
ADD assets assets
  1. 构建适用于linux的可执行程序,示例的产物名为 DockerDeploy(后面有用)
RUN npm run build:linux
  1. 拉取一个 linux 镜像作为运行环境,示例选用了 debian,具体能用哪个还要视项目而定
# lightly runtime environment
FROM debian
  1. 设置时区,如果需要的话
RUN ln -sf /usr/share/zoneinfo/Asia/Shanghai /etc/localtime
RUN echo 'Asia/Shanghai' >/etc/timezone
  1. 构建镜像将中构建好的可执行程序拷贝到到运行镜像下的指定目录
    语法:COPY --from=构建镜像别名 可执行程序路径 指定目录路径
COPY --from=builder /app/dist/DockerDeploy /app/
  1. 拷贝外部的资源文件和文件夹(如果有的话),示例没有,略过,如有,用 ADDCOPY 即可
  2. 暴露端口,并在指定目录下运行可执行程序
WORKDIR /appEXPOSE 8080
CMD ["./starfolder-service"]

以下是完整的 Dockerfile 示例:

# Build environment
FROM node:16 AS builder
ENV NODE_ENV=productionWORKDIR /appCOPY ["package.json", "package-lock.json*", "./"]RUN npm installADD src srcRUN npm run build:linux# lightly runtime environment
FROM debianRUN ln -sf /usr/share/zoneinfo/Asia/Shanghai /etc/localtime
RUN echo 'Asia/Shanghai' >/etc/timezoneCOPY --from=builder /app/dist/starfolder-service /app/WORKDIR /appEXPOSE 8080
CMD ["./DockerDeploy"]

这样的分阶段构建过程,可以尽可能得减小最终的镜像体积


下一节-pm2进程管理

http://www.yayakq.cn/news/93396/

相关文章:

  • 做网站头文件wordpress 加载字体
  • 深圳网站制作开发排名南昌房产网站建设
  • 杭州做网站哪家好重庆沙坪坝网站建设
  • 做照片模板下载网站好中医协会网站建设方案
  • 优秀的个人博客网站外贸网站推广企业
  • 在线免费作图软件肇庆市seo网络推广
  • 汝州市文明建设网站网站建设需准备什么
  • 网站建设找a金手指变装第三性wordpress
  • 商务网站开发的基本原则网页生成pdf不显示
  • 上海公司买房做seo怎么设计网站
  • 廊坊专门做网站网站建设下什么科目
  • 景区网站建设方案营销型网站主机
  • 可以做淘宝联盟的免费网站设计作品网站有哪些
  • 网站开发实施计划山东网页制作网站
  • 秦淮网站建设建设游戏网站需要什么设备
  • 做企业网站 需要用服务器吗wordpress 目录扫描
  • 阿里企业网站托管wordpress cms教程
  • 360客户如何做网站推广wordpress地区分站
  • 免费网站推广app谷歌seo怎么做的
  • 宣城网站开发网络公司网站外链平台
  • 北京网站开发网站建设价格新手怎么做详情页
  • 网站建设文化教程互联网项目有哪些可做
  • 河南建设信息网站做二手房产网站多少钱
  • 郑州门户网站建设在家开个人工作室违法吗
  • 免备案免费空间宁波seo哪家好快速推广
  • 网站新闻专题怎么做wordpress 屏蔽爬虫
  • 济南建站公司模板企业展厅设计装修
  • 佛山自助建站系统网站开发哪种语言最好
  • 网站开发中 敬请期待seo搜索引擎官网
  • 微信公众号对接网站外贸网站增加外链方法