Linux 下安裝 Redis 伺服器

來源:互聯網
上載者:User

標籤:redis   redis伺服器   redis配置   zmalloc_used_memory   redis安裝   

        本文簡單介紹了 Linux 下安裝 Redis 伺服器的步驟,同時簡要介紹伺服器的配置、啟動以及狀態檢測。另外還介紹了 32 位 CentOS 下安裝 Redis 時遇到的一些問題的解決。
        一、 查看 Linux 相關資訊
        版本查看
cat /etc/issue
CentOS release 5.5 (Final)
        位元查看
getconf LONG_BIT
32
        二、 安裝 tcl
        先裝好 tcl,不然 redis 的 make test 不會通過。也可以先安裝 redis 再回過頭來裝 tcl。
        1. 下載 tcl 安裝包
        訪問 http://sourceforge.net/projects/tcl/files/Tcl/,選擇你想要的版本進行下載。作者選擇的是最新穩定版 tcl8.6.1-src.tar.gz,大小 8.5 MB。作者也上傳了一份到 csdn 資源,如果你嫌國外伺服器網速慢,可以下載這個:tcl8.6.1 安裝包。
        2. 安裝
tar xvzf tcl8.6.1-src.tar.gz
cd tcl8.6.1/unix/
./configure
make
make test
make install

        三、 安裝 Redis
        1. 下載 redis 安裝包
        訪問 http://redis.io/download,選擇適合你的情境的版本進行下載。作者選擇的是最新穩定版 redis-2.8.10.tar.gz,大小 1 MB。作者也上傳了一份到 csdn 資源,如果你嫌國外伺服器網速慢,可以下載這個:redis-2.8.10 安裝包。
        2. 區域網路共用
        大部分人的開發環境是 Windows,作者也不例外(當然,Linux 下的軟體開發環境也是很棒的,比如作者就曾在 Linux 下做過半年的 Java Mobile 開發,那段體驗很精彩)。
        所以一般都是先下載到了 Windows 本地(如果你的網速給力也可以用 wget),然後 ftp 到 Linux。當然也可以用掛載的方式,比如作者將 redis-2.8.10.tar.gz 下載到了 D:\defonds\work\20140610,先把此檔案夾共用,Win7 平台下,右擊需要檔案 20140610 -> 屬性 -> 選擇 "共用" 頁項,點 "共用..." 按鈕 -> 檔案分享權限設定對話方塊裡點擊 "共用" 按鈕確認共用,系統會提示已共用並顯示該共用的項目:

        本網查看:

        3. 掛載
        建立 redis 目錄:
mkdir /home/defonds/redis
        比如上一步分享的 ip 是 192.21.40.134,該機使用者名稱 defonds,密碼是 defonds:
mount -o "username=defonds,password=defonds" //192.21.40.134/20140610 /home/defonds/redis
        掛載成功以後,可以使用 df 進行查看掛載結果,比如:
//192.21.40.134/20140610 133122588  72559176  60563412  55% /home/defonds/redis
        4. 安裝
cd /home/defonds/redis
tar xvzf redis-2.8.10.tar.gz
cd redis-2.8.10
make
mkdir /usr/local/redis
make PREFIX=/usr/local/redis install
mkdir /usr/local/redis/etc
mkdir /usr/local/redis/var/
cp redis.conf /usr/local/redis/etc/6379.conf
        注意

        如果在執行 make 的時候遇到以下錯誤(比如作者的 32 位的 CentOS5.5 就碰到了):
zmalloc.o: In function `zmalloc_used_memory‘:
/home/defonds/redis/redis-2.8.10/src/zmalloc.c:223: undefined reference to `__sync_add_and_fetch_4‘
collect2: ld returned 1 exit status
make[1]: *** [redis-server] Error 1
make[1]: Leaving directory `/home/defonds/redis/redis-2.8.10/src‘
make: *** [all] Error 2
        在執行 make 時加上參數 CFLAGS="-march=i686" 就可以了:
make CFLAGS="-march=i686"
        四、 配置 Redis
        對預設 /usr/local/redis/etc/6379.conf 進行稍微調整。注意這個配置禁用了自動儲存功能,SAVE 和 BGSAVE 帶來的 I/0 和記憶體消耗是不容忽視的,我們讓應用或者使用者自行提交儲存。
daemonize yespidfile /usr/local/redis/var/6379.pidlogfile /usr/local/redis/var/6379.logdatabases 2dbfilename 6379.rdbdir /usr/local/redis/varappendfsync no

        五、 運行和檢測
        安裝、配置完以後,可以啟動 redis 了:
cd /usr/local/redis
nice -n -10 bin/redis-server etc/6379.conf

        這時,服務應該運行起來了。我們可以通過這兩種方式進行檢查:
ps aux | grep redis
bin/redis-cli INFO

        第二種方式的列印結果:
# bin/redis-cli INFO
# Server
redis_version:2.8.10
redis_git_sha1:00000000
redis_git_dirty:0
redis_build_id:d911badb15bd35b1
redis_mode:standalone
os:Linux 2.6.18-194.el5 i686
arch_bits:32
multiplexing_api:epoll
gcc_version:4.1.2
process_id:17537
run_id:0258835fab4aa7235c861a7ff812c197b3674003
tcp_port:6379
uptime_in_seconds:33
uptime_in_days:0
hz:10
lru_clock:9976904
config_file:/usr/local/redis/etc/6379.conf




# Clients
connected_clients:1
client_longest_output_list:0
client_biggest_input_buf:0
blocked_clients:0


# Memory
used_memory:629768
used_memory_human:615.01K
used_memory_rss:1617920
used_memory_peak:629768
used_memory_peak_human:615.01K
used_memory_lua:22528
mem_fragmentation_ratio:2.57
mem_allocator:jemalloc-3.2.0


# Persistence
loading:0
rdb_changes_since_last_save:0
rdb_bgsave_in_progress:0
rdb_last_save_time:1402485799
rdb_last_bgsave_status:ok
rdb_last_bgsave_time_sec:-1
rdb_current_bgsave_time_sec:-1
aof_enabled:0
aof_rewrite_in_progress:0
aof_rewrite_scheduled:0
aof_last_rewrite_time_sec:-1
aof_current_rewrite_time_sec:-1
aof_last_bgrewrite_status:ok
aof_last_write_status:ok


# Stats
total_connections_received:1
total_commands_processed:0
instantaneous_ops_per_sec:0
rejected_connections:0
sync_full:0
sync_partial_ok:0
sync_partial_err:0
expired_keys:0
evicted_keys:0
keyspace_hits:0
keyspace_misses:0
pubsub_channels:0
pubsub_patterns:0
latest_fork_usec:0


# Replication
role:master
connected_slaves:0
master_repl_offset:0
repl_backlog_active:0
repl_backlog_size:1048576
repl_backlog_first_byte_offset:0
repl_backlog_histlen:0


# CPU
used_cpu_sys:0.01
used_cpu_user:0.00
used_cpu_sys_children:0.00
used_cpu_user_children:0.00


# Keyspace
        最後對 redis 進行檢測。redis-benchmark 運行了一套 redis 命令,只需要 GET 和 SET 就足以測試主機硬體和編譯器了:
cd /usr/local/redis/bin
./redis-benchmark -t GET,SET

        列印結果:
# ./redis-benchmark -t GET,SET
====== SET ======
  10000 requests completed in 0.66 seconds
  50 parallel clients
  3 bytes payload
  keep alive: 1


30.00% <= 1 milliseconds
61.02% <= 2 milliseconds
92.35% <= 3 milliseconds
99.01% <= 4 milliseconds
99.80% <= 5 milliseconds
100.00% <= 8 milliseconds
15082.96 requests per second


====== GET ======
  10000 requests completed in 0.64 seconds
  50 parallel clients
  3 bytes payload
  keep alive: 1


31.43% <= 1 milliseconds
63.78% <= 2 milliseconds
94.87% <= 3 milliseconds
98.69% <= 4 milliseconds
99.33% <= 5 milliseconds
99.73% <= 7 milliseconds
99.80% <= 8 milliseconds
99.93% <= 9 milliseconds
100.00% <= 9 milliseconds
15552.10 requests per second
        當然,也可以添加 -q 對輸出結果進行精簡:
./redis-benchmark -q -t GET,SET
        列印結果:
# ./redis-benchmark -q -t GET,SET
SET: 14204.55 requests per second
GET: 14245.01 requests per second
        參考資料
  • http://redis.io/topics/quickstart
  • http://bommaritollc.com/2012/01/building-configuring-and-benchmarking-redis-from-github-source/
相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.