redis安裝、配置、使用和redis php擴(kuò)展安裝教程
redis是一個(gè)內(nèi)存數(shù)據(jù)庫,比memcache支持更豐富的value類型,新浪微博就使用redis來做緩存。
redis的源碼安裝
wget http://download.redis.io/redis-stable.tar.gz
tar -zxvf redis-stable.tar.gz
cd redis-stable
make
make test
make install
1.make時(shí)可能會(huì)報(bào)如下錯(cuò)誤:
zmalloc.o: In function `zmalloc_used_memory':
/root/redis-stable/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 `/root/redis-stable/src'
make: *** [all] Error 2
解決辦法:
編輯src/.make-settings里的OPT,改為OPT=-O2 -march=i686。
2.make test報(bào)錯(cuò):
You need tcl 8.5 or newer in order to run the Redis test
make: *** [test] Error 1
解決辦法安裝tcl
wget http://downloads.sourceforge.net/tcl/tcl8.6.0-src.tar.gz
cd tcl8.6.0/
cd unix &&
./configure --prefix=/usr \
--mandir=/usr/share/man \
--without-tzdata \
$([ $(uname -m) = x86_64 ] && echo --enable-64bit) &&
make &&
sed -e "s@^\(TCL_SRC_DIR='\).*@\1/usr/include'@" \
-e "/TCL_B/s@='\(-L\)\?.*unix@='\1/usr/lib@" \
-i tclConfig.sh
make install &&
make install-private-headers &&
ln -v -sf tclsh8.6 /usr/bin/tclsh &&
chmod -v 755 /usr/lib/libtcl8.6.so
redis命令介紹
Redis 由四個(gè)可執(zhí)行文件:redis-benchmark、redis-cli、redis-server、redis-stat 這四個(gè)文件,加上一個(gè)redis.conf就構(gòu)成了整個(gè)redis的最終可用包。它們的作用如下:
redis-server:Redis服務(wù)器的daemon啟動(dòng)程序
redis-cli:Redis命令行操作工具。當(dāng)然,你也可以用telnet根據(jù)其純文本協(xié)議來操作
redis-benchmark:Redis性能測(cè)試工具,測(cè)試Redis在你的系統(tǒng)及你的配置下的讀寫性能
redis-stat:Redis狀態(tài)檢測(cè)工具,可以檢測(cè)Redis當(dāng)前狀態(tài)參數(shù)及延遲狀況
現(xiàn)在就可以啟動(dòng)redis了,redis只有一個(gè)啟動(dòng)參數(shù),就是他的配置文件路徑。
啟動(dòng)redis
復(fù)制源碼包里的redis.conf到/etc
# cp redis.conf /etc/redis.conf
編輯/etc/redis.conf ,修改daemaon no 為daemaon yes ,以守護(hù)進(jìn)程方式啟動(dòng)進(jìn)程。
# redis-server /etc/redis.conf
關(guān)閉redis
# redis-cli shutdown //關(guān)閉所有
關(guān)閉某個(gè)端口上的redis
# redis-cli -p 6397 shutdown //關(guān)閉6397端口的redis
說明:關(guān)閉以后緩存數(shù)據(jù)會(huì)自動(dòng)dump到硬盤上,硬盤地址見redis.conf中的dbfilename dump.rdb
redis配置
注意,默認(rèn)復(fù)制過去的redis.conf文件的daemonize參數(shù)為no,所以redis不會(huì)在后臺(tái)運(yùn)行,這時(shí)要測(cè)試,我們需要重新開一個(gè)終端。修改為yes則為后臺(tái)運(yùn)行redis。另外配置文件中規(guī)定了pid文件,log文件和數(shù)據(jù)文件的地址,如果有需要先修改,默認(rèn)log信息定向到stdout.
下面是redis.conf的主要配置參數(shù)的意義:
daemonize:是否以后臺(tái)daemon方式運(yùn)行
pidfile:pid文件位置
port:監(jiān)聽的端口號(hào)
timeout:請(qǐng)求超時(shí)時(shí)間
loglevel:log信息級(jí)別
logfile:log文件位置
databases:開啟數(shù)據(jù)庫的數(shù)量
save * *:保存快照的頻率,第一個(gè)*表示多長時(shí)間,第三個(gè)*表示執(zhí)行多少次寫操作。在一定時(shí)間內(nèi)執(zhí)行一定數(shù)量的寫操作時(shí),自動(dòng)保存快照??稍O(shè)置多個(gè)條件。
rdbcompression:是否使用壓縮
dbfilename:數(shù)據(jù)快照文件名(只是文件名,不包括目錄)
dir:數(shù)據(jù)快照的保存目錄(這個(gè)是目錄)
appendonly:是否開啟appendonlylog,開啟的話每次寫操作會(huì)記一條log,這會(huì)提高數(shù)據(jù)抗風(fēng)險(xiǎn)能力,但影響效率。
appendfsync:appendonlylog如何同步到磁盤(三個(gè)選項(xiàng),分別是每次寫都強(qiáng)制調(diào)用fsync、每秒啟用一次fsync、不調(diào)用fsync等待系統(tǒng)自己同步)
這時(shí)你可以打開一個(gè)終端進(jìn)行測(cè)試了,配置文件中默認(rèn)的監(jiān)聽端口是6379
redis開機(jī)自動(dòng)啟動(dòng)
用這個(gè)腳本管理之前,需要先配置下面的內(nèi)核參數(shù),否則Redis腳本在重啟或停止redis時(shí),將會(huì)報(bào)錯(cuò),并且不能自動(dòng)在停止服務(wù)前同步數(shù)據(jù)到磁盤上:
# vi /etc/sysctl.conf
vm.overcommit_memory = 1
然后應(yīng)用生效:
# sysctl –p
建立redis啟動(dòng)腳本:
# vim /etc/init.d/redis
#!/bin/bash
#
# Init file for redis
#
# chkconfig: - 80 12
# description: redis daemon
#
# processname: redis
# config: /etc/redis.conf
# pidfile: /var/run/redis.pid
source /etc/init.d/functions
#BIN="/usr/local/bin"
BIN="/usr/local/bin"
CONFIG="/etc/redis.conf"
PIDFILE="/var/run/redis.pid"
### Read configuration
[ -r "$SYSCONFIG" ] && source "$SYSCONFIG"
RETVAL=0
prog="redis-server"
desc="Redis Server"
start() {
if [ -e $PIDFILE ];then
echo "$desc already running...."
exit 1
fi
echo -n $"Starting $desc: "
daemon $BIN/$prog $CONFIG
RETVAL=$?
echo
[ $RETVAL -eq 0 ] && touch /var/lock/subsys/$prog
return $RETVAL
}
stop() {
echo -n $"Stop $desc: "
killproc $prog
RETVAL=$?
echo
[ $RETVAL -eq 0 ] && rm -f /var/lock/subsys/$prog $PIDFILE
return $RETVAL
}
restart() {
stop
start
}
case "$1" in
start)
start
stop)
stop
restart)
restart
condrestart)
[ -e /var/lock/subsys/$prog ] && restart
RETVAL=$?
status)
status $prog
RETVAL=$?
*)
echo $"Usage: $0 {start|stop|restart|condrestart|status}"
RETVAL=1
esac
exit $RETVAL
然后增加服務(wù)并開機(jī)自啟動(dòng):
# chmod 755 /etc/init.d/redis
# chkconfig --add redis
# chkconfig --level 345 redis on
# chkconfig --list redis
redis php擴(kuò)展安裝
wget https://github.com/nicolasff/phpredis/zipball/master -O php-redis.zip
unzip php-redis.zip
cd nicolasff-phpredis-2d0f29b/
/usr/local/php/bin/phpize
./configure --with-php-config=/usr/local/php/bin/php-config
make && make install
完成后redis.so被安裝到
vi /usr/local/php/lib/php.ini
添加
重啟php-fpm即可。
configure時(shí)可能會(huì)遇到,添加--with-php-config參數(shù)可以解決。
configure: error: Cannot find php-config. Please use --with-php-config=PATH
./configure --with-php-config=/usr/local/php/bin/php-config
- 30個(gè)php操作redis常用方法代碼例子
- redis 隊(duì)列操作的例子(php)
- php操作redis中的hash和zset類型數(shù)據(jù)的方法和代碼例子
- php結(jié)合redis實(shí)現(xiàn)高并發(fā)下的搶購、秒殺功能的實(shí)例
- php Session存儲(chǔ)到Redis的方法
- PHP操作Redis常用技巧總結(jié)
- php操作redis緩存方法分享
- 在PHP中使用redis
- PHP實(shí)現(xiàn)操作redis的封裝類完整實(shí)例
- Php-Redis安裝測(cè)試筆記
- Linux下php安裝Redis擴(kuò)展的方法
- php+redis實(shí)現(xiàn)商城秒殺功能
- PHP實(shí)現(xiàn)Redis單據(jù)鎖以及防止并發(fā)重復(fù)寫入
- ThinkPHP自定義Redis處理SESSION的實(shí)現(xiàn)方法
- 詳解thinkphp+redis+隊(duì)列的實(shí)現(xiàn)代碼
- 項(xiàng)目中應(yīng)用Redis+Php的場景
- PHP使用Redis長連接的方法詳解
- php操作redis命令及代碼實(shí)例大全
相關(guān)文章
sql2005可實(shí)時(shí)監(jiān)測(cè)數(shù)據(jù)庫版本控制SQL的觸發(fā)器
用于sql2005實(shí)時(shí)監(jiān)測(cè)數(shù)據(jù)庫版本控制SQL的觸發(fā)器2008-10-10數(shù)據(jù)庫刪除完全重復(fù)和部分關(guān)鍵字段重復(fù)的記錄
重復(fù)記錄分為兩種,第一種是完全重復(fù)的記錄,也就是所有字段均重復(fù)的記錄,第二種是部分關(guān)鍵字段重復(fù)的記錄,例如Name字段重復(fù),而其它字段不一定重復(fù)或都重復(fù)。2008-05-05redis密碼設(shè)置、訪問權(quán)限控制等安全設(shè)置
這篇文章主要介紹了redis密碼設(shè)置、訪問權(quán)限控制等安全設(shè)置,需要的朋友可以參考下2014-05-05復(fù)制數(shù)據(jù)庫表中兩個(gè)字段數(shù)據(jù)的SQL語句
今天為表新添加一個(gè)字段,但又想與表中的另一個(gè)字段值相同,由于數(shù)據(jù)過多想通過sql語句實(shí)現(xiàn),經(jīng)測(cè)試下面的這句話確實(shí)很好用2013-07-07Dbeaver做數(shù)據(jù)遷移的詳細(xì)過程記錄
DBeaver是一款跨平臺(tái)的通用數(shù)據(jù)庫開源管理工具,支持 MySQL,PostgreSQL,Oracle,DB2,MSSQL,Sybase,Mimer,HSQLDB,Derby以及其他兼容JDBC的數(shù)據(jù)庫,下面這篇文章主要給大家介紹了關(guān)于Dbeaver做數(shù)據(jù)遷移的詳細(xì)過程,需要的朋友可以參考下2023-05-05sqlserver中drop、truncate和delete語句的用法
這篇文章主要介紹了sqlserver中drop、truncate和delete語句的用法,本文圖文并茂,內(nèi)容清晰,需要的朋友可以參考下2014-09-09數(shù)據(jù)庫之Hive概論和架構(gòu)和基本操作
Hive是一個(gè)構(gòu)建在Hadoop上的數(shù)據(jù)倉庫框架,最初,Hive是由Facebook開發(fā),后臺(tái)移交由Apache軟件基金會(huì)開發(fā),并做為一個(gè)Apache開源項(xiàng)目,感興趣的同學(xué)可以參考閱讀2023-04-04