Go应该如何实现二级缓存
来源:脚本之家
时间:2023-02-24 21:56:55 462浏览 收藏
来到golang学习网的大家,相信都是编程学习爱好者,希望在这里学习Golang相关编程知识。下面本篇文章就来带大家聊聊《Go应该如何实现二级缓存》,介绍一下二级缓存,希望对大家的知识积累有所帮助,助力实战开发!
一、需求
- 实现二级缓存
- 程序运行起来后提示:“请输入命令:”,如果输入getall,查询并显示所有人员的信息
- 第一次时查询mysql并将结果缓存在redis,设置60秒的过期时间
- 以后的每次查询,如果redis有数据就从redis加载,没有则重复上一步的操作
二、实现连接Mysql并执行查询语句
先实现需求二,当输入命令getall时,查询并显示所有人员的信息。
package main import ( "fmt" _"github.com/go-sql-driver/mysql" "github.com/jmoiron/sqlx" ) type Human struct { Name string `db:"name"` Age int `db:"age"` } func main() { var cmd string for{ fmt.Println("请输入命令:") fmt.Scan(&cmd) switch cmd{ case "getall": //显示所有人的信息 GetAllPeople() case "exit": //退出程序 goto GAMEOVER default: fmt.Println("输入的命令有误,请重新输入!") } } GAMEOVER: fmt.Println("GAME OVER") } func GetAllPeople() { fmt.Println("allPeople") //先尝试拿缓存 GetPeopleFromRedis() db, _ := sqlx.Connect("mysql", "root:123456@tcp(localhost:3306)/mydb") defer db.Close() var people []Human err := db.Select(&people, "select name,age from person") if err!=nil{ fmt.Println("查询失败!err=",err) } fmt.Println(people) CachePeople2Redis(people) }
第一步还是导包,需要在mysql驱动包前面加上下划线_,因为它只是一个驱动文件,并不需要在代码中调用它的有关API接口.
接下来的这个结构体中后面的db:"name" db:"age"一定要加反单引号,否则运行时会报错。(傻傻的编者刚开始这里就出现问题啦~)
type Human struct { Name string `db:"name"` Age int `db:"age"` }
然后main函数里面都是一些基本语法知识,用了switch和goto这两个内容。
接下来就是连接数据库了,这里要用到数据库扩展包Sqlx,Sqlx包其实最大最大的优点是在查询方面,也就是使用select时优化得比较好。比原来的使用查询方便了不止一点。
db, _ := sqlx.Connect("mysql", "root:123456@tcp(localhost:3306)/mydb")
driverName:mysql,表示驱动器的名称是mysql也就上面"github.com/go-sql-driver/mysql"导入的驱动器。
dataSourceName是root:123456@tcp(localhost:3306)/mydb 它的含义是 账户名:密码@tcp(ip:端口)/数据库名称。
将缓存查询结果到Redis,就是通过这个函数CachePeople2Redis(people)。
三、写一个错误处理函数
func HandleError(err error,why string) { if err != nil{ fmt.Println(err,why) os.Exit(1) } }
因为后面需要处理很多错误,而错误处理也是GO的一个特性,所以我们这先写一个错误处理函数。
四、设置二级缓存
func CachePeople2Redis(people []Human) { conn, _ := redis.Dial("tcp", "localhost:6379") defer conn.Close() for _,human := range people{ humanStr := fmt.Sprint(human) _, err := conn.Do("rpush", "people", humanStr) if err != nil{ fmt.Println("缓存失败(rpush people),err=",err) return } } _, err := conn.Do("expire", "people", 66) if err!=nil{ HandleError(err,"@expire people 60") } fmt.Println("缓存成功!") }
redis.Dial()这个函数是用来连接redis的,需要给定网络协议和IP地址及端口号,redis的端口号默认为6379.
defer conn.Close()表示延时结束与redis的连接,为了节省系统的io资源,需要及时关闭连接!刚入门时我们很容易忘记这个,需要我们养成习惯!
conn.Do()是用来执行数据库命令的,第一个参数是命令名,后面的参数是数据库命令的参数。它返回的结果中reply是字节数组[]byte类型,需要根据具体的业务类型进行数据类型转换。
这段代码先将people数组中的每一个human放入到redis的people列表中。然后再执行expire命令,将列表设置过期时间。
执行成功!下面是运行结果:
请输入命令:
getall
allPeople
[{大扬 21} {小飞 21} {大红袍 1} {小芳 18}]
缓存成功!
请输入命令:
然后去看看数据库里面存进去没有。
127.0.0.1:6379> lrange people 0 -1 1) "{\xe5\xa4\xa7\xe6\x89\xac 21}" 2) "{\xe5\xb0\x8f\xe9\xa3\x9e 21}" 3) "{\xe5\xa4\xa7\xe7\xba\xa2\xe8\xa2\x8d 1}" 4) "{\xe5\xb0\x8f\xe8\x8a\xb3 18}"
过了一分钟之后,再查看redis数据库内的数据。
127.0.0.1:6379> lrange people 0 -1 (empty list or set)
已经消失了。
再写一个函数:
func GetPeopleFromRedis() (peopleStrs []string) { //连数据库 conn, _ := redis.Dial("tcp", "localhost:6379") //延迟关闭 defer conn.Close() //执行命令 reply, err := conn.Do("lrange", "people", 0, -1) //处理错误 HandleError(err,"@lrange people 0 -1") //类型转换 peopleStrs, err = redis.Strings(reply, err) //打印结果 fmt.Println("缓存拿取结果:",peopleStrs,err) return }
如果redis里面有就不需要从mysql里面取数据了。直接从redis里面利用lrange命令来获取people的所有值。
今天带大家了解了二级缓存的相关知识,希望对你有所帮助;关于Golang的技术知识我们会一点点深入介绍,欢迎大家关注golang学习网公众号,一起学习编程~
-
505 收藏
-
501 收藏
-
501 收藏
-
501 收藏
-
501 收藏
-
107 收藏
-
176 收藏
-
393 收藏
-
165 收藏
-
313 收藏
-
127 收藏
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 立即学习 542次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 立即学习 507次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 立即学习 497次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 立即学习 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 立即学习 484次学习