使用 pkg 打包分发 nodejs 应用

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

环境准备

能够参考: http://www.javashuo.com/article/p-vysuzxim-my.html,具体的代码就不用粘贴,主要说明pkg
的使用html

  • 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-composenode

相关文章
相关标签/搜索