sanhutrees 发表于 2018-9-19 12:18:52

golang--Redis最佳的Go语言驱动

  Redis可以缓存数据,这使得操作数据可以达到一个较快的速度,在一些需要数据较快存储的场合,例如微博,redis发挥着不可替代的作用。在redis的官网,golang驱动有几个,忽然来了兴致,那个才是redis最佳的Go语言驱动?
  这些驱动都处于开发的前期,还没有发行正式版,有些已经很久没更新了。从更新日期来看,Gary Burd的radigo和gosexy的redis最近有更新,而且从他们的README文件来看,他们对redis的支持还不错。很有可能,他们两者会有1个胜出。但到底谁才是最佳的,这个现在还是不能判断。在gosexy的redis源码库中的有个_benchmarks文件,里面就是一些对各个redis的Go驱动的一些简单的性能测试。简单看了一下,里面的代码就是调用他们各自包中的函数来达到测试的功能。大家不妨看一下。这里就通过这个测试,来简单判断一下谁是最佳。
  首先,安装各个Go的驱动:
  

go get github.com/alphazero/Go-Redis  
go get github.com
/simonz05/godis  
go get github.com
/garyburd/redigo  
go get github.com
/gosexy/redis  
go get cgl.tideland.biz
/redis  

  注意:tcgl原先托管在google,不过现在它现在自己组建源码库了,gosexy的redis的_benchmarks的tcgl_redis_test.go就import了google的版本,不过现在要修改了。也就是注释掉code.google.com/p/tcgl/redis,添加 cgl.tideland.biz/redis,这样我们才能进行下一步动作。
  在一个终端打开redis:
  

redis-server  

  我们要进入_benchmarks这个文件夹,里面的README.md有进行性能测试的步骤,这里要进行的性能测试的操作有Ping, Set, Get, Incr, LPush, LRange10, LRange100, 其中LRange10和 LRange100都是调用LRange操作,不过他们的数量不同而已。以下是我在这些文件夹里面进行的操作。
  新开一个终端:
  

go test -test.bench='.*' > redis-go-driver-benchmark.txt  
.
/grep_data.sh  

  grep_data是我写的一个脚本:
  

#!/bin/sh  
for i in AlphazeroRedis GaryburdRedigo GosexyRedis Simonz05Godis TcglRedis
  
do
  
grep $i redis-go-driver-benchmark.txt| awk '{print $3}' > $i
  
done
  

  这个脚本的作用就是将AlphazeroRedis、GaryburdRedigo、GosexyRedis、Simonz05Godis、TcglRedis等的测试数据从redis-go-driver-benchmark.txt提取出来,也就是他们各自操作的数据,然后写入以他们名字命名的文件里面。我们可以打开AlphazeroRedis看一下,
  

39001  
43967
  
43459
  
43350
  
44249
  
58078
  
139603
  

  这些数据依次对应Ping, Set, Get, Incr, LPush, LRange10, LRange100的每次操作所需要的纳秒时间。我写了一个R的小程序来把这些数据显示到一个图上面,对R不是很熟悉,希望了解R的大牛指正。下面上代码:
  

png(filename="redis的最佳go语言驱动--使用格通测试的数据.png",width=1400,>
Sys.setlocale(,"zh_CN.UTF-8")  
oldpar
页: [1]
查看完整版本: golang--Redis最佳的Go语言驱动