高性能網站架構設計之緩存篇(1)- Redis C#客戶端


一、什么 Redis

REmote DIctionary Server,簡稱 Redis,是一個類似於Memcached的Key-Value存儲系統。相比Memcached,它支持更豐富的數據結構,包括string(字符串)、list(鏈表)、set(集合)、zset(sorted set --有序集合)和hash(哈希類型),並提供了數據持久化機制,在某些場景下,你完全可以把它當做非關系型數據庫來使用。它是一個高性能的存儲系統,能支持超過 100K+ 每秒的讀寫頻率。同時還支持消息的發布/訂閱,從而讓你在構建高性能消息隊列系統時多了另一種選擇。

二、下載

點擊這里下載

我在這里下載的是redis-3.0.0-beta5版,redis從3.0開始支持集群。
三、安裝

以下安裝均為 OSX 操作系統上的步驟:

1、找到你剛剛下載的 redis-3.0.0-beta5.tar.gz文件,解壓這個文件。

2、將解壓后的文件夾拷貝到你很容易找到的目錄下,並修改文件夾名為redis,因為版本號太長了。

2、打開終端,進入redis文件夾,命令如下:

Last login: Fri May 30 21:33:25 on ttys000

zhaoguihuadediannao:~ zhaogh$ cd applications/dev/redis

zhaoguihuadediannao:redis zhaogh$

3、在命令提示符出輸入 make 命令,稍等片刻,便能完成安裝。如果系統提示找不到 make 命令,請參考這篇文章。

裝好了,是不是有點小激動。抽根煙,我們繼續吧。

四、使用

1、啟動服務,先進入 src 目錄,然后執行 redis-server。

zhaoguihuadediannao:redis zhaogh$ cd src

zhaoguihuadediannao:src zhaogh$ ./redis-server

你將會看到:

2343:M 30 May 21:42:50.741 # Server started, Redis version 2.9.54

2343:M 30 May 21:42:50.741 * The server is now ready to accept connections on port 6379

我沒看錯吧,TMD我明明下載的3.0.0,怎么顯示 Redis version 2.9.54 ? 好吧,這不是重點,我也懶得追究了。

6379 是 redis 默認端口,在后續的文章中你將知道如何修改這個默認端口。

2、客戶端連接。

你會發現在執行了第四步之后,我們無法再執行其他命令了,怎么辦?因為redis獨占了此進程,后面告訴你們如果將它修改為后台運行。

我們暫且再打開一個終端吧。還是先進入 src 目錄:

zhaoguihuadediannao:~ zhaogh$ cd applications/dev/redis/src

zhaoguihuadediannao:src zhaogh$

輸入 ./redis-cli 命令:

zhaoguihuadediannao:src zhaogh$ ./redis-cli

127.0.0.1:6379>

已經連接上了,哈哈哈。

3、測試幾個 redis 命令:

127.0.0.1:6379> set testkey001 testkey001

OK

127.0.0.1:6379> get testkey001

"testkey001"

127.0.0.1:6379> append testkey001 aaa

(integer) 13

127.0.0.1:6379> get testkey001

"testkey001aaa"

127.0.0.1:6379>
4、關閉連接,執行 quit 命令

127.0.0.1:6379> quit

zhaoguihuadediannao:src zhaogh$

5、關閉服務。

由於我們剛才已經退出了客戶端,我們再次連接,並執行 shutdown 命令:

127.0.0.1:6379> shutdown

下面提供一個resdis幫助類

 

 /// <summary>  
    /// Redis公共輔助類庫  
    /// </summary>  
    public class RedisHelper : IDisposable
    {
        public RedisClient Redis = new RedisClient("127.0.0.1", 6379);
        //緩存池  
        PooledRedisClientManager prcm = new PooledRedisClientManager();
        //默認緩存過期時間單位秒  
        public int secondsTimeOut = 30 * 60;

        /// <summary>  
        /// 緩沖池  
        /// </summary>  
        /// <param name="readWriteHosts"></param>  
        /// <param name="readOnlyHosts"></param>  
        /// <returns></returns>  
        public static PooledRedisClientManager CreateManager(
         string[] readWriteHosts, string[] readOnlyHosts)
        {
            return new PooledRedisClientManager(readWriteHosts, readOnlyHosts,
                new RedisClientManagerConfig
                {
                    MaxWritePoolSize = readWriteHosts.Length * 5,
                    MaxReadPoolSize = readOnlyHosts.Length * 5,
                    AutoStart = true,
                });// { RedisClientFactory = (IRedisClientFactory)RedisCacheClientFactory.Instance.CreateRedisClient("127.0.0.1", 6379) };            
        }


        /// <summary>  
        /// 構造函數  
        /// </summary>  
        /// <param name="openPooledRedis">是否開啟緩沖池</param>  
        public RedisHelper(bool openPooledRedis = false)
        {
            if (openPooledRedis)
            {
                prcm = CreateManager(new string[] { "127.0.0.1:6379" }, new string[] { "127.0.0.1:6379" });
                Redis = prcm.GetClient() as RedisClient;
            }
        }

 #region Key/Value存儲  
        /// <summary>  
        /// 設置緩存  
        /// </summary>  
        /// <typeparam name="T"></typeparam>  
        /// <param name="key">緩存建</param>  
        /// <param name="t">緩存值</param>  
        /// <param name="timeout">過期時間,單位秒,-1:不過期,0:默認過期時間</param>  
        /// <returns></returns>  
        public bool Set<T>(string key, T t, int timeout = 0)
        {
            if (timeout >= 0)
            {
                if (timeout > 0)
                {
                    secondsTimeOut = timeout;
                }
                Redis.Expire(key, secondsTimeOut);
            }

            return Redis.Add<T>(key, t);
        }
        /// <summary>  
        /// 獲取  
        /// </summary>  
        /// <typeparam name="T"></typeparam>  
        /// <param name="key"></param>  
        /// <returns></returns>  
        public T Get<T>(string key)
        {
            return Redis.Get<T>(key);
        }
        /// <summary>  
        /// 刪除  
        /// </summary>  
        /// <param name="key"></param>  
        /// <returns></returns>  
        public bool Remove(string key)
        {
            return Redis.Remove(key);
        }

        public bool Add<T>(string key, T t, int timeout)
        {
            if (timeout >= 0)
            {
                if (timeout > 0)
                {
                    secondsTimeOut = timeout;
                }
                Redis.Expire(key, secondsTimeOut);
            }
            return Redis.Add<T>(key, t);
        }
        #endregion

        #region 鏈表操作  
        /// <summary>  
        /// 根據IEnumerable數據添加鏈表  
        /// </summary>  
        /// <typeparam name="T"></typeparam>  
        /// <param name="listId"></param>  
        /// <param name="values"></param>  
        /// <param name="timeout"></param>  
        public void AddList<T>(string listId, IEnumerable<T> values, int timeout = 0)
        {
            Redis.Expire(listId, 60);
            IRedisTypedClient<T> iredisClient = Redis.As<T>();
            if (timeout >= 0)
            {
                if (timeout > 0)
                {
                    secondsTimeOut = timeout;
                }
                Redis.Expire(listId, secondsTimeOut);
            }
            var redisList = iredisClient.Lists[listId];
            redisList.AddRange(values);
            iredisClient.Save();
        }

/// <summary>  
        /// 添加單個實體到鏈表中  
        /// </summary>  
        /// <typeparam name="T"></typeparam>  
        /// <param name="listId"></param>  
        /// <param name="Item"></param>  
        /// <param name="timeout"></param>  
        public void AddEntityToList<T>(string listId, T Item, int timeout = 0)
        {
            IRedisTypedClient<T> iredisClient = Redis.As<T>();
            if (timeout >= 0)
            {
                if (timeout > 0)
                {
                    secondsTimeOut = timeout;
                }
                Redis.Expire(listId, secondsTimeOut);
            }
            var redisList = iredisClient.Lists[listId];
            redisList.Add(Item);
            iredisClient.Save();
        }
        /// <summary>  
        /// 獲取鏈表  
        /// </summary>  
        /// <typeparam name="T"></typeparam>  
        /// <param name="listId"></param>  
        /// <returns></returns>  
        public IEnumerable<T> GetList<T>(string listId)
        {
            IRedisTypedClient<T> iredisClient = Redis.As<T>();
            return iredisClient.Lists[listId];
        }
        /// <summary>  
        /// 在鏈表中刪除單個實體  
        /// </summary>  
        /// <typeparam name="T"></typeparam>  
        /// <param name="listId"></param>  
        /// <param name="t"></param>  
        public void RemoveEntityFromList<T>(string listId, T t)
        {
            IRedisTypedClient<T> iredisClient = Redis.As<T>();
            var redisList = iredisClient.Lists[listId];
            redisList.RemoveValue(t);
            iredisClient.Save();
        }
        /// <summary>  
        /// 根據lambada表達式刪除符合條件的實體  
        /// </summary>  
        /// <typeparam name="T"></typeparam>  
        /// <param name="listId"></param>  
        /// <param name="func"></param>  
        public void RemoveEntityFromList<T>(string listId, Func<T, bool> func)
        {
            using (IRedisTypedClient<T> iredisClient = Redis.As<T>())
            {
                var redisList = iredisClient.Lists[listId];
                T value = redisList.Where(func).FirstOrDefault();
                redisList.RemoveValue(value);
                iredisClient.Save();
            }
        }
        #endregion

 

/// <summary>
        /// 釋放資源
        /// </summary>
        public void Dispose()
        {
            if (Redis != null)
            {
                Redis.Dispose();
                Redis = null;
            }
            GC.Collect();
        }

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM