1.安裝 下載安裝後解壓即可執行make命令完成編譯,完整命令如下: wget http://download.redis.io/redis-stable.tar.gz tar xzf redis-stable.tar.gz cd redis-stable make 編譯完成後直接執行make in ...
1.安裝
下載安裝後解壓即可執行make命令完成編譯,完整命令如下:
wget http://download.redis.io/redis-stable.tar.gz
tar xzf redis-stable.tar.gz
cd redis-stable
make
編譯完成後直接執行make install命令來將這些可執行程式複製到/usr/local/bin目錄中以便以後執行程式可以不用輸入完整的路徑。
2.啟動和停止
最常用的兩個程式是redis-server和redis-cli,其中redis-server是redis的伺服器,啟動redis即運行redis-server;而redis-cli是redis自帶的redis命令行客戶端。
啟動有直接啟動和通過初始化腳本啟動兩種方式,分別適用於開發環境和生產環境。
直接啟動
直接運行redis-server即可啟動redis。
redis伺服器預設會使用6379埠,通過--port參數可以自定義埠號:
redis-server --port 6380
通過初始化腳本啟動redis
在linux系統中可以通過初始化腳本啟動redis,使得redis能跟隨系統自動啟動,在生產環境中推薦使用此方法運行redis。在redis源碼目錄的utils文件夾中有一個名為redis_init_script的初始化腳本文件。
我們需要配置redis的運行方式和持久化文件、日誌文件的存儲位置等,具體步驟如下:
(1)配置初始化腳本。首先將初始化腳本複製到/etc/init.d目錄中,文件名為redis_埠號,其中埠號表示要讓redis監聽的埠號,客戶端通過該埠號鏈接redis。然後修改腳本REDISPORT變數的值為同樣的埠號。
(2)建立需要的文件夾。
/etc/redis 存放redis的配置文件
/var/redis/埠號 存放redis的持久化文件
(3)修改配置文件。首先將文件模板(在redis根目錄中redis.conf)複製到/etc/redis目錄中,以埠號命名(如6379.conf),然後按照以下樣例對部分參數進行編輯。
參數 值 說明
daemonize yes 使redis以守護進程模式運行
pidfile /var/run/redis_埠號.pid 設置redis的pid文件位置
port 埠號 設置redis監聽的埠號
dir /var/redis/埠號 設置持久化文件存放位置
現在就可以使用/etc/init.d/redis_埠號start來啟動redis了,而後需要執行下麵的命令使redis隨系統自動啟動:
update-rc.d redis_埠號 defaults
停止redis
考慮到redis有可能正在將記憶體中的數據同步到硬碟中,強行終止redis進程可能會導致數據丟失。正確停止redis的方式應該是向redis發送shutdown命令,方法為:
redis-cli shutdown
當redis收到shutdown命令,會先斷開所有的客戶端連接,然後根據配置執行持久化,最後完成退出。
redis可以妥善處理sigterm信號,所以使用"kill redis進程的PID"也可以正常結束redis,效果同上。
3.redis命令行客戶端
發送命令
通過redis-cli向redis發送命令的方式有兩種:
第一種後面直接加參數,比如redis-cli第一種後面直接加參數,比如redis-cli shutdown。執行時會自動按照預設的配置(伺服器地址為127.0.0.1,埠號為6379)鏈接redis,通過-h和-p參數可以自定義地址和埠號:
redis-cli -h 127.0.0.1 -p 6379
redis提供了ping命令來測試客戶端與redis的鏈接是否正常,如果連接正常會收到PONG。
第二種只輸入redis-cli不添加任何參數會進入交互模式,可以執行任何命令。
命令返回值
命令返回有5種類型
(1)狀態恢復
比如向redis發送set命令設置某個鍵的值,會返回OK表示設置成功,另外發送PING返回PONG也是狀態回覆。
(2)錯誤回覆
當出現命令不存在或命令格式有錯誤等情況redis會返回錯誤回覆,以(error)開頭,後面跟錯誤信息。
(3)整數回覆
redis沒有整數類型,但是提供了一些用於整數操作的命令,整數回覆以(integer)開頭,併在後面跟上整數數據。
(4)字元串回覆
當請求一個字元串類型鍵的鍵值或一個其他類型鍵中的某個元素時就會得到一個字元串回覆,字元串回覆以雙引號包裹。
(5)多行字元串回覆
當請求一個非字元串類型鍵的元素列表時就會收到多行字元串回覆,多行字元串回覆中的每行字元串都是以一個序號開頭。
4.配置
由於redis配置選項比較多,通過啟動參數設置這些選項不方便,所以redis支持通過配置文件來設置這些選項。啟用配置文件的方法是啟動時將配置文件的路徑作為啟動參數傳遞給redis-server,如:
redis-server /path/to/redis.conf
通過啟動參數傳遞同名的配置選項會覆蓋配置文件中相應的參數。
除此之外redis可以在運行時通過"config set"命令在不重新啟動redis的情況下動態修改部分redis配置(不是所有的配置都可以這樣修改),如:
redis>config set loglevel warning
OK
運行時也可以使用"config get"命令獲得redis當前的配置情況,如:
redis>config get loglevel
1)"loglevel"
2)"warning"
第一行字元串回覆表示的是選項名,第二行是選項值。
5.多資料庫
redis是一個字典結構的存儲伺服器,而實際上一個redis實例提供了多個用來存儲數據的字典,客戶端可以指定將數據存儲的哪個字典中。這與我們熟知的在一個關係資料庫實例中可以創建多個資料庫類似,所以可以將其中的每個字典都理解成一個獨立的資料庫。
每個資料庫對外都是以一個從0開始的遞增數字命名,redis預設支持16個資料庫,可以通過配置參數database來修改這一數字。客戶端與redis建立連接後會自動選擇0號資料庫,不過可以隨時使用select命令更換資料庫,如要選擇1號資料庫:
redis>select 1
OK
然而這些以數字命名的資料庫又與我們理解的資料庫有所區別。首先redis不支持自定義資料庫名字,每個資料庫都是以編號命名,開發者必須自己記錄哪些資料庫存儲了哪些數據。另外也不支持為每個資料庫設置不同的訪問密碼,所以一個客戶端要麼可以訪問全部資料庫,要麼連一個資料庫也沒有訪問許可權。最重要的是多個資料庫之間並不是完全隔離的,比如flushall命令可以清空一個redis實例中所有資料庫的數據。綜上所述,這些資料庫更像是一種命名空間,而不適宜存儲不同應用程式的數據。比如可以使用0號資料庫存儲某個應用生產環境中的數據,使用1號資料庫存儲測試環境中的數據,但不適宜使用0號資料庫存儲A應用的數據,使用1號資料庫存儲B應用的數據,不同的應用數據使用不同的redis實例存儲數據。由於redis非常輕量級,一個空的redis實例占用記憶體只有1MB左右,所以不用擔心多個redis實例會額外占用很多記憶體。