首頁  >  文章  >  後端開發  >  Redis 對比 Memcached 並在 CentOS 下進行安裝配置

Redis 對比 Memcached 並在 CentOS 下進行安裝配置

高洛峰
高洛峰原創
2016-11-30 14:46:47942瀏覽

了解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

Redis 對比 Memcached 並在 CentOS 下進行安裝配置

上面 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/

Redis 對比 Memcached 並在 CentOS 下進行安裝配置

3.配置redis.conf

回到/usr/local/redis目錄,進行設定:

cd ../redis
vim redis.conf

回到/usr/local/redis目錄,進行設定:Redis 對比 Memcached 並在 CentOS 下進行安裝配置

cd /usr/local/bin/
redis-server /usr/local/redis/redis.conf
netstat -anp | grep 6379

一個bind和daemonize就行。

bind這裡配置要注意,預設是只有一個127.0.0.1,這個時候只能自己連接,其他區域網路內是連接不上的。所以,需要設定多個 IP ,這樣就可以在區域網路內進行連接了。

Redis 對比 Memcached 並在 CentOS 下進行安裝配置

daemonize是設定是否後台啟動 Redis,預設no,正常都需要以服務形式啟動 Redis,所以這裡設定為yes。

Redis 對比 Memcached 並在 CentOS 下進行安裝配置

修改完后,保存退出。

4.启动

cd /usr/local/bin/
redis-server /usr/local/redis/redis.conf
netstat -anp | grep 6379

Redis 對比 Memcached 並在 CentOS 下進行安裝配置

5.测试一下
这里用命令行模式连接上 Redis 进行一个简单的设置、获取缓存测试。

redis-cli    #连接 Redis ,默认是本机的。
keys *       #查看现在所有 
keyset name mafly    #设置一个key为`name`,value为`mafly`的缓存对象。
get name     #获取key为`name`的缓存

Redis 對比 Memcached 並在 CentOS 下進行安裝配置

6.关闭 Redis

redis-cli shutdown

Redis 對比 Memcached 並在 CentOS 下進行安裝配置

通过 netstat 可以看出来端口已经是TIME_WAIT状态了。

总结一下

经过这次安装配置 Redis 的过程,也让我更加了解了一下 Memcached ,也更明白了这两种最流行的 Key-Value 缓存服务的优劣势,当然大多数都是通过网络获取,在实际运用中怎样也在监测中。



陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn