關於Redis的簡單介紹:
官網:www.redis.io
Redis 的特點:
1.支持數據的持久化,持久化方案:aof,RDB兩種持久化方案,也就是支持將內存中的數據保存到磁盤中,也就是說,redis服務重啟,數據仍舊存在
2.Redis不僅僅支持簡單的key-value 類型的數據,同時提供了list,set,zset,hash等數據結構的存儲
3.Redis支持數據的備份,也支持高可用,Redis 2.8版本以后才支持Redis主從復制。
Redis與傳統的Mysql關系型數據庫的比較:
1.性能極高,Redis的能讀的110000次/s ,也就是說支持高並發,比磁盤的速度要快很多,寫的速度是81000次/s
2.豐富的數據類型,Redis支持很多的數據類型,比如:string,List,hash,sets以及zset五種數據類型
3.原子性:自行理解吧
4.支持過期,以及消息的訂閱和發布,
下載redis :
官網下載最新穩定的redis版本:
linux 進入/usr/local/src目錄,默認的源碼包都放這里,這是一種不成文的規定:
wget http://download.redis.io/releases/redis-3.2.8.tar.gz
注意:沒有安裝wget命令,直接執行yum install -y wget 安裝即可
tar -zxvf redis-3.2.8.tar.gz
cd redis-3.2.8
make
make PREFIX=/usr/local/redis install 【注意后面的install不要忘記加上】
編輯配置文件
daemonize yes :默認為on ,修改成yes ,也就是說會在后端運行
bind 127.0.0.1 192.168.184.3 【后面這個ip地址是為后面的主從同步實現的,建議:如果不是實現主從,那么后面的那個ip地址可以省略,那個ip地址是自己本機的ip地址】
下面是對redis.conf文件對於各種參數配置的簡單介紹,不是很詳細,如果想要詳細了解,自行谷歌
#daemonize:是否以后台daemon方式運行 #pidfile:pid文件位置 #port:監聽的端口號 #timeout:請求超時時間 #loglevel:log信息級別 #logfile:log文件位置 #databases:開啟數據庫的數量 #save * *:保存快照的頻率,第一個*表示多長時間,第三個*表示執行多少次寫操作。在一定時間內執行一定數量的寫操作時,自動保存快照。可設置多個條件。 #rdbcompression:是否使用壓縮 #dbfilename:數據快照文件名(只是文件名,不包括目錄) #dir:數據快照的保存目錄(這個是目錄) #appendonly:是否開啟appendonlylog,開啟的話每次寫操作會記一條log,這會提高數據抗風險能力,但影響效率。 #appendfsync:appendonlylog如何同步到磁盤(三個選項,分別是每次寫都強制調用fsync、每秒啟用一次fsync、不調用fsync等待系統自己同步)
關於redis的啟動腳本,這個是在網上找到,覺得路徑不是符合自己的要求,我自行修改了一下:注意路徑

#!/bin/sh # # redis init file for starting up the redis daemon # # chkconfig: - 20 80 # description: Starts and stops the redis daemon. # Source function library. . /etc/rc.d/init.d/functions name="redis-server" basedir="/usr/local/redis" exec="$basedir/bin/$name" pidfile="/var/run/redis.pid" REDIS_CONFIG="/etc/redis.conf" [ -e /etc/sysconfig/redis ] && . /etc/sysconfig/redis lockfile=/var/lock/subsys/redis start() { [ -f $REDIS_CONFIG ] || exit 6 [ -x $exec ] || exit 5 echo -n $"Starting $name: " daemon --user ${REDIS_USER-redis} "$exec $REDIS_CONFIG" retval=$? echo [ $retval -eq 0 ] && touch $lockfile return $retval } stop() { echo -n $"Stopping $name: " killproc -p $pidfile $name retval=$? echo [ $retval -eq 0 ] && rm -f $lockfile return $retval } restart() { stop start } reload() { false } rh_status() { status -p $pidfile $name } rh_status_q() { rh_status >/dev/null 2>&1 } case "$1" in start) rh_status_q && exit 0 $1 ;; stop) rh_status_q || exit 0 $1 ;; restart) $1 ;; reload) rh_status_q || exit 7 $1 ;; force-reload) force_reload ;; status) rh_status ;; condrestart|try-restart) rh_status_q || exit 0 restart ;; *) echo $"Usage: $0 {start|stop|status|restart|condrestart|try-restart}" exit 2 esac exit $?
這個啟動腳本不是很好,有shell編程基礎的,可以自行修改
添加一個redis用戶:
useradd -s /sbin/nologin redis
創建相關的logfile,pidfile,dir目錄【dir是數據dbdump.db的文件的放置位置,注意權限】
chmod 777 /var/redis
chmod 755 /etc/init.d/redis
chkconfig --add redis
chkconfig redis on
啟動redis :
service redis start
查看服務狀態以及監聽的端口:
ps aux |grep -i redis
至此:redis 3.2.8的安裝完成
測試:
/usr/local/redis/bin/redis-cli
進入后:
set key d.c
get key
"d.c"
至此,redis搭建成功