博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
golang--Redis最佳的Go语言驱动
阅读量:6538 次
发布时间:2019-06-24

本文共 3366 字,大约阅读时间需要 11 分钟。

hot3.png

Redis可以缓存数据,这使得操作数据可以达到一个较快的速度,在一些需要数据较快存储的场合,例如微博,redis发挥着不可替代的作用。在redis的官网,golang驱动有几个,忽然来了兴致,那个才是redis最佳的Go语言驱动?

这些驱动都处于开发的前期,还没有发行正式版,有些已经很久没更新了。从更新日期来看,Gary Burd的和gosexy的最近有更新,而且从他们的README文件来看,他们对redis的支持还不错。很有可能,他们两者会有1个胜出。但到底谁才是最佳的,这个现在还是不能判断。在gosexy的redis源码库中的有个文件,里面就是一些对各个redis的Go驱动的一些简单的性能测试。简单看了一下,里面的代码就是调用他们各自包中的函数来达到测试的功能。大家不妨看一下。这里就通过这个测试,来简单判断一下谁是最佳。

首先,安装各个Go的驱动:

go get github.com/alphazero/Go-Redisgo get github.com/simonz05/godisgo get github.com/garyburd/redigogo get github.com/gosexy/redisgo get cgl.tideland.biz/redis

注意:tcgl原先托管在google,不过现在它现在自己组建源码库了,gosexy的redis的的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/shfor i in AlphazeroRedis GaryburdRedigo GosexyRedis Simonz05Godis TcglRedis do    grep $i redis-go-driver-benchmark.txt  | awk '{print $3}' > $idone

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

390014396743459433504424958078139603

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

png(filename="redis的最佳go语言驱动--使用格通测试的数据.png",width=1400, height=900)Sys.setlocale(, "zh_CN.UTF-8")oldpar <- par(lwd=4)AlphazeroRedis <- read.table("AlphazeroRedis")GaryburdRedigo <- read.table("GaryburdRedigo")GosexyRedis <- read.table("GosexyRedis")Simonz05Godis <- read.table("Simonz05Godis")TcglRedis <- read.table("TcglRedis")plot(AlphazeroRedis$V1, type="o", ylim = c(0, 360000), col = "black", axes=FALSE, ann=FALSE)text(2, AlphazeroRedis$V1[2], cex=2, pos=3, col="black", "AlphazeroRedis")axis(1, at=1:8, lab=c("Ping","Set","Get","Incr", "LPush", "LRange10", "LRange100", ""))axis(2, las=0, at=40000*0: 360000)box()title(xlab="操作", col = "black")title(ylab="每个操作多少纳秒", col = "black")title(main = "5个Redis的Go语言驱动操作比较--使用格通测试的数据")lines(GaryburdRedigo, col = "red")text(6, GaryburdRedigo$V1[6]-10000, cex=2, pos=1, col="red", "GaryburdRedigo")lines(GosexyRedis, col = "blue")text(2, GosexyRedis$V1[2], pos=1,col="blue", cex=2, "GosexyRedis")lines(Simonz05Godis, col = "yellow")text(4, Simonz05Godis$V1[4]+7000,pos=3, col="yellow",cex=2, "Simonz05Godis")lines(TcglRedis, col = "gray")text(3, TcglRedis$V1[3],pos=1,cex=2, col="gray", "TcglRedis")par(oldpar)dev.off()

保存为go-redis-getongs-data.R,用R来调用这个文件:

$R>source("go-redis-getongs-data.R")

在目录下面会生成一个叫”redis的最佳go语言驱动--使用格通测试的数据.png“的文件,我特意把图给放大,以便能够清楚看到线条的走向,图有点大,可能在这里显示不正确:

在的README.md有gosexy测试的数据,我修改了上面的go-redis-getongs-data.R文件,把gosexy测试的数据整理到图上去:

2副图可以看出,tcgl无疑是5个中耗时最多的。在我测试的数据中,GosexyRedis几乎赢得了所有的测试(除了LRange100输给了GaryburdRedigo),GaryburdRedigo基本上是排老二。而使用gosexy的数据,除了tcgl,其他4个的数据相差不大,而GaryburdRedigo还是赢得了LRange100测试,说明在数量比较大的list方面,GaryburdRedigo是十分有优势的。

从上面的数据可以知道,set, get, incr,lpush的操作耗时都在40微秒左右,那就是1s里面能够操作25000次左右。我自己算了一下,吓了一跳, 好像比其他使用案例高了一个数量级(有错希望指正了)。

上面的测试只涉及部分的redis操作,在整体对redis的支持方面,还是需要继续添加其他功能测试。毕竟现在Go才开始发展,还需要继续添砖加瓦。各位看完后也可以自己动手测试一下。

转贴请注明来自:

转载于:https://my.oschina.net/u/191928/blog/618619

你可能感兴趣的文章
XVIII Open Cup named after E.V. Pankratiev. Eastern Grand Prix
查看>>
数据恢复软件如何换机使用?
查看>>
《高性能mysql》到手
查看>>
(转)关于如何学好游戏3D引擎编程的一些经验
查看>>
使用Kotlin为你的APP自定义一个统一的标题栏
查看>>
EF各版本增删查改及执行Sql语句
查看>>
拓扑排序
查看>>
jQGrid API
查看>>
MySQL定时检查是否宕机并邮件通知
查看>>
Bzoj1758: [Wc2010]重建计划
查看>>
LOJ2541:「PKUWC2018」猎人杀
查看>>
从零开始学习Sencha Touch MVC应用之十四
查看>>
redis集群部署及踩过的坑
查看>>
j2EE监听器-listener
查看>>
使用pip命令报You are using pip version 9.0.3, however version 18.0 is available pip版本过期.解决方案...
查看>>
2017.11.14 小组第二次例会
查看>>
(转)LINQ之路
查看>>
WCF 入门
查看>>
Linux Shell编程4
查看>>
Django REST框架--关系和超链接api
查看>>