日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 运维知识 > 数据库 >内容正文

数据库

使用ServiceStackRedis链接Redis简介

發布時間:2025/7/25 数据库 29 豆豆
生活随笔 收集整理的這篇文章主要介紹了 使用ServiceStackRedis链接Redis简介 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

?

?注:關于如何在windows,linux下配置redis,詳見這篇文章:)?

???? 目前網上有一些鏈接Redis的C#客戶端工具,這里介紹其中也是目前我們企業版產品中所使用的ServiceStackRedis, 鏈接地址:
????? https://github.com/mythz/ServiceStack.Redis

???? 下面該鏈接中的源碼包或dll文件,引入到項目中,并添加如下名空間引用(僅限本文):
using ServiceStack.Common.Extensions;
using ServiceStack.Redis;
using ServiceStack.Redis.Generic;
using ServiceStack.Text;
using ServiceStack.Redis.Support;
??? 注:ServiceStackRedis封裝了大量方法和對象,這里只摘有代表性的內容介紹,更多內容參見其官方文檔。

??? 聲明一個客戶端對象:
??? protected RedisClient Redis = new RedisClient("10.0.4.227", 6379);//redis服務IP和端口


一 .基本KEY/VALUE鍵值對操作:
??? 1. 添加/獲取:?
? List<string> storeMembers = new List<string>();
? storeMembers.ForEach(x
=> Redis.AddItemToList("additemtolist", x));

??? 注:也可直接使用AddRangeToList方法將一組數據裝入如:

????? Redis.AddRangeToList("addarrangetolist", storeMembers);

??? 2. 獲取數據
? var members = Redis.GetAllItemsFromList("additemtolist");
? members.ForEach(s
=> Response.Write("<br/>additemtolist :" + s));?
??? 3. 獲取指定索引位置數據?
var item = Redis.GetItemFromList("addarrangetolist", 2);?
??? 4. 移除:
? var list = Redis.Lists["addarrangetolist"];
? list.Clear();
//清空
? list.Remove("two");//移除指定鍵值
? list.RemoveAt(2);//移除指定索引位置數據


二.存儲對象:
??? public class UserInfo
??? {
???????
public long Id { set; get; }
???????
public string UserName { get; set; }
???????
public int Age { get; set; }
??? }
?
??? 1.通常方式(底層使用json序列化):
? Redis.Set<UserInfo>("userinfo", new UserInfo() { UserName = "李四", Age = 45 });
? UserInfo userinfo
= Redis.Get<UserInfo>("userinfo");?
??? 注:當然上面方式也適合于基本類型,如:
??? Redis.Set<int>("my_age", 12);//或Redis.Set("my_age", 12);
??? int age = Redis.Get<int>("my_age");
???
??? 2.object序列化方式存儲:
? var ser = new ObjectSerializer();??? //位于namespace ServiceStack.Redis.Support;
? bool result = Redis.Set<byte[]>("userinfo", ser.Serialize(new UserInfo() { UserName = "張三", Age = 12 }));
? UserInfo userinfo
= ser.Deserialize(Redis.Get<byte[]>("userinfo")) as UserInfo;
?
//也支持列表
? Redis.Set<byte[]>("userinfolist_serialize", ser.Serialize(userinfoList));
? List
<UserInfo> userList = ser.Deserialize(Redis.Get<byte[]>("userinfolist_serialize")) as List<UserInfo>;
??? 需要說明的是在測試過程中發現JSON序列化的效率要比object序列化高一些。
?
三.存儲表格對象,比如:

? using (var redisUsers = Redis.GetTypedClient<UserInfo>())
? {
????? redisUsers.Store(
new UserInfo { Id = redisUsers.GetNextSequence(), UserName = "daizhj", Age = 12 });
????? redisUsers.Store(
new UserInfo { Id = redisUsers.GetNextSequence(), UserName = "daizhenjun", Age = 13 });

????? var allUsers
= redisUsers.GetAll();//就像操作ado對象一樣,可以進行CRUD等操作
????? allUsers.ForEach(s => Response.Write("<br/>user :" + s.UserName + " age:" + s.Age));
? }

?????
四.使用客戶端鏈接池模式提升鏈接速度:

? public static PooledRedisClientManager CreateManager(string[] readWriteHosts, string[] readOnlyHosts)
? {
??????
//支持讀寫分離,均衡負載
?????? return new PooledRedisClientManager(readWriteHosts, readOnlyHosts, new RedisClientManagerConfig
?????? {
?????????? MaxWritePoolSize
= 5,//“寫”鏈接池鏈接數
?????????? MaxReadPoolSize = 5,//“寫”鏈接池鏈接數
?????????? AutoStart = true,
?????? });?????????
? }
?
???? 聲明鏈接池對象(這里只使用一個redis服務端):
? PooledRedisClientManager prcm = CreateManager(new string[] { "10.0.4.210:6379" }, new string[] { "10.0.4.210:6379" });

? List
<UserInfo> userinfoList = new List<UserInfo>();
? userinfoList.Add(
new UserInfo() { UserName = "pool_daizhj", Age = 1 });
? userinfoList.Add(
new UserInfo() { UserName = "pool_daizhj1", Age = 2 });?????????
??? 從池中獲取一個鏈接:
? using (IRedisClient Redis = prcm.GetClient())
? {?????????????
?????? Redis.Set(
"userinfolist", userinfoList);
?????? List
<UserInfo> userList = Redis.Get<List<UserInfo>>("userinfolist");
? }


注:
? 1.前三種方式我在本地測試發現存取效率從高到底,具體原因還待分析。

? 2.如只想使用長鏈接而不是鏈接池的話,可以直接將下面對象用static方式聲明即可:?
????? protected static RedisClient Redis = new RedisClient("10.0.4.227", 6379);

??? 這樣在redis服務端顯示只有一個客戶鏈接

?? 3.與memcached測試過程中發現,在存儲時兩者效率接近(使用本文第一種方式),在取數據時memcached速度比redis要快一些(毫秒級差異),這一點并不像網上一些文章所說的那樣,看來在實際開發和生產環境下還要以使用背景及結果為準。

轉載于:https://www.cnblogs.com/cxd4321/archive/2012/12/14/2817600.html

總結

以上是生活随笔為你收集整理的使用ServiceStackRedis链接Redis简介的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。