一、redis簡單配置
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實例會額外占用很多內存。
一、redis簡單配置