1. 程式人生 > >redis慢查詢日誌、php安裝redis擴充套件、redis儲存session、redis主從配置

redis慢查詢日誌、php安裝redis擴充套件、redis儲存session、redis主從配置

一:redis慢查詢日誌

編輯配置檔案/etc/redis.conf
針對慢查詢日誌,可以設定兩個引數,一個是執行時長,單位是微秒,另一個是慢查詢日誌的長度。當一個新的命令被寫入日誌時,最老的一條會從命令日誌佇列中被移除。
slowlog-log-slower-than 1000 //單位ms,表示慢於1000ms則記錄日誌
slowlog-max-len 128 //定義日誌長度,表示最多存128條
slowlog get //列出所有的慢查詢日誌
slowlog get 2 //只列出2條
slowlog len //檢視慢查詢日誌條數

二:php安裝redis擴充套件

安裝擴充套件模組
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-fpm/bin/phpize
./configure --with-php-config=/usr/local/php-fpm/bin/php-config
make
make install
vim /usr/local/php.ini//增加extension=redis.so
/usr/local/php-fpm/bin/php -m|grep redis//看是否有redis模組
重啟php-fpm服務

三:redis儲存session

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 /usr/local/apache2/htdocs/session.php
其中session.php內容可以參考如下:

 <?php
session_start();
if (!isset($_SESSION['TEST'])) {
$_SESSION['TEST'] = time();
}
$_SESSION['TEST3'] = time();
print $_SESSION['TEST'];
print "<br><br>";
print $_SESSION['TEST3'];
print "<br><br>";
print session_id();
?>

curl localhost/session.php //結果類似於1443702394<br><br>1443702394<br><br>i44nunao0g3o7vf2su0hnc5440
命令列連線redis,也可以檢視到該key以及對應的值
如果想用php連線redis cluster,需要使用predis擴充套件
安裝方法類似phpredis,predis擴充套件地址https://github.com/nrk/predis

四:redis主從配置

為了節省資源,我們可以在一臺機器上啟動兩個redis服務
cp /etc/redis.conf /etc/redis2.conf
vim /etc/redis2.conf //需要修改port,dir,pidfile,logfile
還要增加一行
slaveof 127.0.0.1 6379
如果主上設定了密碼,還需要增加
masterauth aminglinux>com //設定主的密碼
啟動之前不要忘記建立新的dir目錄
redis-server /etc/redis2.conf
測試:在主上建立新的key,在從上檢視
注意:redis主從和mysql主從不一樣,redis主從不用事先同步資料,它會自動同步過去