基本信息
源码名称:Redis多线程 批量插入 性能测试 示例
源码大小:23.22M
文件格式:.zip
开发语言:C#
更新时间:2016-11-27
友情提示:(无需注册或充值,赞助后即可获取资源下载链接)
嘿,亲!知识可是无价之宝呢,但咱这精心整理的资料也耗费了不少心血呀。小小地破费一下,绝对物超所值哦!如有下载和支付问题,请联系我们QQ(微信同号):813200300
本次赞助数额为: 2 元×
微信扫码支付:2 元
×
请留下您的邮箱,我们将在2小时内将文件发到您的邮箱
源码介绍
下为基础操作:
using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Diagnostics;
using System.Drawing;
using System.Linq;
using System.Runtime.InteropServices;
using System.Text;
using System.Threading;
using System.Threading.Tasks;
using System.Windows.Forms;
using ServiceStack.Redis;
using ServiceStack.Redis.Generic;
namespace SSRedisDemo
{
public partial class Form1 : Form
{
public static IRedisClientsManager clientsManager=null;
public static IRedisClient redisClient=null;
public Form1()
{
InitializeComponent();
var count = this.tabControl1.TabCount;
for (int i = 0; i < count; i )
{
this.tabControl1.GetControl(i).Enabled = false;
}
this.tabControl1.GetControl(0).Enabled = true;
}
private void btnConn_Click(object sender, EventArgs e)
{
try
{
#region 集群访问方式
var host = String.Format("{2}@{0}:{1}", this.txtHost.Text, this.txtPort.Text, this.txtPwd.Text);
host = String.Format("{0}:{1}", this.txtHost.Text, this.txtPort.Text);//v3.0格式
clientsManager = new PooledRedisClientManager(new string[] {host});
redisClient = clientsManager.GetClient();
#endregion
#region 单个实例方式
//redisClient = new RedisClient(this.txtHost.Text, Int32.Parse(this.txtPort.Text),this.txtPwd.Text);
#endregion
}
catch(Exception ex)
{
MessageBox.Show("失败:" ex.Message);
return;
}
MessageBox.Show("成功");
var count = this.tabControl1.TabCount;
for (int i = 0; i < count; i )
{
this.tabControl1.GetControl(i).Enabled = true;
}
}
private void btnSetString_Click(object sender, EventArgs e)
{
redisClient.Set(this.txtStringKey.Text, this.txtStringValue.Text);
}
private void btnGetString_Click(object sender, EventArgs e)
{
var strValue=redisClient.Get<string>(this.txtStringKey.Text);
MessageBox.Show(strValue);
}
private void btnTransaction_Click(object sender, EventArgs e)
{
using (IRedisClient RClient = clientsManager.GetClient())
{
RClient.Add("key", 1);
using (IRedisTransaction IRT = RClient.CreateTransaction())
{
IRT.QueueCommand(r => r.Set("key", 20));
IRT.QueueCommand(r => r.Increment("key", 1));
IRT.Commit(); // 提交事务
}
MessageBox.Show(RClient.Get<string>("key"));
}
}
private void btnAcquireLock_Click(object sender, EventArgs e)
{
using (IRedisClient RClient = clientsManager.GetClient())
{
RClient.Add("mykey", 1);
// 支持IRedisTypedClient和IRedisClient
using (RClient.AcquireLock("testlock"))
{
//Response.Write("申请并发锁<br/>");
var counter = RClient.Get<int>("mykey");
Thread.Sleep(100);
RClient.Set("mykey", counter 1);
MessageBox.Show(RClient.Get<int>("mykey").ToString());
}
}
}
private void btnQueue_Click(object sender, EventArgs e)
{
redisClient.EnqueueItemOnList("operLog", "操作时间:" DateTime.Now.ToString());
MessageBox.Show("写入成功");
}
private void btnQueueRead_Click(object sender, EventArgs e)
{
string msg = redisClient.DequeueItemFromList("operLog");
MessageBox.Show(msg);
}
/// <summary>
/// DecrementValue 根据指定的Key,将值减1(仅整型有效)
///DecrementValueBy 根据指定的Key,将值减去指定值(仅整型有效)
///IncrementValue 根据指定的Key,将值加1(仅整型有效)
///IncrementValueBy 根据指定的Key,将值加上指定值(仅整型有效)
/// </summary>
/// <param name="sender"></param>
/// <param name="e"></param>
private void btnIncStart_Click(object sender, EventArgs e)
{
var key = "incKey";
var v = redisClient.IncrementValue(key);//将值加1(仅整型有效)
redisClient.IncrementValueBy(key, 100);//将值加100
MessageBox.Show("Success");
}
private void btnIncStop_Click(object sender, EventArgs e)
{
var key = "incKey";
var v = redisClient.Get<long>(key);
MessageBox.Show("当前值:" v.ToString());
}
private void btnTypedClient_Click(object sender, EventArgs e)
{
Person p1 = new Person() { Id = 1, Name = "刘备" };
Person p2 = new Person() { Id = 2, Name = "关羽" };
Person p3 = new Person() { Id = 3, Name = "张飞" };
Person p4 = new Person() { Id = 4, Name = "曹操" };
Person p5 = new Person() { Id = 5, Name = "典韦" };
Person p6 = new Person() { Id = 6, Name = "郭嘉" };
List<Person> ListPerson = new List<Person>() { p2, p3, p4, p5, p6 };
using (IRedisClient RClient = clientsManager.GetClient())
{
IRedisTypedClient<Person> IRPerson = RClient.As<Person>();
IRPerson.DeleteAll();
//------------------------------------------添加--------------------------------------------
//添加单条数据
IRPerson.Store(p1);
//添加多条数据
IRPerson.StoreAll(ListPerson);
//------------------------------------------查询--------------------------------------------
//Linq支持
MessageBox.Show("Id == 1 的Name:" IRPerson.GetAll().Where(m => m.Id == 1).First().Name); //刘备
//注意,用IRedisTypedClient的对象IRPerson的Srore()添加的才能用IRPerson()方法读取
MessageBox.Show("Id == 2 的Name:" IRPerson.GetAll().First(m => m.Id == 2).Name); //关羽
//------------------------------------------删除--------------------------------------------
IRPerson.Delete(p1); //删除 刘备
MessageBox.Show("删除刘备后总数:" IRPerson.GetAll().Count()); //5
IRPerson.DeleteById(2); //删除 关羽
MessageBox.Show("删除关羽后总数:" IRPerson.GetAll().Count()); //4
IRPerson.DeleteByIds(new List<int> { 3, 4 }); //删除张飞 曹操
MessageBox.Show("删除张飞曹操后总数:" IRPerson.GetAll().Count()); //2
IRPerson.DeleteAll(); //全部删除
MessageBox.Show("全部删除后总数:" IRPerson.GetAll().Count()); //0
}
}
private void btnTestAddSetReplace_Click(object sender, EventArgs e)
{
using (IRedisClient RClient = clientsManager.GetClient())
{
RClient.Add("c1", "缓存1");
RClient.Set("c1", "缓存2");
RClient.Replace("c1", "缓存3");
MessageBox.Show(RClient.Get<string>("c1"));
RClient.Remove("c1");
MessageBox.Show("移除状态:" (RClient.Get<string>("c1") == null));
}
}
private void btnList_T_Click(object sender, EventArgs e)
{
using (IRedisClient RClient = clientsManager.GetClient())
{
//内部维护一个List<T>集合
RClient.AddItemToList("蜀国", "刘备");
RClient.AddItemToList("蜀国", "关羽");
RClient.AddItemToList("蜀国", "张飞");
List<string> ListString = RClient.GetAllItemsFromList("蜀国");
foreach (string str in ListString)
{
MessageBox.Show(str); //输出 刘备 关羽 张飞
}
}
}
private void btnHash_T_Click(object sender, EventArgs e)
{
using (IRedisClient RClient = clientsManager.GetClient())
{
//Hash<T>
RClient.AddItemToSet("魏国", "曹操");
RClient.AddItemToSet("魏国", "曹操");
RClient.AddItemToSet("魏国", "典韦");
HashSet<string> HashSetString = RClient.GetAllItemsFromSet("魏国");
foreach (string str in HashSetString)
{
MessageBox.Show(str); //输出 典韦 曹操
}
}
}
private void btnList_Range_Click(object sender, EventArgs e)
{
using (IRedisClient RClient = clientsManager.GetClient())
{
//内部维护一个List<T>集合
RClient.AddItemToSortedSet("蜀国1", "刘备", 5);
RClient.AddItemToSortedSet("蜀国1", "关羽", 2);
RClient.AddItemToSortedSet("蜀国1", "张飞", 3);
IDictionary<String, double> DicString = RClient.GetRangeWithScoresFromSortedSet("蜀国1", 0, 2);
foreach (var r in DicString)
{
MessageBox.Show(r.Key ":" r.Value); //输出 关羽 张飞 刘备
}
}
}
private void btnHashTable_Click(object sender, EventArgs e)
{
using (IRedisClient RClient = clientsManager.GetClient())
{
RClient.SetEntryInHash("xxx", "key", "123");
List<KeyValuePair<string, string>> keyValuePairs = new List<KeyValuePair<string, string>>();
KeyValuePair<string, string> kvp = new KeyValuePair<string, string>("key", "1");
keyValuePairs.Add(kvp);
RClient.SetRangeInHash("xxx", keyValuePairs);
MessageBox.Show(string.Join("\r\n", RClient.GetHashValues("xxx").ToArray()));
}
}
private void btnSaveT_Click(object sender, EventArgs e)
{
var keyT = "tkey";
redisClient.Set(keyT, new Person() { Id = 6, Name = "好例子" });
var p = redisClient.Get<Person>(keyT);
MessageBox.Show(p.Name);
}
private void btnBatchAdd_Click_1(object sender, EventArgs e)
{
var seed = DateTime.Now.ToString("yyyyMMddHHmmss");
var count = 10000;
Stopwatch watch = new Stopwatch();
using (IRedisClient RClient = clientsManager.GetClient())
{
watch.Start();
for (var i = 0; i < count; i )
{
RClient.Add(seed "" i.ToString(), "缓存" i);
}
watch.Stop();
MessageBox.Show("单线程插入" count "条数据,用时:" watch.ElapsedMilliseconds "毫秒");
}
}
private void btnBatchQueue_Click(object sender, EventArgs e)
{
var seed = DateTime.Now.ToString("yyyyMMddHHmmss");
var count = 10000;
Stopwatch watch = new Stopwatch();
using (IRedisClient RClient = clientsManager.GetClient())
{
watch.Start();
for (var i = 0; i < count; i )
{
redisClient.EnqueueItemOnList("testQueueLog","操作时间:" i);
}
watch.Stop();
MessageBox.Show("单线程插入" count "条数据,用时:" watch.ElapsedMilliseconds "毫秒");
}
}
private void btnBatchAddMulitThread_Click(object sender, EventArgs e)
{
string message="";
var count = int.Parse(this.txtDataCount.Text);// 10000;
var threadCount = int.Parse(this.txtThreadCount.Text);// 20;
int rand = new Random().Next(1, 10000);
Stopwatch watchTotal = new Stopwatch();
watchTotal.Start();
var tasks = new Task[threadCount];
for (int i = 0; i < tasks.Length; i )
{
int taskIndex = i;
tasks[i] = Task.Factory.StartNew(() =>
{
rand = int.Parse(taskIndex.ToString());
var seed = DateTime.Now.ToString("yyyyMMddHHmmss") "_" rand;
Stopwatch watch = new Stopwatch();
using (IRedisClient RClient = clientsManager.GetClient())
{
watch.Start();
for (var j = 0; j < count; j )
{
RClient.Add(seed "" j.ToString(), "缓存" j);
}
watch.Stop();
message = ("\r\n" rand "该线程插入" count "条数据,用时:" watch.ElapsedMilliseconds "毫秒");
}
}
);
}
Task.WaitAll(tasks);
watchTotal.Stop();
//var startNew = Task<string>.Factory.StartNew((o) => ("holy " o), "cow");
//Console.WriteLine(startNew.Result);
MessageBox.Show(threadCount "个线程插入" threadCount * count "条数据,共用时:" watchTotal.ElapsedMilliseconds "毫秒" ",平均用时:" watchTotal.ElapsedMilliseconds/threadCount "毫秒/万条" message);
}
}
public class Person
{
public int Id { get; set; }
public string Name { get; set; }
}
}