別每天OO,這個配置怎么改,這段代碼哪錯了,沒勁,好的程序不光是代碼寫的好,整體架構很重要,多了解程序之外的東西,這篇不再單單是程序方面的東西了,會寫到從程序到服務器的設置,會比較多,但個人的經驗有限,知道的就這么多,不知道的我也沒法寫呀, 文章說的不好大家就當我說夢話得了。 所有程序例子都來自網絡普遍緩存技術數據緩存:這里所說的數據緩存是指數據庫查詢緩存,每次訪問頁面的時候,都會先檢測相應的緩存數據是否存在,如果不存在,就連接數據庫,得到數據,并把查詢結果序列化后保存到文件中,以后同樣的查詢結果就直接從緩存表或文件中獲得。用的最廣的例子看Discuz的搜索功能,把結果ID緩存到一個表中,下次搜索相同關鍵字時先搜索緩存表。舉個常用的方法,多表關聯的時候,把附表中的內容生成數組保存到主表的一個字段中,需要的時候數組分解一下,這樣的好處是只讀一個表,壞處就是兩個數據同步會多不少步驟,數據庫永遠是瓶頸,用硬盤換速度,是這個的關鍵點。頁面緩存:每次訪問頁面的時候,都會先檢測相應的緩存頁面文件是否存在,如果不存在,就連接數據庫,得到數據,顯示頁面并同時生成緩存頁面文件,這樣下次訪問的時候頁面文件就發揮作用了。(模板引擎和網上常見的一些緩存類通常有此功能)時間觸發緩存:檢查文件是否存在并且時間戳小于設置的過期時間,如果文件修改的時間戳比當前時間戳減去過期時間戳大,那么就用緩存,否則更新緩存。內容觸發緩存:當插入數據或更新數據時,強制更新緩存。靜態緩存:這里所說的靜態緩存是指靜態化,直接生成HTML或XML等文本文件,有更新的時候重生成一次,適合于不太變化的頁面,這就不說了。以上內容是代碼級的解決方案,我直接CP別的框架,也懶得改,內容都差不多,很容易就做到,而且會幾種方式一起用,但下面的內容是服務器端的緩存方案,非代碼級的,要有多方的合作才能做到內存緩存:Memcached是高性能的,分布式的內存對象緩存系統,用于在動態應用中減少數據庫負載,提升訪問速度。這里說下Memcached的例子: ?php $memcache = new Memcache; $memcache- connect('localhost', 11211) or die ( Could not connect $version = $memcache- getVersion(); echo Server's version: .$version. /n $tmp_object = new stdClass; $tmp_object- str_attr = 'test'; $tmp_object- int_attr = 123; $memcache- set('key', $tmp_object, false, 10) or die ( Failed to save data at the server echo Store data in the cache (data will expire in 10 seconds)/n $get_result = $memcache- get('key'); echo Data from the cache:/n var_dump($get_result); ? 讀庫的例子: ?php $sql = 'SELECT * FROM users'; $key = md5($sql); //memcached 對象標識符 if ( !($datas = $mc- get($key)) ) { // 在 memcached 中未獲取到緩存數據,則使用數據庫查詢獲取記錄集。 echo n .str_pad('Read datas from html' target='_blank'>MySQL.', 60, '_'). n $conn = mysql_connect('localhost', 'test', 'test'); mysql_select_db('test'); $result = mysql_query($sql); while ($row = mysql_fetch_object($result)) $datas[] = $row; // 將數據庫中獲取到的結果集數據保存到 memcached 中,以供下次訪問時使用。 $mc- add($key, $datas); } else { echo n .str_pad('Read datas from memcached.', 60, '_'). n } var_dump($datas); ?html教程