二级缓存(Go语言实现)-《GO开发知识笔记》

admin 2025-11-04 01:05:10 编程 来源:ZONE.CI 全球网 0 阅读模式

    一、需求

    • 实现二级缓存
    • 程序运行起来后提示:“请输入命令:”,如果输入getall,查询并显示所有人员的信息
    • 第一次时查询mysql并将结果缓存在redis,设置60秒的过期时间
    • 以后的每次查询,如果redis有数据就从redis加载,没有则重复上一步的操作

    二、实现连接Mysql并执行查询语句

    先实现需求二,当输入命令getall时,查询并显示所有人员的信息。

    1. package main
    2. import (
    3. "fmt"
    4. _"github.com/go-sql-driver/mysql"
    5. "github.com/jmoiron/sqlx"
    6. )
    7. type Human struct {
    8. Name string `db:"name"`
    9. Age int `db:"age"`
    10. }
    11. func main() {
    12. var cmd string
    13. for{
    14. fmt.Println("请输入命令:")
    15. fmt.Scan(&cmd)
    16. switch cmd{
    17. case "getall":
    18. //显示所有人的信息
    19. GetAllPeople()
    20. case "exit":
    21. //退出程序
    22. goto GAMEOVER
    23. default:
    24. fmt.Println("输入的命令有误,请重新输入!")
    25. }
    26. }
    27. GAMEOVER:
    28. fmt.Println("GAME OVER")
    29. }
    30. func GetAllPeople() {
    31. fmt.Println("allPeople")
    32. //先尝试拿缓存
    33. GetPeopleFromRedis()
    34. db, _ := sqlx.Connect("mysql", "root:123456@tcp(localhost:3306)/mydb")
    35. defer db.Close()
    36. var people []Human
    37. err := db.Select(&people, "select name,age from person")
    38. if err!=nil{
    39. fmt.Println("查询失败!err=",err)
    40. }
    41. fmt.Println(people)
    42. CachePeople2Redis(people)
    43. }

    第一步还是导包,需要在mysql驱动包前面加上下划线_,因为它只是一个驱动文件,并不需要在代码中调用它的有关API接口.接下来的这个结构体中后面的db:”name” db:”age”一定要加反单引号,否则运行时会报错。(傻傻的编者刚开始这里就出现问题啦~)

    1. type Human struct {
    2. Name string `db:"name"`
    3. Age int `db:"age"`
    4. }

    然后main函数里面都是一些基本语法知识,用了switch和goto这两个内容。接下来就是连接数据库了,这里要用到数据库扩展包Sqlx,Sqlx包其实最大最大的优点是在查询方面,也就是使用select时优化得比较好。比原来的使用查询方便了不止一点。

    1. 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)。三、写一个错误处理函数

    1. func HandleError(err error,why string) {
    2. if err != nil{
    3. fmt.Println(err,why)
    4. os.Exit(1)
    5. }
    6. }

    因为后面需要处理很多错误,而错误处理也是GO的一个特性,所以我们这先写一个错误处理函数。四、设置二级缓存

    1. func CachePeople2Redis(people []Human) {
    2. conn, _ := redis.Dial("tcp", "localhost:6379")
    3. defer conn.Close()
    4. for _,human := range people{
    5. humanStr := fmt.Sprint(human)
    6. _, err := conn.Do("rpush", "people", humanStr)
    7. if err != nil{
    8. fmt.Println("缓存失败(rpush people),err=",err)
    9. return
    10. }
    11. }
    12. _, err := conn.Do("expire", "people", 66)
    13. if err!=nil{
    14. HandleError(err,"@expire people 60")
    15. }
    16. fmt.Println("缓存成功!")
    17. }

    redis.Dial()这个函数是用来连接redis的,需要给定网络协议和IP地址及端口号,redis的端口号默认为6379.defer conn.Close()表示延时结束与redis的连接,为了节省系统的io资源,需要及时关闭连接!刚入门时我们很容易忘记这个,需要我们养成习惯!conn.Do()是用来执行数据库命令的,第一个参数是命令名,后面的参数是数据库命令的参数。它返回的结果中reply是字节数组[]byte类型,需要根据具体的业务类型进行数据类型转换。这段代码先将people数组中的每一个human放入到redis的people列表中。然后再执行expire命令,将列表设置过期时间。执行成功!下面是运行结果:请输入命令:getallallPeople[{大扬 21} {小飞 21} {大红袍 1} {小芳 18}]缓存成功!请输入命令:然后去看看数据库里面存进去没有。

    1. 127.0.0.1:6379> lrange people 0 -1
    2. 1) "{\xe5\xa4\xa7\xe6\x89\xac 21}"
    3. 2) "{\xe5\xb0\x8f\xe9\xa3\x9e 21}"
    4. 3) "{\xe5\xa4\xa7\xe7\xba\xa2\xe8\xa2\x8d 1}"
    5. 4) "{\xe5\xb0\x8f\xe8\x8a\xb3 18}"

    过了一分钟之后,再查看redis数据库内的数据。

    1. 127.0.0.1:6379> lrange people 0 -1
    2. (empty list or set

    已经消失了。再写一个函数:

    1. func GetPeopleFromRedis() (peopleStrs []string) {
    2. //连数据库
    3. conn, _ := redis.Dial("tcp", "localhost:6379")
    4. //延迟关闭
    5. defer conn.Close()
    6. //执行命令
    7. reply, err := conn.Do("lrange", "people", 0, -1)
    8. //处理错误
    9. HandleError(err,"@lrange people 0 -1")
    10. //类型转换
    11. peopleStrs, err = redis.Strings(reply, err)
    12. //打印结果
    13. fmt.Println("缓存拿取结果:",peopleStrs,err)
    14. return
    15. }

    如果redis里面有就不需要从mysql里面取数据了。直接从redis里面利用lrange命令来获取people的所有值。

    以太坊cppgolang区别 编程

    以太坊cppgolang区别

    以太坊是一种去中心化的开源平台,它采用智能合约技术,旨在构建和运行不受干扰的分布式应用程序。作为目前最受欢迎的区块链平台之一,以太坊提供了多种编程语言的支持,其
    progolang 编程

    progolang

    Go语言(Golang)是由Google开发的一门静态类型编程语言。作为一名专业的Golang开发者,我深知这门语言的优势和特点。在本文中,我将介绍Golang
    golangn个发送者 编程

    golangn个发送者

    Golang是一种开源的编程语言,由Google团队开发,旨在提高程序的并发性和简化软件开发过程。在Go语言中,有时需要向多个接收者发送信息。本文将介绍如何在G
    golang技能图谱 编程

    golang技能图谱

    从互联网行业的快速发展到人工智能技术的日益成熟,各种编程语言也应运而生。而在这众多的编程语言中,Golang(即Go)作为一门强大且高效的开发语言备受关注。Go
    评论:0   参与:  14