標籤:
1.Redis介紹
redis是一個key-value儲存系統。和Memcached類似,它支援儲存的value類型相對更多,包括string(字串)、list(鏈表)、set(集合)、zset(sorted set --有序集合)和hash(雜湊類型)。這些資料類型都支援push/pop、add/remove及取交集並集和差集及更豐富的操作,而且這些操作都是原子性的。在此基礎上,redis支援各種不同方式的排序。與memcached一樣,為了保證效率,資料都是緩衝在記憶體中。區別的是redis會周期性的把更新的資料寫入磁碟或者把修改操作寫入追加的記錄檔案,並且在此基礎上實現了master-slave(主從)同步。
Redis 是一個高效能的key-value資料庫。
2.Redis安裝
cd /usr/local/src
$ wget http://download.redis.io/releases/redis-2.8.21.tar.gz$ tar xzf redis-2.8.21.tar.gz$ cd redis-2.8.21$ make
wget http://download.redis.io/releases/redis-2.8.21.tar.gz
make PREFIX=/usr/local/redis install
mkdir /usr/local/redis/etc
cp /usr/local/src/redis-2.8.21/redis.conf /usr/local/redis/etc
wget http://www.apelearn.com/study_v2/.redis_conf -O /usr/local/redis/etc/redis.conf 2>/dev/null
update==>
啟動指令碼
wget http://www.apelearn.com/study_v2/.redis_init -O /etc/init.d/redis 2>/dev/null
useradd -s /sbin/nologin redis
mkdir /usr/local/redis/var
chmod 777 /usr/local/redis/var
chmod 755 /etc/init.d/redis
3.啟動redis
vi /etc/init.d/redis #編輯,添加以下代碼
#!/bin/sh
# chkconfig: 2345 90 10
# description: Redis is a persistent key-value database
# redis Startup script for redis processes
# processname: redis
redis_path="/usr/local/bin/redis-server"
redis_conf="/etc/redis.conf"
redis_pid="/var/run/redis.pid"
# Source function library.
. /etc/rc.d/init.d/functions
[ -x $redis_path ] || exit 0
RETVAL=0
prog="redis"
# Start daemons.
start() {
if [ -e $redis_pid -a ! -z $redis_pid ];then
echo $prog" already running...."
exit 1
fi
echo -n $"Starting $prog "
# Single instance for all caches
$redis_path $redis_conf
RETVAL=$?
[ $RETVAL -eq 0 ] && {
touch /var/lock/subsys/$prog
success $"$prog"
}
echo
return $RETVAL
}
# Stop daemons.
stop() {
echo -n $"Stopping $prog "
killproc -d 10 $redis_path
echo
[ $RETVAL = 0 ] && rm -f $redis_pid /var/lock/subsys/$prog
RETVAL=$?
return $RETVAL
}
# See how we were called.
case "$1" in
start)
start
;;
stop)
stop
;;
status)
status $prog
RETVAL=$?
;;
restart)
stop
start
;;
condrestart)
if test "x`pidof redis`" != x; then
stop
start
fi
;;
*)
echo $"Usage: $0 {start|stop|status|restart|condrestart}"
exit 1
esac
exit $RETVAL
:wq! #儲存退出
chmod 755 /etc/init.d/redis #添加指令碼執行許可權
chkconfig --add redis #添加開啟啟動
chkconfig --level 2345 redis on #設定啟動層級
chkconfig --list redis #查看啟動層級
service redis restart #重新啟動redis
系統營運 www.osyunwei.com 溫馨提醒:qihang01原創內容 著作權,轉載請註明出處及原文連結
4、設定redis設定檔參數
mkdir -p /usr/local/redis/var #建立redis資料庫存放目錄
vi /etc/redis.conf #編輯
daemonize yes #以後台daemon方式運行redis
pidfile "/var/run/redis.pid" #redis以後台運行,預設pid檔案路徑/var/run/redis.pid
port 6379 #預設連接埠
bind 127.0.0.1 #預設綁定本機所有ip地址,為了安全,可以只監聽內網ip
timeout 300 #用戶端逾時設定,單位為秒
loglevel verbose #設定記錄層級,支援四個層級:debug、notice、verbose、warning
logfile stdout #日誌記錄方式,預設為標準輸出,logs不寫檔案,輸出到空裝置/deb/null
logfile "/usr/local/redis/var/redis.log" #可以指定記錄檔路徑
databases 16 #開啟資料庫的數量
save 900 1
save 300 10
save 60 10000
建立本機資料庫快照,格式:save * *
900秒內,執行1次寫操作
300秒內,執行10次寫操作
60秒內,執行10000次寫操作
rdbcompression yes #啟用資料庫lzf壓縮,也可以設定為no
dbfilename dump.rdb #本地快照資料庫名稱
dir "/usr/local/redis/var/" #本地快照資料庫存放目錄
requirepass 123456 #設定redis資料庫連接密碼
maxclients 10000 #同一時間最大用戶端串連數,0為無限制
maxmemory 1024MB #設定redis最大使用記憶體,值要小於實體記憶體,必須設定
appendonly yes #開啟日誌記錄,相當於MySQL的binlog
appendfilename "appendonly.aof" #記錄檔名,注意:不是目錄路徑
appendfsync everysec #每秒執行同步,還有兩個參數always、no一般設定為everysec,相當於MySQL事物日誌的寫方式
:wq! #儲存退出
service redis restart #重啟
5、測試redis資料庫
redis-cli -a 123456 #串連redis資料庫,注意:-a後面跟redis資料庫密碼
set name osyunwei.com #寫資料
get name #讀取資料
exit #退出redis資料庫控制台
redis-benchmark -h 127.0.0.1 -p 6379 -c 1000 -n 100000 #1000個並發串連,100000個請求,測試127.0.0.1連接埠為6379的redis伺服器效能
Linux-NoSQL之Redis