redis使用了兩種文件格式:全量數據和增量請求。全量數據格式是把內存中的數據寫入磁盤,便於下次讀取文件進行加載;增量請求文件則是把內存中的數據序列化爲操做請求,用於讀取文件進行replay獲得數據,序列化的操做包括SET、RPUSH、SADD、ZADD。php
redis的存儲分爲內存存儲、磁盤存儲和log文件三部分,配置文件中有三個參數對其進行配置。linux
save seconds updates,save配置,指出在多長時間內,有多少次更新操做,就將數據同步到數據文件。這個能夠多個條件配合,好比默認配置文件中的設置,就設置了三個條件。git
appendonly yes/no ,appendonly配置,指出是否在每次更新操做後進行日誌記錄,若是不開啓,可能會在斷電時致使一段時間內的數據丟失。由於redis自己同步數據文件是按上面的save條件來同步的,因此有的數據會在一段時間內只存在於內存中。github
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
daemonize:是否之後臺daemon方式運行 pidfile:pid文件位置 port:監聽的端口號 timeout:請求超時時間 loglevel:log信息級別 logfile:log文件位置 databases:開啓數據庫的數量 save * *:保存快照的頻率,第一個*表示多長時間,第三個*表示執行多少次寫操做。在必定時間內執行必定數量的寫操做時,自動保存快照。可設置多個條件。 rdbcompression:是否使用壓縮 dbfilename:數據快照文件名(只是文件名,不包括目錄) dir:數據快照的保存目錄(這個是目錄) appendonly:是否開啓appendonlylog,開啓的話每次寫操做會記一條log,這會提升數據抗風險能力,但影響效率。 appendfsync:appendonlylog如何同步到磁盤(三個選項,分別是每次寫都強制調用fsync、每秒啓用一次fsync、不調用fsync等待系統本身同步)
redis-server /etc/redis.conf less /var/log/redis.log //查看日誌若是有警告就按照它解決https://blog.51cto.com/chenshengsheng/2115482 killall redis-server redis-server /etc/redis.conf
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
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<br><br>1526157029<br><br>edi5pqn9jtu1ndulfe8the8pi0 [root@localhost phpredis-develop]# curl localhost/session.php 1526157032<br><br>1526157032<br><br>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