Go语言学习路线 - 5.基础篇:从一个web项目来谈Go语言的技能点

本文涉及的产品
云解析 DNS,旗舰版 1个月
全局流量管理 GTM,标准版 1个月
公共DNS(含HTTPDNS解析),每月1000万次HTTP解析
简介: 经过了 入门篇 的学习,大家已经初步了解Go语言的语法,也能写常见的代码了。接下来,我们就从一个Web项目入手,看看一些常见的技能与知识吧。我们先简单地聊一下这个Web项目的背景:我们要做的是一个简单的web系统 ,有前端同学负责界面的开发,后端不会考虑高并发等复杂情况。

从一个Web项目开始

经过了 入门篇 的学习,大家已经初步了解Go语言的语法,也能写常见的代码了。接下来,我们就从一个Web项目入手,看看一些常见的技能与知识吧。

我们先简单地聊一下这个Web项目的背景:我们要做的是一个简单的web系统 ,有前端同学负责界面的开发,后端不会考虑高并发等复杂情况。

我们先从一个Web请求出发,看看会涉及到哪些模块。

前端的请求生命周期

用户在web界面上点击了一个按钮,就由前端发起了一个请求。那这个请求的生命周期是怎么样的呢?

通常情况下,后端的工作是解析前端的数据,处理对应的业务逻辑,返回操作结果

这里,离不开三层概念:

  • API层:解析来自前端的数据,转化成go的数据结构
  • Service层:包含业务逻辑,是这个请求具体要做的事情
  • Dao层:数据持久化,也就是更新到数据库等,保证不丢失

不同框架有不同的命名方式,但我个人建议只关注这三层即可。

当然,这三层逻辑并不绝对,会因为项目特点有所调整,但整体的分层思路是不会变化的。我认为,如果你能真正地理解web的分层,对项目的框架就能掌握得很棒了。

接下来,我们自顶向下逐层聊聊。

第一层:API层

通常来说,API层只做三件事:

  1. 根据路由规则,调用具体的处理函数 ,常见的RESTful就是由URL+Method的作为路由规则;
  2. 解析文本或二进制数据到Go结构体,常见的是用json反序列化;
  3. 调用下一层Service的函数

抛开第三点暂且不谈,前两者比较容易理解,大家可以使用标准库里的net/httpencoding/json来完成。具体的代码我就不写了,网上示例非常多。

那么,API层这么简单,有什么学问嘛?这里,我建议大家看看两个开源库:

看看上面的示例,对比一下原生的net/http库写出来的代码,是否感觉可读性大大提高?没错,API层关键点之一的就是可读性

不过Gin相对于Mux非常重量级,学习起来成本很大;而Mux虽然可读性提高,但在解析http body数据这块效果不佳,还是需要逐个手写结构体。

所以,在我看来,这两个都并不是最佳方案,我非常建议有条件的项目能够直接引入 RPC级别的解决方案,例如gRPC。这块我会拿具体项目、花好几讲来好好说说。

在开发的过程中,我对API层的开发会重点关注这几点:

  • 可读性:可以快速地根据命名了解功能,如RESTful
  • 高度复用:如引入mux 中的各种 middleware,比如 防止panic用户认证 、日志打印等
  • 尽量薄:不做或少做业务逻辑处理,复杂处理都丢到service层
  • 文档化:将接口的相关参数通过文档给到前端或第三方,尽量做到自动化或半自动化

我再强调一下API层的重要性:API层是程序最关键的入口和出口,能很好地追踪到数据的前后变化情况。 一个优秀的API层实现,不仅能让我们少写很多重复性代码,也能大幅度地降低我们排查问题的效率。

第二层:Service层

Service层可以理解为服务层,是整个项目中最复杂、也是代码比重往往是最多的。它是一个项目最核心的业务价值所在。

Service是最灵活、也是最考验设计能力的,虽说没有一套固定的模式,但还是会有一定的套路

我分享一下个人的三个见解:

  1. 单元测试覆盖率要尽量高,这是一个高频迭代与重构的模块,也是最容易出现问题的部分;
  2. 深入实践 面向对象与DDD ,最锻炼工程师抽象、解耦等能力的模块;
  3. 选择合适的 设计模式 可大幅度地提升研发效率;

再提一句,请跃跃欲试的各位冷静一下,Service层是和业务一起成长的,前期没必要过度设计。我们把重点放在单元测试的编写上即可,适当地选用一些库来提高效率,如开源的stretchr/testify,内部的reflect等。

第三层:Dao层

Dao层常被理解为数据持久化层,但我们可以将它进行一定的延伸:将RPC调用也当做Dao层(不妨认为将数据持久化到了另一个服务),来适配微服务架构的场景。

严格意义上,RPC调用和普通的Dao差异有不少,但为了收敛话题,我们暂且不细分。

今天,我们不关注分布式场景下的各种数据问题,也不考虑各种存储中间件的特点,而是聚焦于一个问题:如何将内存中的对象持久化到数据库中。在编程领域,这部分的工具被称为ORM

以Go语言对接MySQL为例,最常见的为gorm,它能很便捷地将一个Go语言中的结构体,映射到MySQL数据库某个表中的一行数据。

请自行对比一下,用go官方的sql库写增删改查,与用gorm写增删改查的工作量差异。

关于Dao层,我认为有部分的实践是比较通用的:

  1. 选用官方或社区高频使用的库,避免后期出现功能缺失或性能瓶颈的问题;
  2. 灵活性比易用性更重要,通过一层浅封装,往往能更适配项目,达到更棒的易用性;
  3. 关注数据库的原理、而不是ORM工具的实现方式,数据库的原理是长期的积累,对技术选型和排查故障很有帮助。

至于不同的数据库ORM有不同的最佳实践,一一列举的工作量太大,我会在工程化的过程中选择性地讲解。

串联三层

到这里,我们对这三层有了初步的了解,可以总结为两边薄(API、Dao),中间厚(Service)

这里的实践需要大家不断打磨,比如说:

  • API与Dao会随着个人编程能力的提升,不断地总结出更好的编程实践;
  • 做性能优化时,优先考虑Dao,其次考虑API,这两部分的提效是最明显的;
  • 排查问题时,先分析API的出入口,再分析Dao的出入口,实在解决不了再去看Service(此时已经是严重的业务逻辑问题了);

到最后,相信大家对这三层认知会进一步提升:

  • API:服务对外的门面,通过一个接口定义就能了解大致实现原理;
  • Service:复杂的业务逻辑,非该服务的核心成员无需关注,而核心成员须重点维护;
  • Dao:无论是调用ORM还是SDK,都视为一种工具集,是一个技术人员沉淀通用能力的重点。

CRUD程序员

很多程序员都戏称自己是一个只会CRUD的码农。让我们换个视角,看看CRUD背后有没有一些的技术点。

  • API层:遵循RESTful的原则,提高可读性(最好能在一行代码中看到,如mux
    • 将操作(CRUD)对应到HTTP的Method
    • 将资源对象对应到HTTP的URL
  • Service层:
    • 对于只是简单的修改,Service不用做复杂处理,透传到Dao层即可
    • 如果涉及到多个表的修改,进行事务处理(如mysql的transaction)
    • 在Dao层出现错误时,适当封装错误信息,提高可读性
  • Dao层:
    • 选择并熟练运用ORM,快速实现基本的CRUD
    • 对复杂的ORM进行一层浅封装,方便Service层的调用

经过一段时间的磨练,CRUD的工作能大大提效,我们就能抽出更多的时间去学习其余技能了。

结束语

Web项目是我们日常开发最常见的项目类型,也是很多面试考察点的基点。

我建议大家从分层着手,明确各层职责,关注API与Dao层的提效工作,做好Service层的质量保障,更好地掌控全局。而在具体的开源库的使用过程中,选对比会用更重要,集中在API与Dao层

目录
相关文章
|
19天前
|
存储 JSON 数据安全/隐私保护
"FastAPI身份验证与授权的奥秘:如何用Python打造坚不可摧的Web应用,让你的项目一鸣惊人?"
【8月更文挑战第31天】在现代Web开发中,保证应用安全性至关重要,FastAPI作为高性能Python框架,提供了多种身份验证与授权方式,包括HTTP基础认证、OAuth2及JWT。本文将对比这些机制并附上示例代码,展示如何使用HTTP基础认证、OAuth2协议以及JWT进行用户身份验证,确保只有合法用户才能访问受保护资源。通过具体示例,读者可以了解如何在FastAPI项目中实施这些安全措施。
54 1
|
19天前
|
存储 数据库 开发者
Web2py的神秘力量:如何用Python打造快速原型设计与开发,让你的项目一鸣惊人?
【8月更文挑战第31天】在现代软件开发中,快速原型设计至关重要。Web2py作为一款Python Web框架,凭借其简洁的语法和高效开发流程受到开发者青睐。本文通过在线调查问卷系统的案例,展示Web2py在快速原型设计中的应用,包括需求分析、数据库设计、表单创建及路由实现,并提供示例代码,帮助读者理解其最佳实践。
13 1
|
19天前
|
Rust 安全 开发者
惊爆!Xamarin 携手机器学习,开启智能应用新纪元,个性化体验与跨平台优势完美融合大揭秘!
【8月更文挑战第31天】随着互联网的发展,Web应用对性能和安全性要求不断提高。Rust凭借卓越的性能、内存安全及丰富生态,成为构建高性能Web服务器的理想选择。本文通过一个简单示例,展示如何使用Rust和Actix-web框架搭建基本Web服务器,从创建项目到运行服务器全程指导,帮助读者领略Rust在Web后端开发中的强大能力。通过实践,读者可以体验到Rust在性能和安全性方面的优势,以及其在Web开发领域的巨大潜力。
29 0
|
19天前
|
Java Maven Android开发
解锁Web开发新技能:从零开始的Struts 2之旅——让你的Java编程之路更加宽广,首个应用实例带你飞!
【8月更文挑战第31天】对于初学者,掌握 Struts 2 框架不仅能提升 Web 开发能力,还能深入了解 MVC 架构。Struts 2 是一个基于 Servlet 的 Java 框架,提供表单验证、文件上传、国际化等功能,便于快速构建易维护的 Web 应用。本文通过示例演示如何从零开始搭建环境并创建一个简单的 Struts 2 项目,包括配置 `struts.xml`、编写 Action 类及视图文件,并配置 web.xml。通过这些步骤,你将学会基本的开发流程,为进一步学习高级功能打下基础。
29 0
|
19天前
|
开发者 自然语言处理 存储
语言不再是壁垒:掌握 JSF 国际化技巧,轻松构建多语言支持的 Web 应用
【8月更文挑战第31天】JavaServer Faces (JSF) 框架提供了强大的国际化 (I18N) 和本地化 (L10N) 支持,使开发者能轻松添加多语言功能。本文通过具体案例展示如何在 JSF 应用中实现多语言支持,包括创建项目、配置语言资源文件 (`messages_xx.properties`)、设置 `web.xml`、编写 Managed Bean (`LanguageBean`) 处理语言选择,以及使用 Facelets 页面 (`index.xhtml`) 显示多语言消息。通过这些步骤,你将学会如何配置 JSF 环境、编写语言资源文件,并实现动态语言切换。
21 0
|
19天前
|
开发者 安全 SQL
JSF安全卫士:打造铜墙铁壁,抵御Web攻击的钢铁防线!
【8月更文挑战第31天】在构建Web应用时,安全性至关重要。JavaServer Faces (JSF)作为流行的Java Web框架,需防范如XSS、CSRF及SQL注入等攻击。本文详细介绍了如何在JSF应用中实施安全措施,包括严格验证用户输入、使用安全编码实践、实施内容安全策略(CSP)及使用CSRF tokens等。通过示例代码和最佳实践,帮助开发者构建更安全的应用,保护用户数据和系统资源。
32 0
|
19天前
|
开发者 前端开发 开发框架
JSF与移动应用,开启全新交互体验!让你的Web应用轻松征服移动设备,让用户爱不释手!
【8月更文挑战第31天】在现代Web应用开发中,移动设备的普及使得构建移动友好的应用变得至关重要。尽管JSF(JavaServer Faces)主要用于Web应用开发,但结合Bootstrap等前端框架,也能实现优秀的移动交互体验。本文探讨如何在JSF应用中实现移动友好性,并通过示例代码展示具体实现方法。使用Bootstrap的响应式布局和组件可以确保JSF页面在移动设备上自适应,并提供友好的表单输入和提交体验。尽管JSF存在组件库较小和学习成本较高等局限性,但合理利用其特性仍能显著提升用户体验。通过不断学习和实践,开发者可以更好地掌握JSF应用的移动友好性,为Web应用开发贡献力量。
30 0
|
19天前
|
存储 测试技术 开发者
FastAPI异步处理的神奇之处:如何用Python打造高性能Web应用,让你的项目一鸣惊人?
【8月更文挑战第31天】在现代Web开发中,高性能至关重要。FastAPI作为一款高性能Python Web框架,支持多种异步处理方式,包括非阻塞I/O、异步函数(async/await)及异步上下文管理器(async with),能够大幅提升应用性能。本文通过示例代码详细介绍了FastAPI中的异步处理方法,并分享了最佳实践,帮助开发者构建高效的Web应用。
37 0
|
19天前
|
数据库 开发者 Python
web应用开发
【9月更文挑战第1天】web应用开发
34 1
|
7天前
|
数据可视化 图形学 UED
只需四步,轻松开发三维模型Web应用
为了让用户更方便地应用三维模型,阿里云DataV提供了一套完整的三维模型Web模型开发方案,包括三维模型托管、应用开发、交互开发、应用分发等完整功能。只需69.3元/年,就能体验三维模型Web应用开发功能!
32 8
只需四步,轻松开发三维模型Web应用