go-zero源码学习

2021-12-08 12:21:10 浏览数 (1)

文章目录

  • 框架:
  • 一、core 内核部分
    • 1、conf
      • 将json、yaml、yml转为internal/config下对应的map结构数据
    • 2、mapping
    • 3、store
      • 3.1、cache
        • 3.1.1、redis
        • 3.1.2、sqlc 带缓存的sql语句
        • 3.1.3、sqlx 直接执行(exec)
    • 4、stringx
  • 二、rest部分
  • 三、rpc部分

框架:

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

代码语言:javascript复制
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

代码语言:javascript复制
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 人点赞