介绍

go-redis和redigo底层是通过调用的万能 Do 方法实现, 但是

redigo:

  • 由于输入是万能类型所以必须记住每个命令的参数和返回值情况, 使用起来非常的不友好,
  • 参数类型是万能类型导致在编译阶段无法检查参数类型,
  • 每个命令都需要花时间记录使用方法,参数个数等,使用成本高;

go-redis:

  • 细化了每个redis每个命令的功能, 我们只需记住命令,具体的用法直接查看接口的申请就可以了,使用成本低;
  • 其次它对数据类型按照redis底层的类型进行统一,编译时就可以帮助检查参数类型
  • 并且它的响应统一采用 Result 的接口返回,确保了返回参数类型的正确性,对用户更加友好;

性能对比

从上图可以看出, go-redis虽然每次操作会比redigo慢10%左右, 但是redigo需要显示申请/关闭连接,所以总体上二者的性能差异其实不大

Redigo库

redigo 是Redis数据库的Go客户端, 操作Redis基本和commands一样. Redigo命令基本都是通过Do方法来实现的.

Do

演示

演示基本的连接池建立, ping, string操作, hash操作, list操作, expire等操作

go-redis组件介绍和使用

go-redis提供了三种对应服务端的客户端模式,集群,哨兵,和单机模式,三种模式在连接池这一块都是公用的, 同时还提供了灵活的Hook机制, 其底层实际也是调用的万能 Do 方法.

但go-redis细化了每个redis每个命令的功能, 我们只需记住命令,具体的用法直接查看接口的申请就可以了,使用成本低;其次它对数据类型按照redis底层的类型进行统一,编译时就可以帮助检查参数类型, 并且它的响应统一采用 Result 的接口返回,确保了返回参数类型的正确性,对用户更加友好;

演示

演示基本的连接池建立, ping, string操作, hash操作, list操作, expire等操作

 性能测试

结果输出

goos: darwin
goarch: amd64
cpu: Intel(R) Core(TM) i7-9750H CPU @ 2.60GHz
BenchmarkRedis
BenchmarkRedis/redigo_client_Benchmark
BenchmarkRedis/redigo_client_Benchmark-12                26386         39110 ns/op
BenchmarkRedis/go-redis_client_Benchmark
BenchmarkRedis/go-redis_client_Benchmark-12              28186         37794 ns/op