Linux 下 Redis 安裝詳解

http://www.oschina.net/question/12_18065 html

http://tech.it168.com/a2011/0830/1239/000001239923.shtml linux

================AA============================ 正則表達式

redis做爲NoSQL數據庫的一種應用,響應速度和命中率上仍是比較高效的。項目中須要用集中式可橫向擴展的緩存框架,作了一點調研,即使redis、memcached存在效率上的差別(具體比較參考http://timyang.net/data/mcdb-tt-redis/),但其實都能知足目前項目的需求;可是redis仍是比較風騷的,支持鏈表和集合操做,支持正則表達式查找key,目前項目緩存的結果大可能是鏈表,若是鏈表新增或者修改數據的話,redis就體現出了極大的優點(memcached只能從新加載鏈表,redis能夠對鏈表新增或者修改)

1:下載redis
下載地址 http://code.google.com/p/redis/downloads/list
推薦下載redis-1.2.6.tar.gz,以前這個版本同事已經有成功安裝運行的經驗,redis-2.0.4.tar.gz 這個版本我安裝後沒法操做緩存數據,具體緣由後續再說

2:安裝redis
下載後解壓 tar zxvf redis-1.2.6.tar.gz 到任意目錄,例如/usr/local/redis-1.2.6

解壓後,進入redis目錄
    cd /usr/local/redis-1.2.6  
    make  

拷貝文件
cp redis.conf /etc/ 這個文件時redis啓動的配置文件
cp redis-benchmark redis-cli redis-server /usr/bin/ #這個卻是頗有用,這樣就不用再執行時加上./了,並且能夠在任何地方執行

設置內存分配策略(可選,根據服務器的實際狀況進行設置)
/proc/sys/vm/overcommit_memory
可選值:0、一、2。
0, 表示內核將檢查是否有足夠的可用內存供應用進程使用;若是有足夠的可用內存,內存申請容許;不然,內存申請失敗,並把錯誤返回給應用進程。
1, 表示內核容許分配全部的物理內存,而無論當前的內存狀態如何。
2, 表示內核容許分配超過全部物理內存和交換空間總和的內存

值得注意的一點是,redis在dump數據的時候,會fork出一個子進程,理論上child進程所佔用的內存和parent是同樣的,好比parent佔用的內存爲8G,這個時候也要一樣分配8G的內存給child,若是內存沒法負擔,每每會形成redis服務器的down機或者IO負載太高,效率降低。因此這裏比較優化的內存分配策略應該設置爲 1(表示內核容許分配全部的物理內存,而無論當前的內存狀態如何)

開啓redis端口,修改防火牆配置文件
    vi /etc/sysconfig/iptables  

加入端口配置
    -A RH-Firewall-1-INPUT -m state --state NEW -m tcp -p tcp --dport 6379 -j ACCEPT  

從新加載規則
    service iptables restart   

3:啓動redis服務
    [root@Architect redis-1.2.6]# pwd  
    /usr/local/redis-1.2.6  
    [root@Architect redis-1.2.6]# redis-server /etc/redis.conf  

查看進程,確認redis已經啓動

    [root@Architect redis-1.2.6]# ps -ef | grep redis  
    root       401 29222  0 18:06 pts/3    00:00:00 grep redis  
    root     29258     1  0 16:23 ?        00:00:00 redis-server /etc/redis.conf  

若是這裏啓動redis服務失敗,通常狀況下是由於redis.conf文件有問題,建議檢查或找個可用的配置文件進行覆蓋,避免少走彎路,這裏建議,修改redis.conf,設置redis進程爲後臺守護進程

    # By default Redis does not run as a daemon. Use 'yes' if you need it.  
    # Note that Redis will write a pid file in /var/run/redis.pid when daemonized.  
    daemonize yes  

4:測試redis
    [root@Architect redis-1.2.6]# redis-cli  
    redis> set name songbin  
    OK  
    redis> get name   
    "songbin"  

5:關閉redis服務
    redis-cli shutdown  

redis服務關閉後,緩存數據會自動dump到硬盤上,硬盤地址爲redis.conf中的配置項dbfilename dump.rdb所設定
強制備份數據到磁盤,使用以下命令

    redis-cli save 或者 redis-cli -p 6380 save(指定端口) redis

=========================BB========================= 算法

     Redis是一個開源的使用ANSI C語言編寫、支持網絡、可基於內存亦可持久化的日誌型、Key-Value數據庫,並提供多種語言的API。從2010年3月15日起,Redis的開發工做由VMware主持。 數據庫

  如何安裝Redis? 緩存

  Redis的官方下載站是http://redis.io/download,能夠去上面下載最新的安裝程序下來,我寫此文章時的的穩定版本是2.2.12。 安全

如何安裝Redis?

  怎麼安裝 Redis數據庫呢?下面將介紹Linux版本的安裝方法: 服務器

  步驟一: 下載Redis 網絡

  下載安裝包:wget http://redis.googlecode.com/files/redis-2.2.12.tar.gz

  [root @localhost 4setup]# wget http: // redis.googlecode.com/files/redis-2.2.12.tar.gz

  -- 19: 06: 56-- http: // redis.googlecode.com/files/redis-2.2.12.tar.gz

  正在解析主機 redis.googlecode.com...  74.125. 71.82

  Connecting to redis.googlecode.com| 74.125. 71.82|: 80... 已鏈接。

  已發出 HTTP 請求,正在等待迴應...  200 OK

  長度: 455240 (445K) [application/x-gzip]

  Saving to: `redis- 2.2. 12.tar.gz '

   100%[==========================================>]  455, 240  34.8K/s  in 13s

   19: 07: 16 ( 34.8 KB/s) - `redis- 2.2. 12.tar.gz '  saved [455240/455240]

  [root @localhost 4setup]#

  步驟二: 編譯源程序

  [root @localhost 4setup]# ll

  總計  29168

  -rw-r--r--  1 root root  455240  2011- 07- 22 redis- 2.2. 12.tar.gz

  [root @localhost 4setup]# tar xzf redis- 2.2. 12.tar.gz

  [root @localhost 4setup]# cd redis- 2.2. 12

  [root @localhost redis- 2.2. 12]# make

  cd src && make all

  make[ 1]: Entering directory `/root/4setup/redis- 2.2. 12/src '

  步驟三: 啓動Redis服務

  src/redis-server

  [root @localhost redis- 2.2. 12]# src/redis-server

  [ 624605 Aug  19: 17: 22 # Warning: no config file specified, using the default config. In order  to specify a config file use  ' redis-server /path/to/redis.conf'

  [ 624605 Aug  19: 17: 22 * Server started, Redis version  2.2. 12

  [ 624605 Aug  19: 17: 22 # WARNING overcommit_memory  is  set  to  0! Background save may fail under low memory condition.  To  fix this issue add  ' vm.overcommit_memory = 1' to /etc/sysctl.conf and then reboot or run the command 'sysctl vm.overcommit_memory=1' for this to take effect.

  [ 624605 Aug  19: 17: 22 * The server  is  now ready  to accept connections  on port  6379

  [ 624605 Aug  19: 17: 22 -  0 clients connected ( 0 slaves),  539544 bytes in use

  Redis 服務端的默認鏈接端口是 6379。

  步驟四: 將Redis做爲 Linux 服務隨機啓動

  vi /etc/rc.local, 使用vi編輯器打開隨機啓動配置文件,並在其中加入下面一行代碼。

  /root/4setup/redis- 2.2. 12/src/redis-server
 

  步驟五: 客戶端鏈接驗證

  新打開一個Session輸入:src/redis-cli,若是出現下面提示,那麼您就能夠開始Redis之旅了。

  [root @localhost redis- 2.2. 12]# src/redis-cli

  redis  127.0. 0.1: 6379>

  步驟六: 查看Redis日誌

  查看服務器端session,便可對Redis的運行情況進行查看或分析了。

  [ 624605 Aug  19: 24: 33 -  0 clients connected ( 0 slaves),  539544 bytes in use

  [ 624605 Aug  19: 24: 37 - Accepted  127.0. 0.1: 51381

  [ 624605 Aug  19: 24: 38 -  1 clients connected ( 0 slaves),  547372 bytes in use

  以上的幾個步驟就OK了!!這樣一個簡單的Redis數據庫就能夠暢通無阻地運行起來了。

  步驟七: 中止Redis實例

  最簡單的方法是在啓動實例的session中,直接使用Control-C來將實例中止。

  咱們還能夠用客戶端來中止服務,如能夠用shutdown來中止Redis實例, 具體以下:

  [root @localhost redis- 2.2. 12]# src/redis-cli shutdown

======================配置=====================================

===================================================

linux平臺Redis安裝:

wget http://code.google.com/p/redis/downloads/detail?name=redis-2.0.4.tar.gz
tar xvzf redis-2.0.4.tar.gz
cd  redis-2.0.4
make
mkdir /home/redis
cp redis-server  /home/redis
cp redis-benchmark  /home/redis
cp redis-cli  /home/redis
cp redis.conf  /home/redis
cd  /home/redis

在安裝過程當中可能須要用到sudo命令,可能新裝的redhat虛擬機中新用戶還不能使用sudo命令,所以須要手動的修改/etc/sudoers文件,命令以下:

cd /etc
su root ##切換爲root用戶,同時輸入密碼
chmod u+w sudoers ##放開sudoers文件的寫權限
##在root ALL = (ALL) ALL下面一行增長 "你的用戶名" ALL = (ALL) ALL
:wq ##保存退出
chmod u-w sudoers ##取消修改權限

啓動 
./redis-server redis.conf 
進入命令交互模式,兩種: 
1:   ./redis-cli 
2:   telnet 127.0.0.1 6379       (ip接端口)

============================================================= 
配置文件參數說明: 

1. Redis默認不是以守護進程的方式運行,能夠經過該配置項修改,使用yes啓用守護進程 
    daemonize no 
2. 當Redis以守護進程方式運行時,Redis默認會把pid寫入/var/run/redis.pid文件,能夠經過pidfile指定 
    pidfile /var/run/redis.pid 
3. 指定Redis監聽端口,默認端口爲6379,做者在本身的一篇博文中解釋了爲何選用6379做爲默認端口,由於6379在手機按鍵上MERZ對應的號碼,而MERZ取自意大利歌女Alessia Merz的名字 
    port 6379 
4. 綁定的主機地址 
    bind 127.0.0.1 
5.當 客戶端閒置多長時間後關閉鏈接,若是指定爲0,表示關閉該功能 
    timeout 300 
6. 指定日誌記錄級別,Redis總共支持四個級別:debug、verbose、notice、warning,默認爲verbose 
    loglevel verbose 
7. 日誌記錄方式,默認爲標準輸出,若是配置Redis爲守護進程方式運行,而這裏又配置爲日誌記錄方式爲標準輸出,則日誌將會發送給/dev/null 
    logfile stdout 
8. 設置數據庫的數量,默認數據庫爲0,可使用SELECT <dbid>命令在鏈接上指定數據庫id 
    databases 16 
9. 指定在多長時間內,有多少次更新操做,就將數據同步到數據文件,能夠多個條件配合 
    save <seconds> <changes> 
    Redis默認配置文件中提供了三個條件: 
    save 900 1 
    save 300 10 
    save 60 10000
 
    分別表示900秒(15分鐘)內有1個更改,300秒(5分鐘)內有10個更改以及60秒內有10000個更改。 

10. 指定存儲至本地數據庫時是否壓縮數據,默認爲yes,Redis採用LZF壓縮,若是爲了節省CPU時間,能夠關閉該選項,但會致使數據庫文件變的巨大 
    rdbcompression yes 
11. 指定本地數據庫文件名,默認值爲dump.rdb 
    dbfilename dump.rdb 
12. 指定本地數據庫存放目錄 
    dir ./ 
13. 設置當本機爲slav服務時,設置master服務的IP地址及端口,在Redis啓動時,它會自動從master進行數據同步 
    slaveof <masterip> <masterport> 
14. 當master服務設置了密碼保護時,slav服務鏈接master的密碼 
    masterauth <master-password> 
15. 設置Redis鏈接密碼,若是配置了鏈接密碼,客戶端在鏈接Redis時須要經過AUTH <password>命令提供密碼,默認關閉 
    requirepass foobared 
16. 設置同一時間最大客戶端鏈接數,默認無限制,Redis能夠同時打開的客戶端鏈接數爲Redis進程能夠打開的最大文件描述符數,若是設置 maxclients 0,表示不做限制。當客戶端鏈接數到達限制時,Redis會關閉新的鏈接並向客戶端返回max number of clients reached錯誤信息 
    maxclients 128 
17. 指定Redis最大內存限制,Redis在啓動時會把數據加載到內存中,達到最大內存後,Redis會先嚐試清除已到期或即將到期的Key,當此方法處理 後,仍然到達最大內存設置,將沒法再進行寫入操做,但仍然能夠進行讀取操做。Redis新的vm機制,會把Key存放內存,Value會存放在swap區 
    maxmemory <bytes> 
18. 指定是否在每次更新操做後進行日誌記錄,Redis在默認狀況下是異步的把數據寫入磁盤,若是不開啓,可能會在斷電時致使一段時間內的數據丟失。由於 redis自己同步數據文件是按上面save條件來同步的,因此有的數據會在一段時間內只存在於內存中。默認爲no 
    appendonly no 
19. 指定更新日誌文件名,默認爲appendonly.aof 
     appendfilename appendonly.aof 
20. 指定更新日誌條件,共有3個可選值: 
    no:表示等操做系統進行數據緩存同步到磁盤(快) 
    always:表示每次更新操做後手動調用fsync()將數據寫到磁盤(慢,安全) 
    everysec:表示每秒同步一次(折衷,默認值) 
    appendfsync everysec 

21. 指定是否啓用虛擬內存機制,默認值爲no,簡單的介紹一下,VM機制將數據分頁存放,由Redis將訪問量較少的頁即冷數據swap到磁盤上,訪問多的頁面由磁盤自動換出到內存中(在後面的文章我會仔細分析Redis的VM機制) 
     vm-enabled no 
22. 虛擬內存文件路徑,默認值爲/tmp/redis.swap,不可多個Redis實例共享 
     vm-swap-file /tmp/redis.swap 
23. 將全部大於vm-max-memory的數據存入虛擬內存,不管vm-max-memory設置多小,全部索引數據都是內存存儲的(Redis的索引數據 就是keys),也就是說,當vm-max-memory設置爲0的時候,實際上是全部value都存在於磁盤。默認值爲0 
     vm-max-memory 0 
24. Redis swap文件分紅了不少的page,一個對象能夠保存在多個page上面,但一個page上不能被多個對象共享,vm-page-size是要根據存儲的 數據大小來設定的,做者建議若是存儲不少小對象,page大小最好設置爲32或者64bytes;若是存儲很大大對象,則可使用更大的page,若是不 肯定,就使用默認值 
     vm-page-size 32 
25. 設置swap文件中的page數量,因爲頁表(一種表示頁面空閒或使用的bitmap)是在放在內存中的,,在磁盤上每8個pages將消耗1byte的內存。 
     vm-pages 134217728 
26. 設置訪問swap文件的線程數,最好不要超過機器的核數,若是設置爲0,那麼全部對swap文件的操做都是串行的,可能會形成比較長時間的延遲。默認值爲4 
     vm-max-threads 4 
27. 設置在向客戶端應答時,是否把較小的包合併爲一個包發送,默認爲開啓 
    glueoutputbuf yes 
28. 指定在超過必定的數量或者最大的元素超過某一臨界值時,採用一種特殊的哈希算法 
    hash-max-zipmap-entries 64 
    hash-max-zipmap-value 512
 
29. 指定是否激活重置哈希,默認爲開啓(後面在介紹Redis的哈希算法時具體介紹) 
    activerehashing yes 
30. 指定包含其它的配置文件,能夠在同一主機上多個Redis實例之間使用同一份配置文件,而同時各個實例又擁有本身的特定配置文件 
    include /path/to/local.conf

相關文章
相關標籤/搜索