首页 > 其他分享 >pkg对egg项目打包

pkg对egg项目打包

时间:2022-12-20 10:57:25浏览次数:40  
标签:win js pkg config egg 打包

前言
项目部署,没做之前以为很简单,不就跟vue一样build一下就行么,然而并不是这样的,在第一次对egg项目打包使用了各种方法,也都无果,最后还是使用了egg官网的项目部署,上传服务器之后解压完,还是能看见源代码,这就让有些人说,你不能把源代码给放在服务器上啊,我也想啊,于是抽出时间对pkg打包进行了一些时间的研究,有所小成,何为小成,小成也,运行之成功,访问之成功,请求之成功也……

一、pkg是什么?
pkg在这里是协助打包的工具,更多请看pkg.

二、使用步骤(win&linux)
由于服务器的node版本是12的,所以打包就选择了12的版本

1.公共部分

 1 config/config.default.js文件下
 2 
 3 const process = require('process'), path = require('path');//这句放在外面
 4 config.static = {
 5 prefix: '/public',
 6 dir: process.cwd() + '/public',
 7 };
 8 config.rundir = process.cwd() + '/run';
 9 config.logger = {
10 dir: path.join(process.cwd(), 'logs', '/'),
11 outputJSON: false,
12 };
13 build.js文件(自己创建)
14 
15 'use strict';
16 const egg = require('egg');
17 const workers = Number(process.argv[2] || require('os').cpus().length);
18 egg.startCluster({
19 workers,
20 baseDir: __dirname,
21 });
22 package.json文件
23 
24 "scripts": {
25 "build": "pkg . --targets node12-win-x64 --out-path ./mydist --debug",//加上这句
26 ...
27 },
28 "pkg": {
29 "scripts": [
30 "./app/**/*.js",
31 "./config/*.js",
32 "./config/*",
33 "./app.js",
34 "./node_modules/nanoid/**/*.js",
35 "./node_modules/nanoid/**/*.cjs"
36 ],
37 "assets": [],
38 "targets": [
39 "node12-win-x64"
40 ]
41 },
42 "bin": "build.js",

 

2.windows
1.由上面的公共部分可以看出node-12后面是win的,在运行npm run build 之前,先安装一下pkg,命令是npm i -g pkg
2.到打包的目录下,可以直接在vscode中进入终端运行,本人是在资源管理中打开再cmd,两者命令输入的命令相同, 名称.exe ,回车就会运行,
3.可能遇到的问题,就是运行报pkg或者报node的错误,这个问题可是困扰了两三天,由于我的egg版本是4,改为3就可以了。

3.linux
1.把公共部分中的win改为linux,再次打包.
2.运行命令为 ./名称 start
3.可能遇到的问题,在服务器启了,但是访问不到,可以试试把config/config.default.js文件下的hostname改为0.0.0.0如下:

1 config.cluster = {
2 listen: {
3 path: '',
4 port: 端口号,
5 hostname: '0.0.0.0'
6 }
7 }


总结
写了这么多也该有个总结,以上就是本期的内容,只是简单的使用了下pkg,如何打包成win和linux的,以及运行之后所出现问题的介绍,如您有更好的办法,欢迎评论加点赞,我们一同学习……

原文链接:https://blog.csdn.net/weixin_44637104/article/details/128181127

标签:win,js,pkg,config,egg,打包
From: https://www.cnblogs.com/dss0223/p/16993721.html

相关文章