了解Redis
Redis 是一個開源、支援網路、基於記憶體、鍵值對的Key-Value 資料庫,使用ANSI C 編寫,並提供多種語言的API ,它幾乎沒有上手難度,只需要幾分鐘我們就能完成安裝工作,並讓它開始與應用程式順暢協作。換句話說,只要投入一小部分時間與精力,大家就能獲得即時且效果極佳的效能表現提升,就是說它是一個非常簡單快取解決方案。它支援儲存的 Value 類型不僅限於字串,支援主從同步,資料持久化等等,大家都認為 Redis 是最受歡迎的 Key-Value 儲存資料庫,一定有人問 Memcached 呢?
Redis VS Memcached
首先我剛去DB-Engines.com 的資料庫排行中看了一下,Redis 排行第九,Key-value store第一位;Memcached 排行二十三,Key-value store第二位。這當然不能說明什麼了。
Redis 支援更多的資料類型,包括:String、Hash、List、Set;Memcached 僅支援一種 String 資料類型。
Redis 透過 Multi/Watch/Exec 等命令可以支援事務的概念,原子性的執行一批命令;Memcached 的應用模式中,除了increment/decrement這樣的原子操作命令,不存在對事務的支持。
Redis 可以以 master-slave的方式配置伺服器實現主從同步備份,同時只持兩種持久化方案;Memcached 不保證儲存的資料的有效性,也不做資料的持久化工作。當然這些也都說明不了什麼。
每種事物存在著這個世界總有他的意義。 Memcached 的內部記憶體管理機制雖然不像Redis 的那樣複雜,但卻更具實際效率,因為Memcached 在處理元資料時所消耗的記憶體資源相對較少;在橫向擴展方面也比Redis更具優勢,由於其在設計上的思路傾向以及相對較簡單的功能設定。例如,快取一段字串或 Html頁面的時候,相對來說用 Memcached 會更好。
CentOS 下 安裝 Redis
1.下載解壓縮安裝 redis ,這裡是官網下載的最新的3.2.5版本,依然透過wget下載(我喜歡這種方式)。
wget http://download.redis.io/releases/redis-3.2.5.tar.gztar xzf redis-3.2.5.tar.gz mv redis-3.2.5 /usr/local/redis
上面 mv redis-3.2.5 /usr/local/redis 指令是移動 Redis 安裝檔案到安裝目錄,當然這個目錄你可以自訂。
2.進入目錄,編譯安裝
cd /usr/local/redis make make install
安裝完成,這時候會在/usr/local/bin/目錄下看到redis-server、redis-cli等這個可執行腳本,進入看一下,如果沒有,就要去解壓縮目錄複製進去了。
cd /usr/local/bin/
3.配置redis.conf
回到/usr/local/redis目錄,進行設定:
cd ../redis vim redis.conf
回到/usr/local/redis目錄,進行設定:
cd /usr/local/bin/ redis-server /usr/local/redis/redis.conf netstat -anp | grep 6379一個bind和daemonize就行。
bind這裡配置要注意,預設是只有一個127.0.0.1,這個時候只能自己連接,其他區域網路內是連接不上的。所以,需要設定多個 IP ,這樣就可以在區域網路內進行連接了。
修改完后,保存退出。
4.启动
cd /usr/local/bin/ redis-server /usr/local/redis/redis.conf netstat -anp | grep 6379
5.测试一下
这里用命令行模式连接上 Redis 进行一个简单的设置、获取缓存测试。
redis-cli #连接 Redis ,默认是本机的。 keys * #查看现在所有 keyset name mafly #设置一个key为`name`,value为`mafly`的缓存对象。 get name #获取key为`name`的缓存
6.关闭 Redis
redis-cli shutdown
通过 netstat 可以看出来端口已经是TIME_WAIT状态了。
总结一下
经过这次安装配置 Redis 的过程,也让我更加了解了一下 Memcached ,也更明白了这两种最流行的 Key-Value 缓存服务的优劣势,当然大多数都是通过网络获取,在实际运用中怎样也在监测中。