最新要闻
- 与网易和好基无可能 魔兽关服倒计时:暴雪代理谈判进入第二阶段
- 120Hz自适应刷新0延迟:一加11成屏幕流畅体验天花板
- 环球速读:五月天版权回归网易云音乐 网友:糟糕的心情好了些
- 每日消息!俞敏洪给自己2022年打8分:没有欠员工一分钱工资
- 动态:4599元 雷军分享Redmi K60冠军版特写照:和跑车一样精致
- Redmi K60素皮版本质感堪比手工!雷军:值得你细品
- 环球看热讯:健康速食!西安饭庄油泼biangbiang面大促:每盒6.66元
- 今日热门!罗永浩怎么看?西门子回应洗衣机10年包修为保证能修 洋品牌赤裸裸坑国人
- Intel Unison正式上线:实现PC与安卓/iOS手机无缝连接
- 当前消息!你最想看哪个?2023春节档已官宣五部电影 《满江红》比拼《流浪地球2》
- 环球微头条丨销量甩Intel+Zen4全家!AMD神U锐龙7 5800X3D卖成年度处理器销冠
- 全球速递!等了7年!《大圣归来》导演新作《深海》定档 要做国漫里程碑、视觉突破极限
- 每日速看!10多万买“大路虎” 奇瑞旗舰SUV瑞虎9官图发布:霸气
- 全球要闻:最贵748元!苹果全系电池涨价 3月1日开始:非针对国人 成本增加所致
- 【焦点热闻】行驶中天窗可能会掉 奔驰再次召回超12万辆汽车
- 环球今日讯!诺氟沙星突然爆火!医生紧急提醒:未成年人禁用
手机
iphone11大小尺寸是多少?苹果iPhone11和iPhone13的区别是什么?
警方通报辅警执法直播中被撞飞:犯罪嫌疑人已投案
- iphone11大小尺寸是多少?苹果iPhone11和iPhone13的区别是什么?
- 警方通报辅警执法直播中被撞飞:犯罪嫌疑人已投案
- 男子被关545天申国赔:获赔18万多 驳回精神抚慰金
- 3天内26名本土感染者,辽宁确诊人数已超安徽
- 广西柳州一男子因纠纷杀害三人后自首
- 洱海坠机4名机组人员被批准为烈士 数千干部群众悼念
家电
世界速递!如何站在开发者的角度理解框架的设计思想?
有问必答
最近有好多读者私信我,为什么选择GoFrame做电商项目的开发?
原因很简单:
因为我司是用GoFrame做电商业务开发的,而且我司同事基本都是PHP转Go的。GoFrame可以说是非常适合PHPer转Gopher的开发框架。
【资料图】
在入职我司之前,我有使用Gin和go-micro框架,目前也正在学习go-zero。
不管是开发语言还是开发框架,都服务于我们所做的业务,抛开业务去聊语言或者框架都是没有意义的。
使用GoFrame做开源项目的另一个原因是:想体验一下V2版本的新特性,自己的项目怎么做自己能完全说了算,没有历史包袱。
前言
让开发者更好的做到“模块内部高内聚,模块之间松耦合”,是我认为GoFrame V2设计的精髓。
用GoFrame开发商业项目已经很长时间,发现GoFrame的版本更新比较快,社区也非常的活跃。
因为历史原因,我之前一直用V1.16版本做商业项目的开发,虽然个人有比较强的意愿升级到V2。
但是考虑到项目稳定性及开发成本等等原因,商业项目并未升级。这可能也是很多小伙伴面临的问题。
受到鼓励
正好前段时间,分享了自己的开源项目【Go WEB进阶实战】基于GoFrame搭建的电商前后台API系统受到了大家的关注和支持,GoFrame的作者也在点赞转发,更受鼓励。
更重要的是:收到了社区里很多小伙伴的建议,最多的建议就是建议我使用V2版本,因为提供了很多新特性,可以更好的实现需求,稳定且高效。
决定升级
所以,我决定把我开源的项目从V1.16.x版本,升级到最新的V2.2.0版本,踩一下升级的坑,享受一下升级后的快乐。
欢迎小伙伴们加入到我的开源项目中:电商前后台系统API,目前V1版本已经收尾,包括电商项目的常用功能,开发了120多个接口。
一起参与
V2版本在开发过程中,目前已经开发了30多个接口,计划这个月内开发完毕,也开源出去。欢迎小伙伴们参与共建,也欢迎阅读我的源码,多提宝贵建议:
V2版本GitHub地址
因为内容比较长且硬核,所以我决定分两篇文章分享:
这篇文章重点:介绍GoFrame V2的新特性,和V1相比有哪些优势?最大的变化是什么?
下一篇文章会分享一下:我从V1升级到V2的踩坑之旅,相信对很多小伙伴都有帮助。
这个经历实属不易,希望小伙伴们可以点赞、关注、转发一波。
适合看的人群
- 掌握Go基础后,想用成熟框架开发项目的伙伴,建议读完我的文章之后,直接使用GoFrame最新的V2版本实战开发
- 目前在用V1版本,有意愿但是没有大量精力学习V2新特性的伙伴,担心升级问题太高不敢贸然升级的伙伴们。
- 想提高自己学习新知识效率的小伙伴,欢迎复刻我的这种实践方式。
站在开发者的角度
不管你是哪种人群,都建议先花时间仔细阅读官方文档,尤其是 框架介绍这部分。
区别于官方文档,这篇文章会结合我自己的经验,站在框架使用者的角度,帮大家更快更好的理解Goframe V2版的设计思路,基于V2版本如何更好的进行商业项目的开发。
踩的坑
在我升级版本的过程中发现:一定要先了解清楚V2的新特性,然后再从V1升级到V2,否则升级到一半会出现无从下手的问题:
因为通过V2版本的CLI工具生成的dao、model,和V1版本是不一致的:废弃了gmvc模块等,也引入了新的模块。
V2版本支持
gf gen service
的方式生成service层,统一我们接口逻辑的实现方式,引入了logic层和service层的概念
结合自己的升级经历,分享给大家学习GoFrame V2必知必会的知识点:
必知必会
项目工程结构发生了变化,且需要按照V2的标准来,因为gf工具生成代码的目录结构发生了改变,更重要的:V2官方建议的目录结构也是我们践行"高内聚低耦合"比较好的工程目录结构。
gf gen dao
除了会像V1一样生成dao层和model层,还会另外生成do层和entity层V2版本的目录结构实践了业务模型和数据模型解耦的思想(也是我认为非常赞的地方)
V2相比于V1会出现方法或者模块废弃的情况,比如废弃了gmvc耦合模块,未来不再进一步支持。同时也为我们提供了更好的实现方式。
V2有点编写“微服务”的意思了,需要服务注册:controller调用一个或多个service实现具体的业务逻辑;但是复杂的业务逻辑又不是在service中实现的,为了解耦,V2版本引入了logic目录,用于编写和复用复杂的业务逻辑。在logic中注册服务,在service中通过接口方式规范logic层要实现的方法。
重中之重
下面再介绍一下我花了很长时间才消化的知识点:
dao代码生成(很重要)
gf gen dao
在业务项目中,官方推荐使用dao/do/entity的方式操作数据库,这些文件都是通过开发工具自动生成的,由开发工具统一维护。
区别于V1版本,V2版本引入了do的概念,为什么这么设计?
在这里我只说结论,文章最后会附上官方链接:
dao层用于数据访问,这是一层抽象对象,用于和底层数据库交互,仅包含最基础的 CURD 方法
model层是结构模型,是数据结构管理模块,管理数据实体对象,以及输入与输出数据结构定义。
2.1 model中的do是领域对象,用于dao数据操作中业务模型与实例模型转换,由工具维护,用户不能修改。
2.2 model中的entity是数据模型,数据模型是模型与数据集合的一对一关系,由工具维护,用户不能修改。
后面我会带着大家用实例讲解
服务接口生成(更重要)
gf gen service
服务接口是非常重要的知识点,也是我认为在cli工具支持方面和V1版本最大的区别:
为了降低业务项目内部模块间的耦合,框架将模块间的依赖抽象为了接口,由internal/service包维护。internal/service可以由开发者自定义维护接口,也可以通过internal/logic业务封装的代码按照一定规则自动生成接口代码文件。
实践出真知
看10遍文档,都不如一次动手实践。建议大家和我一起操练起来,欢迎复刻:
我的思路是这样:
下载官方的示例项目,学习一下官方是怎么写的。
给自己提需求,参考官方的实现方式,实现自己的业务场景。
我会带着大家实现经典的电商场景:添加和查询商品信息。
1. 下载运行官方示例的GitHub
官方示例GitHub
1.1 下载部署好项目之后,启动:非常顺滑的就启动成功了:
1.2 请求接口,验证试一下DB是否连接正常。
1.3 查询数据库,也是有值的。
验证环境无误,下面开始带着大家参考官方示例实现自己的需求,进而更好的理解V2版本新特性和工程实践。
2. 基于V2编写商品管理
我们按照官方建议的工程方式去实践,看看会不会踩坑:
2.1 创建goods表如下:
2.2 通过gf gen dao生成dao和model
初次尝试,失败,原因是没有修改hack目录下的config.yaml配置文件。
注意:和V1不同,官方说hack目录的作用是工具脚本,存放项目开发工具、脚本等内容。例如,CLI工具的配置,各种shell/bat脚本等文件。所以我们就不要像V1一样把cli工具的配置文件也写到manifest/config目录中了。
2.3 搞定,成功生成。
小技巧,如果我们不指定tables,则生成所有表对应的数据。我是比较喜欢这么操作:因为能避免自己改了多个tables,但是在配置文件中漏写了某个tables导致意料之外的问题。
下面开始正式撸代码了:
我会先按照大家容易理解的方式进行编写,文章最后我会分享实践经验:按照什么顺序编写各个模块的代码是比较科学的。
2.4 首先我们实现api层,定义请求和响应的结构体
2.5 我们在cmd中注册Goods相关的路由
2.6 我们发现注册路由时,controller.Goods飘红,原因是我们还没有编写这个方法。
我们参考示例代码去编写controller层:
我们发现右侧的示例项目,方法内部调用了service中的方法,但是我们目前还没有定义service,怎么办?
我们先点击示例项目中的user.go,查看一下service中都定义了什么:
经过查阅文档得知:
我们需要通过编写logic层实现业务逻辑,通过配置goland插件,自动生成service代码。
这要是官方建议我们的最佳实践:
2.7 导入官方提供的xml文件(只需要配置一次)
xml文件地址
强烈建议大家这么操作,经过这个配置在我们编写logic层代码的时候,service能自动生成接口定义文件。
当然也可以不配置,只是每一次在开发/更新完成logic业务模块后,都需要手动执行一下 gf gen service 命令。太麻烦了!!!
2.8 我们参考右侧的示例 编写商品goods的logic代码,处理业务逻辑:
2.9 经测试我发现:在编写logic逻辑后,就自动在service层生成了对应的goods文件和方法,非常方便。
2.10 我们再继续写添加商品逻辑和查看商品逻辑
我们发现:在logic层编写完添加商品逻辑后,在右侧的service层自动生成了代码。
2.11 细心的同学可能发现了service层的RegisterGoods方法,这是干嘛用的呢?
答案是:我们要在service层生成RegisterXX()方法后,在对应的业务模块中加上接口的实现注入。
小提示:该方法每个业务模块加一次即可。
建议大家在编写完第一个logic方法后(或者说service层生成了RegisterXX方法后):
就在logic层的init函数中实现服务的注册;
然后去查看logic.go文件是否添加了相关的依赖,没有的话也可以手动添加一下;
要成良好的编码习惯,少出bug。
2.12 我们查看logic目录下的logic.go文件,发现已经自动添加了我们本次编写的goods相关的import:
这个文件的作用是:将接口的具体实现,在程序启动时执行注册。
好了,logic和service到此结束,我们已经完成了业务逻辑的编写。
内容不少,大家可以上划再看一遍这部分内容,消化吸收一下。
2.13 咱们回过头来,继续编写controller层的代码:
我们参考官方提供的controller/user.go 实现了我们自己的 controller/goods.go的添加商品方法:
2.14 到这里,我们已经完成了新需求的编写,启动服务查看一下效果:
很OK,已经看到了对应的接口。
编码完毕,测试一下:
我们请求接口,添加数据看一下:
在数据库中也查看到数据:插入成功,流程走通!
反思回顾
按照上面这个流程走下来,虽然整体跑通了。我个人感觉还是比较混乱的。
我又花了比较长的时间消化吸收了官方文档的工程实践,结合我自己的经验。
我们再来梳理一下V2项目的编写流程,我的建议是这样的:
整理流程
设计表结构
使用
gf gen dao
生成对应的dao/do/model目录代码编写api层:定义「业务模块」的数据结构,提供对外接口的输入/输出数据结构
编写model层:定义「数据模块」的数据结构,提供对内的数据处理的输入/输出数据结构
编写logic层,自动生成service层代码。(通过配置goland File Watcher自动生成,也可以通过gf gen service手动执行脚本生成,强烈建议前者)
在service层代码生成RegisterXX()方法后,在对应的logic模块注册服务(每个模块只需要写一次)
编写controller层,接收/解析用户输入的参数,调用service层的服务。
注册路由,对外暴露接口,比如这个项目是编写cmd.go文件。
在main.go中 加入一行_ "project-name/internal/logic" (只需写一次)
在main.go中加入一行 _ "github.com/gogf/gf/contrib/drivers/mysql/v2" (如果你使用的是mysql;只需写一次)
关键流程
- 上面的步骤只有3~8是每次开发新需求都需要的
- 步骤1、2设计表结构和自动生成代码很简单,涉及到新增表或者修改表时才需要
- 步骤9、10在创建项目时编写一次即可
再次实操
我按照上面这个步骤,编写了查询商品逻辑,整体还是非常顺滑的:
小伙伴们也动手实践吧,欢迎star fork我的开源项目:https://github.com/wangzhongyang007/goframe-shop-v2
带着问题学习
我在编写商品管理需求的时候有些疑惑:
为什么要定义两遍数据结构呢?在api层定义了一遍,在model层又定义了一遍,我写了两遍重复的结构体,意义何在呀?
我静下心来想想,这个设计还是值得好好推敲的,我结合之前的项目经历分享一下我的理解。抛砖引玉,小伙伴们有什么理解欢迎在评论区留言。
之前遇到的问题
我们之前在在开发商品中心统一入库时就遇到了难以维护的问题,原因就是业务逻辑和数据处理逻辑耦合在一起。
随着业务的复杂度越来越高,项目维护成本越来越高,甚至达到了难以维护的程度。
我们是如何解决的呢?
解决办法和GoFrame的数据模型和业务模型解耦,底层思想是一样的:
我们把复杂的逻辑进行了拆分:定义了业务模块和数据处理模块。
「业务模块」:只处理接收的参数,并不关心如何入库和取值,按照「数据模块」的要求,处理好前端传入的数据,统一结构体传递给「数据模块」即可。
「数据模块」:不需要关心「业务模块」的具体实现,定义了统一的入参标准,要求业务模块按照自己的要求,统一传入数据;数据模块考虑的重点是如何高效的批量插入数据,如何高效的按需取值,并不需要关心多变的业务侧需求。
升华一下
经过对冗余模块的拆解,梳理清楚了「数据模块」和「业务模块」的边界,我们不仅解决了之前项目难以维护的问题,还提高了灵活对接客户需求的能力。
结合自己的项目经历和这次实践V2版本的经历,所以我开篇说:让开发者更好的做到“模块内部高内聚,模块之间松耦合”,是我认为GoFrame V2设计的精髓。
好了,这篇文章就到这里,硬核爆肝5千字,坚持更新实属不易,欢迎大家点赞、评论、转发。
-
每日热门:文件IO操作开发笔记(一):使用Qt的QFile对磁盘文件存储进行性能测试以及测试工具
前言在做到个别项目对日志要求较高,要求并行写入的数据较多,尽管写入数据的线程放在子线程,仍然会造...
来源: -
全球微资讯!python 中os和sys模块常用方法
OS常用方法os remove()删除文件os rename()重命名文件os walk()生成目录树下的所以文件名os chdir()...
来源: 世界速递!如何站在开发者的角度理解框架的设计思想?
每日热门:文件IO操作开发笔记(一):使用Qt的QFile对磁盘文件存储进行性能测试以及测试工具
全球微资讯!python 中os和sys模块常用方法
与网易和好基无可能 魔兽关服倒计时:暴雪代理谈判进入第二阶段
120Hz自适应刷新0延迟:一加11成屏幕流畅体验天花板
环球速读:五月天版权回归网易云音乐 网友:糟糕的心情好了些
每日消息!俞敏洪给自己2022年打8分:没有欠员工一分钱工资
动态:4599元 雷军分享Redmi K60冠军版特写照:和跑车一样精致
世界视讯!什么是 A/B 实验,为什么要开 A/B 实验?
环球热文:IT 技术工作详解 -小马说工作
每日热文:SweetAlert让消息弹出窗口更加具有个性化!
Redmi K60素皮版本质感堪比手工!雷军:值得你细品
环球看热讯:健康速食!西安饭庄油泼biangbiang面大促:每盒6.66元
今日热门!罗永浩怎么看?西门子回应洗衣机10年包修为保证能修 洋品牌赤裸裸坑国人
Intel Unison正式上线:实现PC与安卓/iOS手机无缝连接
当前消息!你最想看哪个?2023春节档已官宣五部电影 《满江红》比拼《流浪地球2》
每日快看:建筑软件解决方案丨Bluebeam简介
头条:2022 倒带 - NutUI
环球简讯:面试官:为什么 wait/notify 必须与 synchronized 一起使用??
环球微头条丨销量甩Intel+Zen4全家!AMD神U锐龙7 5800X3D卖成年度处理器销冠
全球速递!等了7年!《大圣归来》导演新作《深海》定档 要做国漫里程碑、视觉突破极限
每日速看!10多万买“大路虎” 奇瑞旗舰SUV瑞虎9官图发布:霸气
全球要闻:最贵748元!苹果全系电池涨价 3月1日开始:非针对国人 成本增加所致
【焦点热闻】行驶中天窗可能会掉 奔驰再次召回超12万辆汽车
环球今日讯!诺氟沙星突然爆火!医生紧急提醒:未成年人禁用
每日速递:[概率论与数理统计]笔记:1.4 条件概率
全球消息!699元Redmi 12C开卖 员工:对比友商1500元线下机 竞争力也十足
天天要闻:2023年电动车在美国会更便宜 更多人买得起了!有4点原因
我国最大的固体运载火箭!力箭一号遥二开启总装测试:拟5月发射
故事老套且拖沓?不妨对《阿凡达2》宽容一点
《阿凡达2》票房达到回本线了:全球票房已突破14亿美元
商业网络安全解决方案丨Avast产品简介
时讯:Kubernetes监控手册05-监控Kubelet
袋鼠云产品功能更新报告03期丨产品体验全面优化,请查收!
对标苹果!三星推出27寸ViewFinity S9显示器:5K屏、全金属机身
当前报道:免费十年突然改版!游侠对战平台宣布每天只能免费一小时
焦点日报:价格下来了:东方基因快速检测试剂盒4.9元/份
天天微头条丨每5辆新车就有4辆电动车 挪威电动车市占率近80%全球第一高
灭菌独立装 袋鼠医生N95医用口罩30片45元大促
世界视点!从源代码构建TensorFlow流程记录
全球百事通!最大尺寸iPad被砍!曝苹果不打算在今年发14.1英寸iPad Pro
环球即时:比亚迪百万级越野车 仰望R1最新预告:首搭最具辨识度的尾灯
Firefox遭意外“误伤”:新版本被错误识别为IE 11
特斯拉全年销量破130万辆 还是全球纯电动车销冠
【全球快播报】如何不动声色的让身边的人知道你买RTX 4090了?
天天快讯:github上传本地代码到仓库教程
世界速看:联合三个国家尖端技术!38年后Intel重回老本行 让存储性能爆炸性提高
全球实时:西安高铁站私家车上站台接送乘客引争议:VIP贵宾服务 存在多年
2023年第一涨 国内油价今晚迎来调整 每升或上调0.2元
当前观点:你想成特斯拉车主吗?分析称Model 2快要来了 售价17万
世界热议:苹果中国工厂都要搬走?印度产iPhone加大 还要拿下iPad、Mac等
速看:AMD Zen4锐龙狂降价作用不大:德国电商销量不及Zen3五分之一
环球观察:抖音推出桌面端聊天软件抖音聊天:神似微信电脑版
天天百事通!微信支付之支付码支付
关注:学习Python第一个程序“Hello,World”
【新要闻】1.2 今天和对象吵架 但依旧学了代码
热文:谁说的不流畅?Steam玩家调查:Win11成香饽饽 NV四年前神卡1650领跑
新年暴击!超10家车企宣布涨价 特斯拉公开“唱反调”
三星将在CES 2023展示新款显示屏:折叠、滑动都支持
赚翻的节奏:美国超级百万彩票头奖升至54亿元 竟多次没人中奖
全球热门:女司机等红灯陌生男突然上车搭讪:拉车门坐到后排 被当场吓哭
环球关注:保研经历分享
环球消息!MySQL——事务
今亮点!特斯拉司机在德国高速公路上睡着!无视交警 结果“很刑”
世界讯息:2022年新生儿爆款名字出炉上热搜 这些字用得最多:土爆了?
全球微速讯:电商晒数据!4年卖出那么多块SSD 三星质量稳如狗:零返修
天天日报丨1.2复习了一下MySQL的索引
Codeforces Good Bye 2022 CF 1770 F Koxia and Sequence 题解
世界热头条丨WPF+ASP.NET SignalR实现动态折线图
世界头条:1. 线程管理基础
天天短讯!越南地产大佬都做出60万的车了 建议国内这位好好学
环球快资讯丨2023元旦档总票房5.47亿:《阿凡达2》撑起“半壁江山”
bbs项目(部分讲解)
天天通讯!手慢真无了!徐福记零食礼盒大促:39.9元到手 送礼有面
天天即时看!NVIDIA服软了!RTX 4070 Ti大量偷跑:价格低至6299元
环球速讯:国行6499元买到就是赚到?RTX 4070 Ti性能抢先看:对比4080
世界观焦点:解放生产力!一文教你快速入门正则表达式
全球快看:你肯定达标了?31省份最低工资表公布:上海第一 超2500元
热议:29岁男子身高2.89米成世界上最高的人:还在生长中!
JavaWeb学习笔记
焦点快看:因14 Plus销量太差 曝苹果将对iPhone 15 Plus价格大调整
环球头条:超14亿美元!《阿凡达2》票房达到回本线 你贡献了几张票?
世界快看:3G CDMA再见!美国运营商关闭 中国电信也快关闭了
新消息丨苹果中国不手软:iPhone 14之前机型保修费大涨 700元换块电池
即时焦点:tclap库的使用
美好午餐肉罐头促销:5盒不到20元 味道鲜美入口留香
天天新资讯:MySQL——基础架构
Python类与对象详解
【环球热闻】Python重用父类方法
Python类的封装教程
世界热门:电竞圈说的“满血”到底是啥 真能带来游戏体验升级?实测揭秘真相
女子花2700修热水器:成本只有13元
docker复杂安装
热点在线丨AcWing1170. 排队布局[USACO05]
当前速读:今天是卢伟冰入职小米4周年!卢伟冰想起4年前雷军说过的话
取暖电器火了!成为老外眼中的香饽饽
看点:docker安装软件
天天看点:根治安卓卡顿!一加11超21万人预约:本周发
蔚来2022年累计交付新车122486辆 明年目标超雷克萨斯
速讯:微软吹大了!Win11流畅度没那么神:Office/PS还没Win10快