C# Redis

引用:ServiceStackRedis

static void Main(string[] args)
 {
	 var Redis = new RedisClient(“127.0.0.1″, 6379);//redis服务IP和端口
	 #region =insert=
	 //var storeMembers = new List<string> { ”jj”, ”lihui”, ”cc” };
	 //storeMembers.ForEach(x => Redis.AddItemToList(“additemtolist”, x));
	 //注:也可直接使用AddRangeToList方法将一组数据装入如:
	 //Redis.AddRangeToList(“additemtolist”, storeMembers);
	 #endregion
	  #region =get=
	  //var members = Redis.GetAllItemsFromList(“additemtolist”);
	  //members.ForEach(s => Console.WriteLine(“additemtolist :” + s));
	  //Console.WriteLine(Redis.GetItemFromList(“additemtolist”, 2));
	  #endregion
	  #region =delete=
	  //var list = Redis.Lists["additemtolist"];
	  //list.Clear();//清空
	  //list.Remove(“two”);//移除指定键值
	  //list.RemoveAt(2);//移除指定索引位置数据
	  #endregion
	  #region =object=
	  //Redis.Set(“userinfo”, new UserInfo() { UserName = ”李四”, Age = 45 });
	  //UserInfo userinfo = Redis.Get<UserInfo>(“userinfo”);
	  //Console.WriteLine(userinfo.UserName);
	  //Redis.Set<int>(“my_age”, 12);//或Redis.Set(“my_age”, 12);
	  //Console.WriteLine(Redis.Get<int>(“my_age”));
	  #endregion
	  var ser = new ObjectSerializer();    //位于namespace ServiceStack.Redis.Support;
	  #region =序列化=
	  //bool result = Redis.Set<byte[]>(“userinfo”, ser.Serialize(new UserInfo() { UserName = ”张三”, Age = 12 }));
	  //UserInfo userinfo = ser.Deserialize(Redis.Get<byte[]>(“userinfo”)) as UserInfo;
	  //Console.WriteLine(userinfo.UserName);
	  #endregion
	  //也支持列表
	  //Redis.Set<byte[]>(“userinfolist_serialize”, ser.Serialize(userinfoList));
	  #region =负载均衡=
	  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 Redis2 = prcm.GetClient())
	  {
		  Redis2.Set(“userinfolist”, userinfoList);
		  List<UserInfo> userList = Redis2.Get<List<UserInfo>>(“userinfolist”);
	  }
	  #endregion
	  Console.ReadLine();
  }
  public static PooledRedisClientManager CreateManager(string[] readWriteHosts, string[] readOnlyHosts)
  {
	  //支持读写分离,均衡负载
	  return new PooledRedisClientManager(readWriteHosts, readOnlyHosts, new RedisClientManagerConfig
	  {
		  MaxWritePoolSize = 5,//“写”链接池链接数
		  MaxReadPoolSize = 5,//“写”链接池链接数
		  AutoStart = true,
	  });
  }

static void Main(string[] args)
{
   var Redis = new RedisClient(“127.0.0.1″, 6379);//redis服务IP和端口

   #region =insert=

   //var storeMembers = new List<string> { ”jj”, ”lihui”, ”cc” };
   //storeMembers.ForEach(x => Redis.AddItemToList(“additemtolist”, x));
   //注:也可直接使用AddRangeToList方法将一组数据装入如:

   //Redis.AddRangeToList(“additemtolist”, storeMembers);
   #endregion

   #region =get=

   //var members = Redis.GetAllItemsFromList(“additemtolist”);
   //members.ForEach(s => Console.WriteLine(“additemtolist :” + s));
   //Console.WriteLine(Redis.GetItemFromList(“additemtolist”, 2));
   #endregion

   #region =delete=

   //var list = Redis.Lists["additemtolist"];
   //list.Clear();//清空
   //list.Remove(“two”);//移除指定键值
   //list.RemoveAt(2);//移除指定索引位置数据
   #endregion
   #region =object=

   //Redis.Set(“userinfo”, new UserInfo() { UserName = ”李四”, Age = 45 });
   //UserInfo userinfo = Redis.Get<UserInfo>(“userinfo”);
   //Console.WriteLine(userinfo.UserName);

   //Redis.Set<int>(“my_age”, 12);//或Redis.Set(“my_age”, 12);
   //Console.WriteLine(Redis.Get<int>(“my_age”));
   #endregion

   var ser = new ObjectSerializer();    //位于namespace ServiceStack.Redis.Support;
   #region =序列化=
	//bool result = Redis.Set<byte[]>(“userinfo”, ser.Serialize(new UserInfo() { UserName = ”张三”, Age = 12 }));
	//UserInfo userinfo = ser.Deserialize(Redis.Get<byte[]>(“userinfo”)) as UserInfo;
	//Console.WriteLine(userinfo.UserName);
	#endregion

	//也支持列表
	//Redis.Set<byte[]>(“userinfolist_serialize”, ser.Serialize(userinfoList));

	#region =负载均衡=

	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 Redis2 = prcm.GetClient())
	{
		Redis2.Set(“userinfolist”, userinfoList);
		List<UserInfo> userList = Redis2.Get<List<UserInfo>>(“userinfolist”);
	}

	#endregion
	Console.ReadLine();
}
public static PooledRedisClientManager CreateManager(string[] readWriteHosts, string[] readOnlyHosts)
{
	//支持读写分离,均衡负载
	return new PooledRedisClientManager(readWriteHosts, readOnlyHosts, new RedisClientManagerConfig
	{
		MaxWritePoolSize = 5,//“写”链接池链接数
		MaxReadPoolSize = 5,//“写”链接池链接数
		AutoStart = true,
	});
}
此条目发表在article分类目录,贴了标签。将固定链接加入收藏夹。