『性能』ServiceStack.Redis 和 StackExchange.Redis 性能比较
背景
近来,需要用到 Redis 这类缓存技术 —— MongoDB 和 Redis 没有进行过比较。
我也懒得在这些细节上 纠结那么多 —— 按照网友给出的文章,听从网友建议,选择 Redis。
Redis 我在 2014年的时候正式用过一次,那时候用的是 ServiceStack.Redis —— 要引用4、5个程序集,挺闹心的。
正题
开始比较 客户端调用时, ServiceStack.Redis 与 StackExchange.Reids 的性能。
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading;
using ServiceStack.Redis;
using StackExchange.Redis;
namespace Temp_20180713_Redis
{
class Program
{
static void Main(string[] args)
{
DateTime time0 = DateTime.Now;
DateTime time1 = DateTime.Now;
#region StackExchange.Redis
{
IConnectionMultiplexer proxy = ConnectionMultiplexer.Connect("127.0.0.1");
IDatabase db = proxy.GetDatabase(6379);
time0 = DateTime.Now;
for (int i = 0; i < 100000; i++)
{
db.StringSet("AAAA", "AAAAAAA");
}
time1 = DateTime.Now;
Console.WriteLine("StackExchange.Redis 赋值 10,0000 次, 耗时: {0} 秒", (time1 - time0).TotalSeconds);
string valueStr = "";
time0 = DateTime.Now;
for (int i = 0; i < 100000; i++)
{
RedisValue value = db.StringGet("AAAA");
valueStr = value;
}
time1 = DateTime.Now;
Console.WriteLine("StackExchange.Redis 取值 10,0000 次, 耗时: {0} 秒", (time1 - time0).TotalSeconds);
Console.WriteLine(valueStr);
Console.WriteLine("----------------------------------");
}
#endregion
#region ServiceStack.Redis
using (RedisClient redisClient = new RedisClient("127.0.0.1", 6379))
{
time0 = DateTime.Now;
for (int i = 0; i < 100000; i++)
{
redisClient.Set("AAAA", "AAAAAAA");
}
time1 = DateTime.Now;
Console.WriteLine("ServiceStack.Redis 赋值 10,0000 次, 耗时: {0} 秒", (time1 - time0).TotalSeconds);
string valueStr = "";
time0 = DateTime.Now;
for (int i = 0; i < 100000; i++)
{
valueStr = redisClient.Get<string>("AAAA");
}
time1 = DateTime.Now;
Console.WriteLine("ServiceStack.Redis 取值 10,0000 次, 耗时: {0} 秒", (time1 - time0).TotalSeconds);
Console.WriteLine(valueStr);
Console.WriteLine("----------------------------------");
}
#endregion
}
}
}
比较结果如图:
没错: ServiceStack.Redis 居然崩溃了:每小时只能调用 6000次,除非购买商用版。【别说商用了,6000次,我个人使用都不够啊】
我将 ServiceStack.Redis 降级到 3.9.40 版本,继续测试
结论
同样的 10W次 赋值、取值 调用。
StackExchange.Redis 耗时 18秒
ServiceStack.Redis 耗时 16秒
—— ServiceStack.Redis 性能高一点点。
建议
但最终:我还是觉得应该选择 StackExchange.Redis
理由如下:
StackExchange.Redis 和 ServiceStack.Redis 两者性能差距不大,性能差别仅 11%
StackExchange.Redis 没有版权限制,暂时没有出现 不给钱只调用 6000 次。
我看了一下 两个框架的函数定义: StackExchange.Redis 定义得更友善一些。反例比如:ServiceStack.Redis 有 Hash字段赋值函数,却没有 Hash字段取值函数(除非你把指定的Hash 全部键值对都取出来,然后再筛选指定的字段 —— 那些不需要的也得取出来,感觉挺浪费的)
而且某些地方的 隐式转换 可以节省不少代码:自动帮你推断你想要的数据类型。
当然,两者的实现原理 我这边并未深究,也懒得深究。
其实,我也不知道 StackExchange.Redis 是否支持 .Net 40 —— 否则就真的是一大败笔了。
其实我想要的很简单
最低支持 .Net 40。
没有过分的使用限制(比如每小时6000次)。
不要引用一堆的程序集,最好一个程序集就行。
友好的函数封装
我特别讨厌,一个三方框架好几个程序集
如果这个框架,实现的功能比较多,好几个程序集区分功能 我可以理解。
你特么就只实现一个功能,却稀里糊涂给我一堆程序集 是个什么鬼 ~
看到太多程序集,我会有一种不安全感:
如果发布时少了个程序集怎么办?
程序集少更新了其中一个怎么办?
这些程序集在偷偷干嘛?
如果复制程序集时,把部分64位的复制替换了了32位而导致执行时(可能是偶发异常)才报错怎么办?)
就不能把 附属程序集 嵌入到主程序集中么?要么内存加载子程序集,要么自动释放子程序集。
我只想无脑的 Ctrl+C Ctrl+V,我不想 复制粘贴时 还要顾忌这、担心那。
『性能』ServiceStack.Redis 和 StackExchange.Redis 性能比较的更多相关文章
- (三)Redis for StackExchange.Redis
目录 (一)Redis for Windows正确打开方式 (二)Redis for 阿里云公网连接 (三)Redis for StackExchange.Redis StackExchange.Re ...
- asp.net Core 使用redis(StackExchange.Redis)
原文:asp.net Core 使用redis(StackExchange.Redis) 一.添加配置(appsettings.json) "Redis": { "Def ...
- 怎样在Redis通过StackExchange.Redis 存储集合类型List
StackExchange 是由StackOverFlow出品, 是对Redis的.NET封装,被越来越多的.NET开发者使用在项目中. 绝大部分原先使用ServiceStack的开发者逐渐都转了过来 ...
- 在.Net下使用redis基于StackExchange.Redis
研究了下redis在.net下的使用,因为以前在java上用redis用的是jedis操作,在.net不是很熟悉,在网站上也看了一部分的.net下redis的使用,大部分都是ServiceStack. ...
- 在.net中使用redis(StackExchange.Redis)
本文介绍如何在.net中使用redis 安装 代码使用 StackExchange.Redis基础使用 StackExchange.Redis中的事务 安装(windows平台) 安装Chocolat ...
- Redis和StackExchange.Redis
redis有多个数据库1.redis 中的每一个数据库,都由一个 redisDb 的结构存储.其中,redisDb.id 存储着 redis 数据库以整数表示的号码.redisDb.dict 存储着该 ...
- .NetCore使用Redis,StackExchange.Redis队列,发布与订阅,分布式锁的简单使用
环境:之前一直是使用serverStack.Redis的客服端,今天来使用一下StackExchange.Redis(个人感觉更加的人性化一些,也是免费的,性能也不会差太多),版本为StackExch ...
- .net core 使用redis 基于 StackExchange.Redis
一.添加引用包 StackExchange.Redis Microsoft.Extensions.Configuration 二.修改配置文件 appsettings.json { " ...
- c#使用 StackExchange.Redis 封装 RedisHelper
公司一直在用.net自带的缓存,大家都知道.net自带缓存的缺点,就不多说了,不知道的可以查一查,领导最近在说分布式缓存,我们选的是redis,领导让我不忙的时候封装一下,搜索了两天,选了选第三方的插 ...
随机推荐
- 遍历php数组的几种方法
第一.foreach() foreach()是一个用来遍历数组中数据的最简单有效的方法. <?php $urls= array('aaa','bbb','ccc','ddd'); foreach ...
- Spring结合log4j(slf4j)
maven依赖 <!-- slf4j (级联:log4j/slf4j-api) --> <dependency> <groupId> ...
- 2018山东省ACM省赛G题-Game
Alice and Bob are playing a stone game. There are n piles of stones. In each turn, a player can remo ...
- 1、原生javascript方法小汇
Js 对象 使用new 关键字来创建对象,举例如下, var a = new String();如构造函数无参数,则不必加括号, JS内部对象数组(Array)对象创建数组var myarray = ...
- (六)SpringBoot2.0基础篇- Redis整合(JedisCluster集群连接)
一.环境 Redis:4.0.9 SpringBoot:2.0.1 Redis安装:Linux(Redhat)安装Redis 二.SpringBoot整合Redis 1.项目基本搭建: 我们基于(五) ...
- Netty中的连接管理
连接管理是我们首先需要关注的,检测空闲连接以及超时对于及时释放资源来说是至关重要的.由于这是一项常见的任务,Netty特地为它提供了几个ChannelHandler实现. 用于空闲连接以及超时的Cha ...
- Java 8 文件操作(转)
我们知道在JDK6甚至之前的时候,我们想要读取一个文本文件也是非常麻烦的一件事,而现在他们都变得简单了, 这要归功于NIO2,我们先看看之前的做法: 读取一个文本文件 BufferedReader b ...
- Java NIO Buffer缓冲区
原文链接:http://tutorials.jenkov.com/java-nio/buffers.html Java NIO Buffers用于和NIO Channel交互.正如你已经知道的,我们从 ...
- HTTP Strict Transport Security实战详解
HTTP Strict Transport Security (通常简称为HSTS) 是一个安全功能,它告诉浏览器只能通过HTTPS访问当前资源, 禁止HTTP方式. 0×01. Freebuf百科: ...
- C语言实现计算双基回文数详解
双基回文数的定义: 如果一个正整数n至少在两个不同的进位制(二进制<=进制=<十进制)b1和b2下都是回文数,则称n是双基回文数. 根据定义,简单的说就是在二进制到十进制之间(包括十进制和 ...