轉自:http://www.jianshu.com/p/6b5eca8d908b
-安裝
下載安裝包 redis-3.0.7.tar.gz
解壓:tar -zvxf redis-3.0.7.tar.gz 將解壓后的文件夾放到 /usr/local目錄下
編譯測試:接下來在終端中切換到/usr/local/redis目錄下,輸入:sudo make test


編譯安裝:在終端中輸入命令:sudo make install


啟動Redis,輸入命令redis-server


看到這個界面表示我們已經成功的安裝Redis。
二配置
1、在 /usr/local/redis目錄下建立bin,etc,db三個目錄
2、把/usr/local/redis/src目錄下的mkreleasehdr.sh,redis-benchmark, redis-check-dump, redis-cli, redis-server拷貝到bin目錄
3、在etc下,參考原/usr/local/redis目錄下的redis.conf,新建一個redis.conf
修改redis.conf,具體如下:
#修改為守護模式
daemonize yes
#設置進程鎖文件
pidfile /usr/local/redis/redis.pid
#端口
port 6379
#客戶端超時時間
timeout 300
#日志級別
loglevel debug
#日志文件位置
logfile /usr/local/redis/log-redis.log
#設置數據庫的數量,默認數據庫為16,可以使用SELECT 命令在連接上指定數據庫id
databases 16
##指定在多長時間內,有多少次更新操作,就將數據同步到數據文件,可以多個條件配合
#save
#Redis默認配置文件中提供了三個條件:
save 900 1
save 300 10
save 60 10000
#指定存儲至本地數據庫時是否壓縮數據,默認為yes,Redis采用LZF壓縮,如果為了節省CPU時間,
#可以關閉該#選項,但會導致數據庫文件變的巨大
rdbcompression yes
#指定本地數據庫文件名
dbfilename dump.rdb
#指定本地數據庫路徑
dir /usr/local/redis/db/
#指定是否在每次更新操作后進行日志記錄,Redis在默認情況下是異步的把數據寫入磁盤,如果不開啟,可能
#會在斷電時導致一段時間內的數據丟失。因為 redis本身同步數據文件是按上面save條件來同步的,所以有
#的數據會在一段時間內只存在於內存中
appendonly no
#指定更新日志條件,共有3個可選值:
#no:表示等操作系統進行數據緩存同步到磁盤(快)
#always:表示每次更新操作后手動調用fsync()將數據寫到磁盤(慢,安全)
#everysec:表示每秒同步一次(折衷,默認值)
appendfsync everysec
4、保存后,啟動redis:./bin/redis-server etc/redis.conf
5、查看日志文件:tail -f log-redis.log

到這里,我們已經完成redis安裝和配置。
三其他
1、檢查是否啟動:redis-cli ping
2、redis-cli 跟上命令會將參數發送到本地redis 6379 的端口,下面來看看基本操作:

3、關閉命令:redis-cli shutdown
四.服務器配置
上面只是基本的安裝,如果要用到生產環境,得配置一些文件
1.首先把redis-cli 移動到/usr/local/bin 目錄,方便執行,和JAVA_HOME 類似
默認install 的時候已經有了
2.創建你存放配置文件和數據文件的目錄
sudomkdir /etc/redissudo mkdir /var/redis
3.復制初始化腳本到/etc/init.d 目錄,建議默認只有這個端口,作開機啟動
$ sudocp utils/redis_init_script /etc/init.d/redis_6379
4.進入腳本,確保你的REDISPORT 是你正在使用的
sudovi /etc/init.d/redis_6379
5.復制redis.conf ,和腳本保持一致
sudocp redis.conf /etc/redis/6379.conf
6.創建一個存放工作數據的目錄
sudomkdir /var/redis/6379
同時可以對redis.conf配置其他屬性
# 來源:http://www.cnblogs.com/shanyou/archive/2012/01/28/2330451.htmldaemonize:是否以后台daemon方式運行pidfile:pid文件位置port:監聽的端口號timeout:請求超時時間loglevel:log信息級別logfile:log文件位置databases:開啟數據庫的數量save **:保存快照的頻率,第一個*表示多長時間,第三個*表示執行多少次寫操作。在一定時間內執行一定數量的寫操作時,自動保存快照。可設置多個條件。rdbcompression:是否使用壓縮dbfilename:數據快照文件名(只是文件名,不包括目錄)dir:數據快照的保存目錄(這個是目錄)appendonly:是否開啟appendonlylog,開啟的話每次寫操作會記一條log,這會提高數據抗風險能力,但影響效率。appendfsync:appendonlylog如何同步到磁盤(三個選項,分別是每次寫都強制調用fsync、每秒啟用一次fsync、不調用fsync等待系統自己同步)
7.最后將腳本設置默認啟動
sudoupdate-rc.d redis_6379 defaults
8.現在可以執行腳本了
/etc/init.d/redis_6379start
五.MAC 版本差異
一個不幸的事實是:mac 上是沒有init.d 目錄的,mac啟動腳本是 以.plist 結尾了,
好吧,我在 ~/Library/LaunchAgents 目錄下自己建立一個 redis.plist
參考:http://www.js2node.com/redis-io/install-redis-io-2-4-17-on-mac-osx-as-service
$ sudovi redis.plist
然后輸入以下內容
Labelio.redis.redis-serverProgramArguments/usr/local/bin/redis-server/usr/local/etc/redis.confRunAtLoad
執行命令
$ sudolaunchctlload/Library/LaunchDaemons/io.redis.redis-server.plist
打開關閉:
$ sudolaunchctlstartio.redis.redis-server$ sudo launchctl stop io.redis.redis-server
六.brew 進行安裝
下面我用brew來操作,關於brew 的安裝我看的:http://my.oschina.net/liygheart/blog/284668
安裝好了,然后 參考:https://gist.github.com/tonypujals/9631143
$brew info redis
會有提示,然后輸入
$ln -nfs /usr/local/opt/redis/*.plist ~/Library/LaunchAgents
和
$load ~/Library/LaunchAgents/homebrew.mxcl.redis.plist
小結
1.基本都是是文檔上來的基礎,主要因為系統問題,導致安裝遇到點小麻煩記錄一下,也分享一下
2.如果有錯,請指點 非常感謝。
關於redis 選型的文章推薦:
http://www.infoq.com/cn/articles/tq-why-choose-redis
優化的推薦:
http://www.infoq.com/cn/articles/tq-redis-memory-usage-optimization-storage
更多命令操作參考:
http://redis.io/commands
基本學習
http://try.redis.io/
順便給個安裝其他東西的地址
https://github.com/davetheninja/dots/blob/master/bootstrap.sh