最近有个需求,需要使用golang做一个小工具,然后我就想既然是小工具,那就把前后端放在一个二进制文件中。恰好使用的项目架构是go frame,它已经提供了这样的能力,但是没想到碰到了一鼻子灰。。。

1.首先我安装的gf工具的版本为

GoFrame CLI Tool v2.1.0, https://goframe.org
GoFrame Version: cannot find goframe requirement in go.mod
CLI Installed At: D:\Go\gopath\gf.exe
CLI Built Detail:
Go Version: go1.17.11
GF Version: v2.1.0
Git Commit: 2022-06-21 21:52:54 3b9e5c71bfd9f19e53dc4754e2170df1c534f0bb
Build Time: 2022-06-21 22:04:44

2.然后我init的工程,go.mod文件为

go 1.15

require github.com/gogf/gf/v2 v2.0.6

3.然后我就去参考了官方文档

文档中提到只要在配置文件中配置如下参数,然后使用gf build命令打包即可

gfcli:
build:
name: "my-application"
arch: "amd64"
system: "linux"
mod: "none"
cgo: 0
pack: "manifest/config,manifest/i18n,resource/public,resource/template"
version: ""
output: "./bin"
extra: ""

但是我按照操作执行后,怎么都访问不到我添加进去的配置文件

4.使用gf build --debug=true命令

使用gf build --debug=true命令执行编译过程中,发现打印了一条日志

build input: {Meta:{} File: Name:neuedu-cli Version: Arch:amd64 System:linux Output: Path:./temp Extra: Mod:none Cgo:false VarMap:map[] PackSrc: Pa
ckDst:internal/packed/build_pack_data.go ExitWhenError:false}

里面没有打印pack参数,反而打印了PackSrc,然后是没有赋值的状态.那么我需要设置的参数会不是其实是PackSrc

5. 然后我修改配置文件如下

gfcli:
build:
name: "neuedu-cli"
arch: "amd64"
system: "linux"
mod: "none"
cgo: 0
PackSrc: "config"
extra: ""

6.可是仍然没有效果

于是我看了前面的几个文档,包括在build的过程中使用了debug打印日志

2022-08-15 15:32:33.381 [DEBU] build input: {Meta:{} File: Name:test-cli Version: Arch:amd64 System:linux Output: Path:./temp Extra: Mod:none Cgo:false VarMap:map[] PackSrc:config Pa
ckDst:internal/packed/build_pack_data.go ExitWhenError:false}
2022-08-15 15:32:33.385 gf pack config internal/packed/build_pack_data.go
2022-08-15 15:32:33.446 done!
2022-08-15 15:32:33.533 [DEBU] git log -1 --format="%cd %H" --date=format:"%Y-%m-%d %H:%M:%S"
2022-08-15 15:32:33.536 start building...
2022-08-15 15:32:33.536 [DEBU] go build -o ./temp/linux_amd64/neuedu-cli -ldflags "-X 'github.com/gogf/gf/v2/os/gbuild.builtInVarStr=eyJidWlsdEdpdCI6IiIsImJ1aWx0VGltZSI6IjIwMjItMDgtMTU
gMTU6MzI6MzMifQ=='" main.go
2022-08-15 15:32:33.539 go build -o ./temp/linux_amd64/neuedu-cli main.go
2022-08-15 15:32:36.141 [DEBU]
2022-08-15 15:32:36.142 done!
2022-08-15 15:32:36.143 remove the automatically generated resource go file: internal/packed/build_pack_data.go

我看到日志中提到了internal/packed/build_pack_data.go这个文件,然后编译后又给删除了,我就想他是不是需要引用这个文件

然后我又在main.go中添加了对这个包的引用

import (
_ "test_cli/api"
_ "test_cli/internal/packed" "github.com/gogf/gf/v2/frame/g"
) func main() {
s := g.Server()
s.SetPort(8199)
s.Run()
}

最后终于读取到了配置文件

总结起来就是需要注意两点:

1.需要添加配置文件,但是可能我的版本太高了,官方文档还没有更新,扫描添加文件的路径参数为PackSrc而不是pack

2.可能是我生成工程后调整目录过程中误删了对packed包的引用,当然这个就怪我自己了,没弄明白就修改了初始化的工程。。

最后我想说一句,go frame真的是一个非常强大实用的框架,但是希望文档能跟随正式版本一起发布。也祝愿像go frame的国产框架能发展壮大,有更多的大神参与进来。

go frame资源管理打包失败的更多相关文章

  1. maven打包失败 Cannot create resource output directory

    转https://blog.csdn.net/wuyuanshun/article/details/103097447 maven clean后打包出现Cannot create resource o ...

  2. hbuilder ios 打包失败,无法导入p12证书的解决方案

    问题描述: 在profile文件和私钥证书通过hbuilder ios 打包成功过的前提下,突然遇到打包失败的问题,问题详情是无法导入p12证书. 探索过程: 本着遇到问题先自省的态度,重复打包了几次 ...

  3. idea在maven打包时运行Test测试, 导致打包失败, 乱七八糟的错误

    在maven打包时运行Test测试, 导致打包失败, 乱七八糟的错误 在maven projects中图标toggle'skip Tests' Mode //宏杰帮助 网上案例:https://blo ...

  4. java分模块项目在idea中使用maven打包失败(ps:maven常用到的命令)

    一.分模块项目打包失败 情况:项目是分模块创建的,一些公共的方法是单独的一个模块common,其他模块依赖于此模块,poom依赖已经添加了,项目可以正常运行,但使用maven打包时出现了问题:找不到依 ...

  5. 17、uwp 打包失败记录

    今天在打包时,总是打包失败, visual studio 报错误: 严重性 说明 代码 项目 文件 行 禁止显示状态错误 Error info: error 80080204: All app pac ...

  6. NGUI在5.3打包失败问题

    一.NGUI版本 NGUI是很好用的Unity UI插件. 当前使用版本NGUI Next-Gen UI v3.9.7 (Feb 10, 2016)和NGUI Next-Gen UI 3.9.0两个版 ...

  7. 解决因生成javadoc失败导致Maven打包失败问题

    方案就是设置javadoc生成失败时不导致整个打包失败: <plugin> <groupId>org.apache.maven.plugins</groupId> ...

  8. maven 打包失败 提示找不到jar的问题

    服务打包的时候发现打包失败,查看原因大概是找不到jar包,但是本地仓库有.最终的解决的办法是使用maven 命令重新把jar包安装到本地仓库. 命令如下:mvn install:install-fil ...

  9. ionic在iOS中打包失败

    在ios中打包失败,遇上这样的错误 解决办法,查看index.html的权限是否是只读状态,如果是,改成可读可写,再次打包重试,成功!

  10. Hbuild在线云ios打包失败,提示BuildConfigure Failed 31013 App Store 图标 未找到 解决方法

    用 hbuild 打 IOS 包,打包失败,提示以下错误: manifest.plus.plugins.push.igexin;manifest.plus.plugins.oauth.weixin; ...

随机推荐

  1. 【WEB】URL文件

    早些年接触电脑的时候就有这个东西,去网站上下载盗版游戏,网站会附加这种URL文件 双击运行之后是打开浏览器跳转到该文件描述的网址 我从来没想过这东西里面写的是什么 百度经验: https://baij ...

  2. 【Java,IDEA】配置文件快速生成

    比如这里的druid连接配置文件,和mybatis的mapper配置文件就是使用模版创建好的 在创建文件时会有选项选择:

  3. 《Python数据可视化之matplotlib实践》 源码 第一篇 入门 第一章

    最近手上有需要用matplotlib画图的活,在网上淘了本实践书,发现没有代码,于是手敲了一遍,mark下. 第一篇    第一章 图1.1 import matplotlib.pyplot as p ...

  4. ( Ubuntu环境下 ) Vim插件管理器 Vundle 的安装

    为vim安装插件的时候一般会选择先安装一个插件管理器,  一般有 Pathogen和Vundle 比较常用,同时也有比较轻量级的   Vim插件管理神器vim-plug . 1.   下载  Vim插 ...

  5. Salesforce Sales Cloud 零基础学习(五) My Labels的使用

    本篇参考: https://help.salesforce.com/s/articleView?id=sf.sales_core_record_labels.htm&type=5 在公司中,S ...

  6. 记一次 .NET某智慧出行系统 CPU爆高分析

    一:背景 1. 讲故事 前些天有位朋友找到我,说他们的系统出现了CPU 100%的情况,让你帮忙看一下怎么回事?dump也拿到了,本想着这种情况让他多抓几个,既然有了就拿现有的分析吧. 二:WinDb ...

  7. k8s手动安装

    一.主节点安装 设置主机名hostnamectl set-hostname masterhostnamectl set-hostname node01 修改hosts文件vim /etc/hosts1 ...

  8. Catlan--卡特兰数--组合数学

    卡特兰数 \(Catlan\) ·赘述 其实发现卡特兰数和之前不同的是,前面的是给你公式,让你去求具体的例子,然而卡特兰数这里是给你大量例子来给你证明和解释什么是卡特兰数. ·定义 对于卡特兰数来说, ...

  9. 全网最适合入门的面向对象编程教程:39 Python常用复合数据类型-集合

    全网最适合入门的面向对象编程教程:39 Python 常用复合数据类型-集合 摘要: 在 Python 中,集合(set)是一种常用的复合数据类型.集合是一组无序且不重复的元素.与列表和元组不同,集合 ...

  10. 【Python自动化】之利用JS操作页面滚动条(新)

    如何操作页面中的滚动条,有以下几个方法: 一.查找可见元素进行滚动页面(通用) 方法一: ①移动到元素element对象的"顶端",与当前窗口的"顶部"对齐(默 ...