1、redis簡單配置

1.安裝linux

  下載安裝後解壓便可執行make命令完成編譯,完整命令以下:redis

  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實例會額外佔用不少內存。

6.訪問遠程redis

  這裏先說配置文件中的兩個配置中的參數:

  bind:這個參數值表明這個地址能夠接收到請求。

  protect-mode:是否開啓保護模式,參數值只有"yes"和"no"。

  默認狀況下redis是隻能被本機訪問的,若是要被遠程訪問須要更改一點配置,在.conf配置文件中有一個"bind"的配置,默認是"bind 127.0.0.1",表示只能被本機訪問,若是將這個配置註釋掉則會容許全部訪問,可是註釋掉之後仍是不能訪問,由於redis默認是被保護起來的,因此找到配置文件中"protect-mode"的配置,默認是"yes",能夠改成"no",這時候全部的遠程服務器也均可以成功訪問,可是這樣是及其不安全的,生產環境不會這樣作,因此protect-mode仍是要改成yes,在bind這個參數後面加上容許接收請求的網卡ip地址便可。下面對bind作更詳細的解釋:

  假如如今有兩個遠程服務器ip分別是xxx.A和xxx.B,不少地方對於bind的解釋或者翻譯都是說只接收bind後面的ip的請求,因此容易配置成"bind xxx.A xxx.B",可是這樣其實仍是沒法訪問的。

  這裏要說bind實際上是網絡接口也就是網卡,一臺服務器可能有多個網卡,假如一個用來接收局域網請求的ip爲"xxx.C"和接收外網請求的ip爲"xxx.D",若是上面的"xxx.A""xxx.B"都在同一個局域網內,即須要使用"xxx.C"這塊網卡接收請求,那麼bind參數只須要配置上"bind xxx.C"兩臺服務器均可以成功訪問redis。

  總結:bind綁定的ip不是請求來源的ip,而是你redis服務器自己接受請求的ip。

相關文章
相關標籤/搜索