| 導購 | 订阅 | 在线投稿
分享
 
 
當前位置: 王朝網路 >> mysql >> 優化使用mysql存儲session
 

優化使用mysql存儲session

2008-12-22 08:09:25  編輯來源:互聯網  简体版  手機版  評論  字體: ||
 
 
  之前寫過兩篇文章《自定義SESSION(二)——數據庫保存》和《我爲什麽不使用session》

   但後來發現都有問題。前者處理在實際中幾乎沒什麽用處,而且session回收還得自己另外處理。後者頻繁的操作數據庫,打來了很大的性能問題。

   這兩天仔細考慮下,大致給出一個方案,但還沒有具體詳細的測試。

   1、session處理和統計結合起來。同時遊客也都有記錄。

   2、完全使用數據庫和cookie來模擬session的功能。

   3、用戶的對session的操作都盡量保證在一條sql語句完成。不用到session的時候,絕對不多一條查詢。

   4、爲了效率起見,session的回收沒有集成進來,但提供了接口,可以調用實現。

  暫時給出代碼,不具體解釋。

  sql

  CREATE TABLE `*****_session` (

  `sid` char(32) NOT NULL,

  `uid` int(10) NOT NULL,

  `username` char(32) NOT NULL,

  `usertype` tinyint(1) NOT NULL,

  `activetime` int(10) NOT NULL,

  `expiry` int(10) NOT NULL,

  `ip` char(15) NOT NULL,

  `url` char(80) NOT NULL,

  `value` char(255) NOT NULL,

  PRIMARY KEY (`sid`)

  ) ENGINE=MEMORY DEFAULT CHARSET=utf8;

  php代碼

  <?

  class session{

  

   private $_sessionPrex= '';//session的前綴

  

   private $_time = '';//當前時間

  

   private $_model = null;//數據庫操作模型

  

   private $_expiry = 1200;//session有效時間

  

   private $_domain = '';//session的作用域

  

   protected $isNew = 0;//判定操作動作 0 更新 1 增加

  

   protected $session = array();//對應的一條session記錄

  

   public function __construct($options){

   $this->_setOptions($options);

   if(empty($this->_time))$this->_time = time();

   $this->session['activetime'] = $this->_time;

   }

  

   public function start(){

   $this->_getSid();

   }

  

   public function set($key,$value){

   if(in_array($key,array('uid','username','usertype','url','expiry'))){

   if($key == 'expiry'){

   $this->_setCookie($this->_sessionPrex.'_sid',$this->session['sid'],$value);

   $this->_setCookie($this->_sessionPrex.'_uid',$this->session['uid'],$value);

   }

   $this->session[$key] = $value;

   }else{

   $other = $this->session['value'];

   $other[$key] = $value;

   $this->session['value'] = $other;

   }

   }

  

   public function get($key){

   if(in_array($key,array('uid','username','usertype','url','expiry'))){

   return $this->session[$key];

   }else{

   if(isset($this->session['value'][$key])){

   return $this->session['value'][$key];

   }

   return null;

   }

   }

  

   public function gc($file,$time = 1200){

   $lasttime = file_get_contents($file);

   if($lasttime + $time<$this->_time){

   file_put_contents($file,$this->_time);

   return $this->_model->delete('activetime+expiry<'.$this->_time);

   }

   }

  

   public function destroy(){

   $this->session['uid'] = 0;

   $this->session['username'] = '';

   $this->session['usertype'] = -1;

   $this->session['expiry'] = $this->_expiry;

   $this->session['value'] = array();

   $this->_setCookie($this->_sessionPrex.'_sid',$this->session['sid'],$this->_expiry);

   $this->_setCookie($this->_sessionPrex.'_uid',$this->session['uid'],$this->_expiry);

   }

  

   public function __destruct(){

   $this->_save();

   }

  

   private function _save(){

   $dbSession = $this->session;

   $dbSession['value'] = serialize($dbSession['value']);

   if(strlen($dbSession['value'])>255)$this->_error('session->value is too long!');

   if($this->isNew == 1){

   //增加

   $this->_model->insert($dbSession);

   }else{

   //更新

   $sid = $dbSession['sid'];

   $this->_model->update(array_slice($dbSession,1),'sid=\''.$sid.'\'');

   }

   }

  

   private function _getSession($sid){

   $dbSession = $this->_model->detail('sid = \''.$sid.'\'');

   if(!$dbSession)return false;

   $dbSession['value'] = unserialize($dbSession['value']);

   $this->session = array_merge($dbSession,$this->session);

   return true;

   }

  

   private function _getSid(){

   $sid = strip_tags($_COOKIE[$this->_sessionPrex.'_sid']);

   if(strlen($sid)==32){

   if($this->_getSession($sid)){

   return true;

   }

   }else{

   $sid = md5(time().mt_rand(1000,10000));

   $this->_setCookie($this->_sessionPrex.'_sid',$sid);

   }

   $this->_setCookie($this->_sessionPrex.'_uid',0);

   $this->session = array(

   'uid' => 0,

   'username' => '',

   'usertype' => -1,

   'activetime' => $this->_time,

   'ip' => $this->_getip(),

   'url' => strip_tags($_SERVER['REQUEST_URI']),

   'expiry' =>$this->_expiry,

   'value' => array()

   );

   $this->isNew = 1;

   $this->session['sid'] = $sid;

   }

  

   private function _setCookie($name,$value,$expiry=0){

   if(empty($expiry))$expiry = $this->_expiry;

   if(empty($this->_domain)){

   setcookie($name,$value,$this->_time + $expiry,'/');

   }else{

   setcookie($name,$value,$this->_time + $expiry,'/',$this->_domain);

   }

   }

  

   private function _getip(){

   return getip();

   }

  

   private function _setOptions($options){

   foreach ($options as $key=>$value){

   if(in_array($key,array('sessionPrex','time','model','expiry','domain'))){

   $key = '_'.$key;

   $this->$key = $value;

   }

   }

   }

  

   private function _error($msg){

   throw new Phpbean_Exception($msg);

   }

  }

  ?>

  (注意,該代碼不能直接使用,本文主要是提供一種思路)
 
 
 
上一篇《MySQL 5.0系列新的社區穩定版5.0.75發布》
下一篇《使用session_set_save_handler函數重載SESSION存儲方式之MYSQL》
 
 
 
 
 
 
日版寵物情人插曲《Winding Road》歌詞

日版寵物情人2017的插曲,很帶節奏感,日語的,女生唱的。 最後聽見是在第8集的時候女主手割傷了,然後男主用嘴幫她吸了一下,插曲就出來了。 歌手:Def...

兄弟共妻,我成了他們夜裏的美食

老鍾家的兩個兒子很特別,就是跟其他的人不太一樣,魔一般的執著。兄弟倆都到了要結婚的年齡了,不管自家老爹怎麽磨破嘴皮子,兄弟倆說不娶就不娶,老父母爲兄弟兩操碎了心...

如何磨出破洞牛仔褲?牛仔褲怎麽剪破洞?

把牛仔褲磨出有線的破洞 1、具體工具就是磨腳石,下面墊一個硬物,然後用磨腳石一直磨一直磨,到把那塊磨薄了,用手撕開就好了。出來的洞啊很自然的。需要貓須的話調幾...

我就是掃描下圖得到了敬業福和愛國福

先來看下敬業福和愛國福 今年春節,支付寶再次推出了“五福紅包”活動,表示要“把欠大家的敬業福都還給大家”。 今天該活動正式啓動,和去年一樣,需要收集“五福”...

冰箱異味産生的原因和臭味去除的方法

有時候我們打開冰箱就會聞到一股異味,冰箱裏的這種異味是因爲一些物質發出的氣味的混合體,聞起來讓人惡心。 産生這些異味的主要原因有以下幾點。 1、很多人有這種習...

《極品家丁》1-31集大結局分集劇情介紹

簡介 《極品家丁》講述了現代白領林晚榮無意回到古代金陵,並追隨蕭二小姐化名“林三”進入蕭府,不料卻陰差陽錯上演了一出低級家丁拼搏上位的“林三升職記”。...

李溪芮《極品家丁》片尾曲《你就是我最愛的寶寶》歌詞

你就是我最愛的寶寶 - 李溪芮 (電視劇《極品家丁》片尾曲) 作詞:常馨內 作曲:常馨內 你的眉 又鬼馬的挑 你的嘴 又壞壞的笑 上一秒吵鬧 下...

烏梅的功效與作用以及烏梅的食用禁忌有哪些?

烏梅,又稱春梅,中醫認爲,烏梅味酸,性溫,無毒,具有安心、除熱、下氣、祛痰、止渴調中、殺蟲的功效,治肢體痛、肺痨病。烏梅泡水喝能治傷寒煩熱、止吐瀉,與幹姜一起制...

什麽是脂肪粒?如何消除臉部脂肪粒?

什麽是脂肪粒 在我們的臉上總會長一個個像脂肪的小顆粒,弄也弄不掉,而且顔色還是白白的。它既不是粉刺也不是其他的任何痘痘,它就是脂肪粒。 脂肪粒雖然也是由油脂...

網絡安全治理:國家安全保障的主要方向是打擊犯罪,而不是處置和懲罰受害者

來源:中國青年報 新的攻擊方法不斷湧現,黑客幾乎永遠占據網絡攻擊的上風,我們不可能通過技術手段杜絕網絡攻擊。國家安全保障的主要方向是打擊犯罪,而不是處置和懲罰...

河南夫妻在溫嶺網絡直播“造人”內容涉黃被刑事拘留

夫妻網絡直播“造人”爆紅   1月9日,溫嶺城北派出所接到南京警方的協查通告,他們近期打掉了一個涉黃直播APP平台。而根據掌握的線索,其中有一對涉案的夫妻主播...

如何防止牆紙老化?牆紙變舊變黃怎麽辦?

如何防止牆紙老化? (1)選擇透氣性好的牆紙 市場上牆紙的材質分無紡布的、木纖維的、PVC的、玻璃纖維基材的、布面的等,相對而言,PVC材質的牆紙最不透氣...

鮮肌之謎非日本生産VS鮮肌之謎假日貨是謠言

觀點一:破日本銷售量的“鮮肌之謎” 非日本生産 近一段時間,淘寶上架了一款名爲“鮮肌之謎的” 鲑魚卵巢美容液,號稱是最近日本的一款推出的全新護膚品,産品本身所...

中國最美古詩詞精選摘抄

系腰裙(北宋詞人 張先) 惜霜蟾照夜雲天,朦胧影、畫勾闌。人情縱似長情月,算一年年。又能得、幾番圓。 欲寄西江題葉字,流不到、五亭前。東池始有荷新綠,尚小如...

關于女人的經典語句

關于女人的經典語句1、【做一個獨立的女人】 思想獨立:有主見、有自己的人生觀、價值觀。有上進心,永遠不放棄自己的理想,做一份自己喜愛的事業,擁有快樂和成就...

未來我們可以和性愛機器人結婚嗎?

你想體驗機器人性愛嗎?你想和性愛機器人結婚嗎?如果你想,機器人有拒絕你的權利嗎? 近日,第二屆“國際人類-機器人性愛研討會”大會在倫敦金史密斯大學落下帷幕。而...

全球最變態的十個地方

10.土耳其地下洞穴城市 變態指數:★★☆☆☆ 這是土耳其卡帕多西亞的一個著名景點,傳說是當年基督教徒們爲了躲避戰爭而在此修建。裏面曾住著20000人,...

科學家稱,人類死亡後意識將在另外一個宇宙中繼續存活

據英國《每日快報》報道,一位科學家兼理論家Robert Lanza博士宣稱,世界上並不存在人類死亡,死亡的只是身體。他認爲我們的意識借助我們體內的能量生存,而且...

《屏裏狐》片頭曲《我愛狐狸精》歌詞是什麽?

《我愛狐狸精》 - 劉馨棋   (電視劇《屏裏狐》主題曲)   作詞:金十三&李旦   作曲:劉嘉   狐狸精 狐狸仙   千年修...

 
 
 
之前寫過兩篇文章《自定義SESSION(二)——數據庫保存》和《我爲什麽不使用session》 但後來發現都有問題。前者處理在實際中幾乎沒什麽用處,而且session回收還得自己另外處理。後者頻繁的操作數據庫,打來了很大的性能問題。 這兩天仔細考慮下,大致給出一個方案,但還沒有具體詳細的測試。 1、session處理和統計結合起來。同時遊客也都有記錄。 2、完全使用數據庫和cookie來模擬session的功能。 3、用戶的對session的操作都盡量保證在一條sql語句完成。不用到session的時候,絕對不多一條查詢。 4、爲了效率起見,session的回收沒有集成進來,但提供了接口,可以調用實現。 暫時給出代碼,不具體解釋。 sql CREATE TABLE `*****_session` ( `sid` char(32) NOT NULL, `uid` int(10) NOT NULL, `username` char(32) NOT NULL, `usertype` tinyint(1) NOT NULL, `activetime` int(10) NOT NULL, `expiry` int(10) NOT NULL, `ip` char(15) NOT NULL, `url` char(80) NOT NULL, `value` char(255) NOT NULL, PRIMARY KEY (`sid`) ) ENGINE=MEMORY DEFAULT CHARSET=utf8; php代碼 <? class session{ private $_sessionPrex= '';//session的前綴 private $_time = '';//當前時間 private $_model = null;//數據庫操作模型 private $_expiry = 1200;//session有效時間 private $_domain = '';//session的作用域 protected $isNew = 0;//判定操作動作 0 更新 1 增加 protected $session = array();//對應的一條session記錄 public function __construct($options){ $this->_setOptions($options); if(empty($this->_time))$this->_time = time(); $this->session['activetime'] = $this->_time; } public function start(){ $this->_getSid(); } public function set($key,$value){ if(in_array($key,array('uid','username','usertype','url','expiry'))){ if($key == 'expiry'){ $this->_setCookie($this->_sessionPrex.'_sid',$this->session['sid'],$value); $this->_setCookie($this->_sessionPrex.'_uid',$this->session['uid'],$value); } $this->session[$key] = $value; }else{ $other = $this->session['value']; $other[$key] = $value; $this->session['value'] = $other; } } public function get($key){ if(in_array($key,array('uid','username','usertype','url','expiry'))){ return $this->session[$key]; }else{ if(isset($this->session['value'][$key])){ return $this->session['value'][$key]; } return null; } } public function gc($file,$time = 1200){ $lasttime = file_get_contents($file); if($lasttime + $time<$this->_time){ file_put_contents($file,$this->_time); return $this->_model->delete('activetime+expiry<'.$this->_time); } } public function destroy(){ $this->session['uid'] = 0; $this->session['username'] = ''; $this->session['usertype'] = -1; $this->session['expiry'] = $this->_expiry; $this->session['value'] = array(); $this->_setCookie($this->_sessionPrex.'_sid',$this->session['sid'],$this->_expiry); $this->_setCookie($this->_sessionPrex.'_uid',$this->session['uid'],$this->_expiry); } public function __destruct(){ $this->_save(); } private function _save(){ $dbSession = $this->session; $dbSession['value'] = serialize($dbSession['value']); if(strlen($dbSession['value'])>255)$this->_error('session->value is too long!'); if($this->isNew == 1){ //增加 $this->_model->insert($dbSession); }else{ //更新 $sid = $dbSession['sid']; $this->_model->update(array_slice($dbSession,1),'sid=\''.$sid.'\''); } } private function _getSession($sid){ $dbSession = $this->_model->detail('sid = \''.$sid.'\''); if(!$dbSession)return false; $dbSession['value'] = unserialize($dbSession['value']); $this->session = array_merge($dbSession,$this->session); return true; } private function _getSid(){ $sid = strip_tags($_COOKIE[$this->_sessionPrex.'_sid']); if(strlen($sid)==32){ if($this->_getSession($sid)){ return true; } }else{ $sid = md5(time().mt_rand(1000,10000)); $this->_setCookie($this->_sessionPrex.'_sid',$sid); } $this->_setCookie($this->_sessionPrex.'_uid',0); $this->session = array( 'uid' => 0, 'username' => '', 'usertype' => -1, 'activetime' => $this->_time, 'ip' => $this->_getip(), 'url' => strip_tags($_SERVER['REQUEST_URI']), 'expiry' =>$this->_expiry, 'value' => array() ); $this->isNew = 1; $this->session['sid'] = $sid; } private function _setCookie($name,$value,$expiry=0){ if(empty($expiry))$expiry = $this->_expiry; if(empty($this->_domain)){ setcookie($name,$value,$this->_time + $expiry,'/'); }else{ setcookie($name,$value,$this->_time + $expiry,'/',$this->_domain); } } private function _getip(){ return getip(); } private function _setOptions($options){ foreach ($options as $key=>$value){ if(in_array($key,array('sessionPrex','time','model','expiry','domain'))){ $key = '_'.$key; $this->$key = $value; } } } private function _error($msg){ throw new Phpbean_Exception($msg); } } ?> (注意,該代碼不能直接使用,本文主要是提供一種思路)
󰈣󰈤
 
 
 
  免責聲明:本文僅代表作者個人觀點,與王朝網路無關。王朝網路登載此文出於傳遞更多信息之目的,並不意味著贊同其觀點或證實其描述,其原創性以及文中陳述文字和內容未經本站證實,對本文以及其中全部或者部分內容、文字的真實性、完整性、及時性本站不作任何保證或承諾,請讀者僅作參考,並請自行核實相關內容。
 
 
高清美女攝影(8)
高清美女攝影(7)
高清美女攝影(6)
高清美女攝影(5)
痞子的甘南日記
疑是銀河落九天
雪域壩上四——純美色
冬日戀歌——西城楊柳弄輕柔
 
>>返回首頁<<
 
 熱帖排行
 
 
 
 
© 2005- 王朝網路 版權所有