go-zero源码学习

框架:

1、框架的作用就是简化开发。其中之一就是已经有很多轮子。如:生成n位随机字符串。如:封装redis使能兼容集群和单node
2、读懂xxxConf就读懂了框架结构
rest配置:(很大,框架无非rest和rpc两部分)
在这里插入图片描述

3、internal.svc(服务上下文)

  • Context(上下文)相当于一个全局对象。类似laravel的App
  • 上下文的思路和其他go-kit微服务框架一致
    4、写go要要用js的思维,不能用PHP的思维(强化PHP的面对对象思维+迭代器模式【laravel的model,那个链感觉就永远不会断似的】)。
  • 一套嵌一套
  • 一套东西只是做一个参数在使用。

一、core 内核部分

1、这里面的东西是可以直接拿来使用的,不要重复造轮子。

1、conf

将json、yaml、yml转为internal/config下对应的map结构数据

重点:
1、框架所有的配置都是一个xxxconf样式的struct(结构体)
2、通过使用core.mapping模块将yaml格式转化成类似map数据格式的struct

2、mapping

多少和字典数据有关

3、store

1、Cache.ClusterConf-Cache.NodeConf-redis.RedisConf依次为前一个的字元素

3.1、cache

1、在CacheConf对比RedisConf就多了一个权重参数

3.1.1、redis

1、封装redis使能兼容集群和单node

3.1.2、sqlc 带缓存的sql语句

1、框架不厌其烦的将每次mysql查询、查询结果做了redis缓存
如:QueryRow

return cc.cache.Take(v, key, func(v interface{}) error {
		return query(cc.db, v)
	})
3.1.3、sqlx 直接执行(exec)

1、mysql操作的一种封装。里面带有orm操作(不要重复轮子)
2、缓存没有,则直接查mysql

err := m.QueryRow(&resp, userIdKey, func(conn sqlx.SqlConn, v interface{}) error {
		query := fmt.Sprintf("select %s from %s where `id` = ? limit 1", userRows, m.table)
		return conn.QueryRow(v, query, id)
	})

这段代码可以看出sqlc、sqlx都有相同的函数名称。都是获取一行数据。sqlc没有用sqlx

4、stringx

1、处理字符串的框架之组件。如:n位随机字符串。

二、rest部分

三、rpc部分

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值