PHPでのredisの使用–ストレージセッション
ストレージ構造とストレージフォーマット
redisは、フルデータとインクリメンタルリクエストの2つのファイルフォーマットを使用します.全量のデータフォーマットはメモリの中のデータをディスクに書き込むので、次回ファイルを読み込んでロードするのに便利です;インクリメンタル要求ファイルはメモリ中のデータを操作要求にシーケンス化し、ファイルを読み取りreplayしてデータを得るためのものであり、シーケンス化の操作にはSET、RPUSH、SADD、ZADDが含まれる.
redisのストレージはメモリストレージ、ディスクストレージ、logファイルの3つの部分に分けられ、プロファイルには3つのパラメータが構成されています.
save seconds updates,save構成は,更新操作がどれくらいの時間でデータファイルに同期されるかを示す.これは、デフォルトのプロファイルの設定など、複数の条件を組み合わせて3つの条件を設定できます.
appendonly yes/no、appendonly構成は、更新操作のたびにログ記録を行うかどうかを示し、オンにしないと、電源が切れたときに一定時間のデータが失われる可能性があります.redis自体の同期データファイルは上記のsave条件で同期されるため、一定期間メモリにしか存在しないデータもあります.
appendfsync no/always/everysec,appendfsync構成,noはオペレーティングシステムがデータキャッシュをディスクに同期することを示し,alwaysは更新操作のたびにfsync()を手動で呼び出してデータをディスクに書き込み,everysecは毎秒同期することを示す.
Redisインストール-サービス側
ダウンロード、インストール
プロファイルの変更
redis.confの主な構成パラメータの意義
redisの起動
redis起動スクリプトを作成することもできます.
ユーザーの作成
インストールredis.so拡張モジュール-クライアント
テスト
redisは、フルデータとインクリメンタルリクエストの2つのファイルフォーマットを使用します.全量のデータフォーマットはメモリの中のデータをディスクに書き込むので、次回ファイルを読み込んでロードするのに便利です;インクリメンタル要求ファイルはメモリ中のデータを操作要求にシーケンス化し、ファイルを読み取りreplayしてデータを得るためのものであり、シーケンス化の操作にはSET、RPUSH、SADD、ZADDが含まれる.
redisのストレージはメモリストレージ、ディスクストレージ、logファイルの3つの部分に分けられ、プロファイルには3つのパラメータが構成されています.
save seconds updates,save構成は,更新操作がどれくらいの時間でデータファイルに同期されるかを示す.これは、デフォルトのプロファイルの設定など、複数の条件を組み合わせて3つの条件を設定できます.
appendonly yes/no、appendonly構成は、更新操作のたびにログ記録を行うかどうかを示し、オンにしないと、電源が切れたときに一定時間のデータが失われる可能性があります.redis自体の同期データファイルは上記のsave条件で同期されるため、一定期間メモリにしか存在しないデータもあります.
appendfsync no/always/everysec,appendfsync構成,noはオペレーティングシステムがデータキャッシュをディスクに同期することを示し,alwaysは更新操作のたびにfsync()を手動で呼び出してデータをディスクに書き込み,everysecは毎秒同期することを示す.
Redisインストール-サービス側
ダウンロード、インストール
cd /usr/local/src/
wget http://download.redis.io/redis-4.0.1.tar.gz
tar -zxvf redis-4.0.1.tar.gz
cd redis-4.0.1
make && make install
cp redis.conf /etc/redis.conf
プロファイルの変更
vim /etc/redis.conf \\
daemonize yes
logfile "/var/log/redis.log"
dir /data/redis_data/
appendonly yes
mkdir /data/redis_data
redis.conf,
mv /etc/redis.conf /etc/redis.conf.bak
vim /etc/redis.conf
daemonize yes
pidfile "/var/log/redis.pid"
port 6379
timeout 300
loglevel debug
logfile "/var/log/redis.log"
databases 16
save 900 1
save 300 10
save 60 10000
rdbcompression yes
dbfilename dump.rdb
dir /data/redis_data
appendonly no
appendfsync always
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の起動
redis-server /etc/redis.conf
less /var/log/redis.log // https://blog.51cto.com/chenshengsheng/2115482
killall redis-server
redis-server /etc/redis.conf
redis起動スクリプトを作成することもできます.
vi /etc/init.d/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="$basedir/var/redis.pid"
REDIS_CONFIG="$basedir/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 $?
############
ユーザーの作成
redis , redis
useradd -s /sbin/nologin redis
chmod 755 /etc/init.d/redis
/etc/init.d/redis start
インストールredis.so拡張モジュール-クライアント
cd /usr/local/src
wget https://coding.net/u/aminglinux/p/yuanke_centos7/git/raw/master/21NOSQL/phpredis.zip
unzip phpredis.zip
cd phpredis-develop
/usr/local/php/bin/phpize
./configure --with-php-config=/usr/local/php/bin/php-config
make &make install
vim /usr/local/php.ini// extension=redis.so
/usr/local/php/bin/php -m|grep redis// redis
php-fpm
vim /usr/local/php-fpm/etc/php.ini//
session.save_handler = "redis"
session.save_path = "tcp://127.0.0.1:6379"
apache :
php_value session.save_handler " redis"
php_value session.save_path " tcp://127.0.0.1:6379"
php-fpm pool :
php_value[session.save_handler] = redis
php_value[session.save_path] = " tcp://127.0.0.1:6379 "
テスト
:
wgt http://study.lishiming.net/.mem_se.txt
mv .mem_se.txt session.php session
session.php https://coding.net/u/aminglinux/p/yuanke_centos7/git/blob/master/21NOSQL/session.php
# curl localhost/session.php
[root@localhost phpredis-develop]# curl localhost/session.php
1526157029
1526157029
edi5pqn9jtu1ndulfe8the8pi0
[root@localhost phpredis-develop]# curl localhost/session.php
1526157032
1526157032
pbg5h030i98qk18ovfjj5ggg51
:
# redis-cli // redis-cli, key
127.0.0.1:6379> keys *
1) "PHPREDIS_SESSION:edi5pqn9jtu1ndulfe8the8pi0"
2) "PHPREDIS_SESSION:pbg5h030i98qk18ovfjj5ggg51"
:
php redis cluster, predis
phpredis,predis https://github.com/nrk/predis