Linux-NoSQL之Redis

來源:互聯網
上載者:User

標籤:

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

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在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.