轉(zhuǎn)儲session的原因
藍山ssl適用于網(wǎng)站、小程序/APP、API接口等需要進行數(shù)據(jù)傳輸應(yīng)用場景,ssl證書未來市場廣闊!成為成都創(chuàng)新互聯(lián)的ssl證書銷售渠道,可以享受市場價格4-6折優(yōu)惠!如果有意向歡迎電話聯(lián)系或者加微信:028-86922220(備注:SSL證書合作)期待與您的合作!
網(wǎng)上有許多session需要用數(shù)據(jù)庫儲存的原因,對我來說原因很簡單,僅僅只是node的生產(chǎn)環(huán)境不允許將session存到服務(wù)器的內(nèi)存中。會報一個內(nèi)存溢出的風險警告。所以我決定將session轉(zhuǎn)儲到數(shù)據(jù)庫中。而用于存儲session的方案有許多,這里由于本人比較菜,所以選擇了主流的redis來保存我的session狀態(tài)
安裝redis
首先既然要使用redis,那么第一步當然是將redis安裝到服務(wù)器上,服務(wù)器一般都是linux的操作系統(tǒng)。
所以下面是linux的安裝步驟
1.進入官網(wǎng)下載redis
2.將下載好的文件通過xftp上傳到服務(wù)器并進行安裝
這里我將安裝包放到了/usr/local/src 的目錄下
然后通過xshell來對其進行解壓
cd /usr/local/src //進入存放redis的文件 tar -xzvf redis-4.0.11.tar.gz //解壓文件
解壓完成后進入解壓后的文件夾對其進行編譯
編譯完成后就可以對其進行配置
打開配置文件
vim redis.conf
為了讓其在后臺運行
需將其修改為守護進程模式
然后給redis設(shè)置密碼
修改完成按esc退出
:wq保存
然后將redis設(shè)置為開機啟動
首先新建redis的開機啟動腳本
vim /etc/init.d/redis
文件內(nèi)容如下
#!/bin/sh # chkconfig: 2345 80 90 # description: Start and Stop redis #PATH=/usr/local/bin:/sbin:/usr/bin:/bin REDISPORT=6379 EXEC=/usr/local/src/redis-4.0.11/src/redis-server REDIS_CLI=/usr/local/src/redis-4.0.11/src/redis-cli PIDFILE=/var/run/redis_6379.pid CONF="/usr/local/src/redis-4.0.11/redis.conf" AUTH="lhy" case "$1" in start) if [ -f $PIDFILE ] then echo "$PIDFILE exists, process is already running or crashed" else echo "Starting Redis server..." $EXEC $CONF fi if [ "$?"="0" ] then echo "Redis is running..." fi ;; stop) if [ ! -f $PIDFILE ] then echo "$PIDFILE does not exist, process is not running" else PID=$(cat $PIDFILE) echo "Stopping ..." $REDIS_CLI -p $REDISPORT SHUTDOWN while [ -x ${PIDFILE} ] do echo "Waiting for Redis to shutdown ..." sleep 1 done echo "Redis stopped" fi ;; restart|force-reload) ${0} stop ${0} start ;; *) echo "Usage: /etc/init.d/redis {start|stop|restart|force-reload}" >&2 exit 1 esac
這里的pidfile 在redis.conf配置文件中有
如下圖
編輯完成后保存退出
然后添加開機啟動服務(wù)
vim /etc/rc.local
進入文件后在末尾添加
service redis start
保存退出
然后設(shè)置權(quán)限
chmod 755 /etc/init.d/redis
設(shè)置完成后注冊系統(tǒng)服務(wù)
chkconfig --add redis
然后測試一下redis能否啟動
進入redis文件夾后
輸入
service redis start
啟動成功后我們看一下redis是否配置成功
ps -ef|grep redis
沒有問題就可以創(chuàng)建軟連接了
ln -s /usr/local/src/redis-4.0.11/src/redis-cli /usr/bin/redis
測試redis
軟連接創(chuàng)建完直接在命令行輸入
redis即可
這里要輸入你在配置文件中設(shè)置的密碼
到這里redis就安裝完成了
配置防火墻
在上面的配置完成后我們還不能正常使用
還需要對防火墻進行配置
我們先查看一下端口的情況
netstat -lntp
我們可以看到6379已經(jīng)被正確監(jiān)聽了
在這里由于我并不會對redis進行什么操作
也不關(guān)心它保存的數(shù)據(jù),所以我不需要從外網(wǎng)對redis進行訪問,因為它只是暫存一下項目的session
所以我這里就不開放防火墻上的端口了
如果需要開放的小伙伴
使用以下命令
firewall-cmd --zone= public --add-port=這里是你想開啟的端口 /tcp --permanent (--permanent永久生效,沒有此參數(shù)重啟后失效)
firewall-cmd --reload 重啟防火墻
在node中使用redis
redis已經(jīng)安裝完成了
接下來就是在node中使用redis來暫存session了
首先在package.json中安裝
redis模塊,connect-redis模塊
"redis": "^2.8.0"
"connect-redis":"^3.3.3"
重新安裝一下依賴
cnpm i
這里由于npm比較慢所以我用的cnpm
然后就可以在代碼中使用了
先看一下原本沒用redis的代碼
我用express-session來保存用戶狀態(tài)
有這一行代碼
使用req.session就可以保存用戶的一些數(shù)據(jù)
接下來把剛才的兩行代碼
session = require('express-session'); app.use(session({secret:'lhy2018'}));
修改為如下代碼
session = require('express-session'), redis = require('redis'), client = redis.createClient({password:"lhy"}),//這里填寫redis的密碼 RedisStore = require('connect-redis')(session); client.on("error", function (err) { console.log("Error " + err);//用于提示錯誤信息 }); let options = { client:client, port:6379,//端口號 host:"127.0.0.1"http://主機 }; app.use(session( { store: new RedisStore(options), secret:"lhy2018"http://以此字符串加密 }));
這樣使用req.session就可以將你想保存的會話數(shù)據(jù)存到redis中了
就可以避免內(nèi)存溢出的風險了
然后用pm2重啟服務(wù)
總結(jié)
以上所述是小編給大家介紹的node.js使用redis儲存session的方法,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復(fù)大家的。在此也非常感謝大家對創(chuàng)新互聯(lián)網(wǎng)站的支持!