之前我們曾深入的探討過PHP快取技術,其中主要提到了資料快取。資料快取主要是指資料庫查詢緩存,每次存取頁面的時候,都會先偵測對應的快取資料是否存在,如果不存在,就連接資料庫,得到數據, 並把查詢結...
之前我們曾深入的探討PHP快取技術,其中主要提到了資料快取。資料快取主要是指資料庫查詢緩存,每次造訪頁面的時候,都會先檢測相應的快取資料是否存在,如果不存在,就連接資料庫,得到數據, 並把查詢結果序列化後儲存到文件中,以後同樣的查詢結果就直接從快取表或文件中取得。
用的最廣的例子看Discuz的搜尋功能,把結果ID快取到一個表中,下次搜尋相同關鍵字時先搜尋快取表。
舉個常用的方法,多表關聯的時候,把附表中的內容生成數組保存到主表的一個字段中,需要的時候數組分解一下,這樣的好處是只讀一個表,壞處就是兩個資料同步會多不少步驟,資料庫永遠是瓶頸,用硬碟換速度,是這個的關鍵點。
每次訪問頁面的時候,都會先檢測相應的緩存頁面文件是否存在,如果不存在,就連接數據庫,得到數據,顯示頁面並同時生成緩存頁面文件,這樣下次訪問的時候頁面文件就發揮作用了。 (模板引擎和網路上常見的一些快取類別通常有此功能)
時間觸發快取
檢查檔案是否存在且時間戳小於設定的過期時間,如果檔案修改的時間戳比目前時間減去過時間戳大,那麼就用緩存,否則更新緩存。
內容觸發快取
當插入資料或更新資料時,強制更新快取。
靜態快取
這裡所說的靜態快取是指靜態化,直接產生HTML或xml等文字文件,有更新的時候重生成一次,適合於不太變化的頁面,這就不說了。
記憶體快取
Memcached是高效能的,分散式的記憶體物件快取系統,用於在動態應用中減少資料庫負載,提升存取速度。
$memcache = new Memcache;
$memcache->connect('localhost', 11211) $memcache->connect('localhost', 11211) 11121" = $memcache->getVersion() ;
echo “Server's version: “.$version.”n”;
$tmp_object = new stdClass;
_test.mp_object = new stdClass;
_test. ject->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);
$get_result = $memcache->get('key');
echo “Data from the cache:n”;
『var_dump($get_result);
讀庫的範例:
$sql = 'SELECT * FROM users';
$key = md5($sql); //4mmc key)) ) {
// 在memcached 中未取得到快取數據,則使用資料庫查詢取得記錄集
echo “n”.str_pad('Read datas from My.', 60, '_'). n”;
$conn = mysql_connect('localhost', 'test', 'test');
mysql_select_db('test'); hile ($row = mysql_fetch_object($result))
$datas[] = $row;
// 將資料庫中取得的結果集資料儲存到memcached 中,以便在下次存取時使用$com key, $datas);
} else {
echo “n”.str_pad('Read datas from memcached.', 60,} '_').”n”; s);
?>
PHP的緩衝器
例如eaccelerator,apc,phpa,xcache等等。
MySQL快取
這也算非程式碼級的,經典的資料庫就是用的這種方式,看下面的運行時間,0.09xxx之類的。
[client]
……
default-character-set=gbk
『『+〦 ections=600
max_connect_errors=500
back_log=200
interactive_timeout=7200
『 table_cache=512
……
myisam_max_sort_file_size=100G
myisam_max_exmort uffer_size=128M
key_buffer_size= 1024M
read_buffer_size=512M
…
thread_concurrency=88『 如Nginx,SQUID,mod_PRoxy(apache2以上又分為mod_proxy和mod_cache)
NGINX的例子:
#user nobody;
worker_processes 4;
error_log logs/error.log crito; worker_rlimit_nofile 10240;
events {
use epoll;
worker_connections 512000 ;
}
http {
include mime.types;
『
keepalive_timeout 65;
tcp_nodelay on;
# server
server 10.10.10.224:80 weight=1;
server 10.10.10.221:80 weight=1; 㟎
『
server 10.10.10.201:80 weight=1;
}
upstream bspstylesvr {
server 10.10.10.202:80 weight=1;
}
upstream bsphelpsvr.
}
upstream bspwsisvr {
server 10.10.10.203:80 weight =1;
}
upstream bspadminsvr {
server 10.10.10.222:80 weight=1; vr {
server 10.10.10.223:80 weight=1;
}
upstream bspsellers }
upvr bspsellerssvr {
server 10.10.10.225:80 weight=1;
}
upstream bsploginsvr {
}
upstream bspregistersvr {
server 10.10.10.220:80 weight =1;
}
log_format test_com '$remote_addr – $remote_user [$time_local] “$request” '
_$s
靦""
#————— ———————————————–
#img.test.com
server {
listen 10.10.10.230:80; location / {
proxy_pass http://bspimgsvr;
include proxy_setting.conf;
} test>setting.conf;
〜} test>test.test; }
#style.test.com
server {
listen 10.10.10.230:80;
server_name style.test.com;
location / {
proxy_pass http://bspstylescom
}
access_log logs/style.log test_com;
}
#help.test.com
server {
listen 10.10.10.
listen 10.10.10.230:80$com;
location / {
proxy_pass http://bsphelpsvr;
include proxy_setting .conf;
}
access_log logs/help.log test_com;
} 🎀 listen 10.10.10.230:80;
server_name admin.test.com;
location / {
proxy_pass http://bspadminsvr;
include proxy_setting.conf;
include
}
#buyer.test.com
server {
listen 10.10.10.230:80;
server_name buyer.test.com;
location / {
、 .
}
access_log logs/buyer.log test_com;
}
#seller.test.com
伺服器{
聽10.10.10.230:80;
伺服器名稱seller.test.com;
位置/ {
proxy_pass http://bspsellersvr;
佛access_log 日誌/seller.log test_com;
}
#wsi.test.com
伺服器{
聽10.10.10.233); / {
proxy_pass http://bspwsisvr;
包括proxy_setting.conf;
佛}
佛語
凡伺服器{
凡聽10.10.10.230:80;
server_name www.test.com *.test.com;
位置~ ^/NginxStatus/ {
位置~
}
位置/ {
proxy_pass http://bspfrontsvr;
包含proxy_setting.conf;
佛}
505_Ftest> $505050505050 4票化。 2 503 504 / 50x.html;
位置= /50x.html {
凡}
位置= /50x.html {
凡}
凡#login.test.com
凡}
凡#login.test.comcom ;
伺服器名稱login.test.com;
ssl 開啟;
ssl_certificate cert.pem;
:ssl_certificate_key cert.pem;
:ssl_certificate_key cert.key; cols SSLv2 SSLv3 TLSv1;
ssl_ciphers 全部:!ADH :!EXPORT56:RC4+RSA:+高:+中:+低:+SSLv2:+EXP;
ssl_prefer_server_ciphers 開啟;
位置/ {
_c
佛}
佛access_log 日誌/login.log test_com;
凡}
凡#login.test.comcomcomo
凡}
凡#login.test.com7050300600030003700370037名伺服器50. in .test.com;
位置/ {
proxy_pass http://bspregistersvr;
包含proxy_setting.conf;
佛} fxy test
test.
proxy_set_header 主機$host;
proxy_set_header X-真實IP $remote_addr; proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
client_max_body_size 10m_xy 85; _timeout 90; proxy_send_timeout 90; proxy_read_timeout 90; proxy_buffer_size 4k; proxy_buffers 4 32k ; proxy_busy_buffers_size 64k; proxy_temp_file_write_size 64k;
mod_proxy 的範例:
irt;
ServerAdmin admin@zxsv.com
#反向代理設定
ProxyPass / http://www.zxsv.com:8080/
ProxyPassReverse / http://www.zxsv. com:8080/
# 快取目錄根根
/Rache
# 最大快取儲存
CacheSize 50000000
# 小時:每4 小時
CacheGcInterval 4
# 小時:每4 小時
:CacheGcInterval 4 Max 707 月
#過期時間= (now – Last_modified) * CacheLastModifiedFactor
CacheLastModifiedFactor 0.1
預設過期標籤:小時
CacheDefaultExpire 1
#ache 檢索內容百分比後強製完成 10% CustomLog /usr/local /apache/logs/dev_access_log 組合