码迷,mamicode.com
首页 > Web开发 > 详细

使用 pkg 打包分发 nodejs 应用

时间:2019-01-28 13:50:26      阅读:1780      评论:0      收藏:0      [点我收藏+]

标签:line   macos   body   image   重要   assets   mit   而且   工具   

pkg 是一个很不错的跨平台 nodejs 应用打包工具,使用此工具,我们只需要给与用户提供一个简单的
可执行文件就可以了,同时代码也是二进制的,提高了代码的安全性
备注:测试demo 很简单,也比较典型,包装了sofa 框架,我们可以直接查看graphql api 以及open api

环境准备

可以参考: https://www.cnblogs.com/rongfengliang/p/10326302.html,具体的代码就不用粘贴,主要说明pkg
的使用

  • package.json 文件
 {
  "name": "sofa-graphql2rest",
  "version": "1.0.0",
  "license": "MIT",
  "main": "index.ts",
  "pkg": {
    "scripts": "dist/**/*.js",
    "assets":["node_modules/swagger-ui-dist/**/*.*","node_modules/swagger-ui-express/**/*.*"]
  },
  "bin": "dist/index.js",
  "scripts": {
    "start": "ts-node index.ts",
    "build":"tsc"
  },
  "dependencies": {
    "body-parser": "1.18.3",
    "chalk": "2.4.2",
    "express": "4.16.4",
    "express-graphql": "0.7.1",
    "graphql": "^14.0.2",
    "graphql-subscriptions": "^1.0.0",
    "graphql-tag": "2.10.0",
    "graphql-tools": "4.0.3",
    "sofa-api": "^0.2.2",
    "swagger-ui-express": "4.0.2"
  },
  "devDependencies": {
    "@types/swagger-ui-express": "3.0.0",
    "@types/body-parser": "1.17.0",
    "@types/express": "4.16.0",
    "@types/express-graphql": "0.6.2",
    "@types/graphql": "14.0.3",
    "esm": "^3.0.84",
    "ts-loader": "^5.3.3",
    "ts-node": "7.0.1",
    "typescript": "3.2.2"
  }
}
  • 说明
    对于pkg 的打包我们需要的主要是package.json 文件的配置,同时注意需要包好bin 以及pkg,对于依赖的静态资源
    也需要说明,比如上边的因为swagger ui 需要一个依赖css 资源,同时也是一个npm 包,所以 在pkg 配置中,手工
    指定了加载的资源,这个很重要,类似的问题都可以使用这种方法解决
    "assets":["node_modules/swagger-ui-dist/**/*.*","node_modules/swagger-ui-express/**/*.*"]

构建&&效果

  • 安装pkg (全局)
npm install -g pkg 
  • 构建
    不指定平台的话,默认是三端的(linux,mac windows)
pkg   . 
  • 运行
    ./sofa-graphql2rest-macos
    技术分享图片
    技术分享图片
    技术分享图片

说明

使用pkg 的打包方式,对于我们减少代码包的大小也是很不错的,比如在容器中运行,而且对于软件的分发也很方便,而且跨平台。
## 参考资料
https://github.com/rongfengliang/sofa-graphql2rest-docker-compose

使用 pkg 打包分发 nodejs 应用

标签:line   macos   body   image   重要   assets   mit   而且   工具   

原文地址:https://www.cnblogs.com/rongfengliang/p/10329403.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!