387
iPhone_iPad_Mac_手機_平板_蘋果apple
2.1 保存網站用戶登錄session__2. OCS最佳實踐_開放緩存OCS 體驗_體驗館-阿裏雲
使用OCS保存網站用戶登錄session返回體驗館
場景介紹
用戶在利用PHP搭建網站時,會把一些信息存放在$_SESSION
全局變量裏,可以很方便的存取。在PHP的ini配置文件裏麵提供了[Session]
相關配置,可以支持將信息存到文件或memcached服務器裏麵。由配置項session.save_handler = memcached
決定。大多數場景,該session數據並不需要持久化,且為了提升網站性能,會選擇將session信息緩存到memcached裏麵。
問題
現在問題來了,已知阿裏雲OCS是實現了標準memcached協議的緩存,用戶一方麵為了減少服務器內存占用,一方麵減少對memcached的維護,希望將session的存儲從自建的memcached遷移到OCS上麵,且不希望改寫代碼。切換過程中遇到了問題,因此有了這篇文章,希望能幫到大家。
首先弄清OCS和自建memcached的區別,他們都實現了標準memcached協議。但OCS是分布式集群統一對外提供服務,實現了負載均衡且無單點故障,用戶可自由動態彈性調整配置且無需重啟服務。既然是對外提供服務,就有相應的安全機製,如白名單、流控、賬號密碼鑒權。這裏對比自建memcached,最重要的區別就是“賬號密碼鑒權”,因為大多數用戶自建memcached是不需要設置賬號密碼的,跟OCS比就少了SASL鑒權流程。那麼用戶將session的存儲從自建的memcached遷移到OCS上麵,就需要在php.ini
中配置賬號密碼。
解決方案
1、在老版本的php memcached擴展中無法支持,需要升級php memcached擴展至2.2.0版本。重新按照阿裏雲OCS官網的PHP教程示例編譯擴展。
步驟如下:
wget https://pecl.php.net/get/memcached-2.2.0.tgz
tar zxvf memcached-2.2.0.tgz
cd memcached-2.2.0
phpize
./configure --with-libmemcached-dir=/usr/local/libmemcached --enable-memcached-sasl
make
make install
2、找到剛升級memcached.so
,stat
命令確定下是否更新(注意下modify時間)
3、修改php.ini
配置
3.1 session段
找到[Session]
段落,修改存儲引擎為:
session.save_handler = memcached
(注意是帶d擴展)
修改存儲地址,即OCS訪問地址為:
session.save_path = "be6b6b8221cc11e4.m.cnhzalicm10pub001.ocs.aliyuncs.com:11211"
(注意帶d擴展,則前麵不用加tcp://,不帶d的擴展需要加)
修改緩存到memcached的key的時間
session.gc_maxlifetime = 1440
(單位是秒,強烈建議必須設置一個合理時間,以保證OCS始終隻緩存熱點數據)
3.2 memcached段
在php.ini
的全局段,建一個單獨段落[memcached]
,然後在空白地方加入下麵配置
[memcached]
memcached.use_sasl = On
memcached.sess_binary = On
memcached.sess_sasl_username = "your_ocs_name"
memcached.sess_sasl_password = "your_ocs_password"
memcached.sess_locking = Off
安裝步驟完結,上述關於memcached段和Session段其他有用參數,參考鏈接如下:
https://php.net/manual/en/memcached.configuration.php https://php.net/manual/en/session.configuration.php
接下來是測試是否生效。
測試
寫測試代碼如下session.php
<?php
session_start();
$sn = session_id();
echo "session id:".$sn."n";
$_SESSION["ocs_key"]="session_value";
echo "session:".$_SESSION["ocs_key"]."n";
?>
輸出如下:
session id:ttrct9coa2q62r2sodlq4qf376
session:session_value
測試代碼get.php
去從OCS獲取剛才session.php
通過session寫入的數據
<?php
$memc = new Memcached();
$memc->setOption(Memcached::OPT_COMPRESSION, false);
$memc->setOption(Memcached::OPT_BINARY_PROTOCOL, true);
$memc->addServer("be6b6b8221cc11e4.m.cnhzalicm10pub001.ocs.aliyuncs.com", 11211);
$memc->setSaslAuthData("your_ocs_name", "your_ocs_password");
echo $memc->get("memc.sess.key.ttrct9coa2q62r2sodlq4qf376");
/*注意這裏的key是有前綴的,由php.ini中memcached.sess_prefix字段決定,
默認值為"memc.sess.key."。然後再拚接上麵打出來的
sessionid“ttrct9coa2q62r2sodlq4qf376”即可。*/
?>
該代碼輸出如下:
ocs_key|s:13:"session_value";
即PHP SESSION已經成功寫入OCS。
OCS最佳實踐
- 通過OCS記錄接口訪問頻率,快速了解
最後更新:2016-05-06 10:45:31
上一篇:
1. OCS快速開始__開放緩存OCS 體驗_體驗館-阿裏雲
下一篇:
2.2 記錄接口訪問頻率__2. OCS最佳實踐_開放緩存OCS 體驗_體驗館-阿裏雲
InvalidSignature__錯誤說明_API 網關-阿裏雲
阿裏雲發布新一代數據庫產品POLARDB,跑分超越AWS Aurora
堡壘機__使用金融雲產品_金融雲-阿裏雲
NotifyContentFormat__基本概念_API使用手冊_消息服務-阿裏雲
查詢執行計劃詳情__執行計劃_API參考_E-MapReduce-阿裏雲
1. OSS快速開始__開放存儲OSS 體驗_體驗館-阿裏雲
在違規處罰中,一般違規、嚴重違規和特別嚴重違規是怎麼定義的?__規則FAQ_常見問題_阿裏雲規則-阿裏雲
馬雲叫你來捉妖,阿裏雲棲大會本周三正式召開了,去年馬雲提出新零售催生了三江購物,今年呢?
通用錯誤碼__API-Reference_日誌服務-阿裏雲
處理-數據清洗/ETL__最佳實踐_日誌服務-阿裏雲
相關內容
常見錯誤說明__附錄_大數據計算服務-阿裏雲
發送短信接口__API使用手冊_短信服務-阿裏雲
接口文檔__Android_安全組件教程_移動安全-阿裏雲
運營商錯誤碼(聯通)__常見問題_短信服務-阿裏雲
設置短信模板__使用手冊_短信服務-阿裏雲
OSS 權限問題及排查__常見錯誤及排除_最佳實踐_對象存儲 OSS-阿裏雲
消息通知__操作指南_批量計算-阿裏雲
設備端快速接入(MQTT)__快速開始_阿裏雲物聯網套件-阿裏雲
查詢API調用流量數據__API管理相關接口_API_API 網關-阿裏雲
使用STS訪問__JavaScript-SDK_SDK 參考_對象存儲 OSS-阿裏雲