Kategoriler
Php uygulamalari Php ve mysql Webmaster yardım

Php ile sql cache uygulamasi: Sisteminizi rahatlatin, sitenizi hizlandirin!

Sql cache, file cache ile nerdeyse ayni mantiga sahip bir php cache uygulamasidir. Tek farki sql cache verileri disk uzerinde degil mysql tablolarinda tutmasidir. Bunun file cache’ye gore bir cok artilarinin oldugunu dusunuyorum. Cunku bazi olumsuz durumlar file cache yapisinin iyi sekilde calisamamasina neden oluyor. Ornegin kullandiginiz hostun yada sunucunun disk yapisinin veya yazma hizinin dusuk olmasi cache sirasinda yavaslamalar ve optimasyon sorunlari yasamasina neden olur. Ozellikle SATA diskler uzerinde bu biraz daha gozle gorulur derecede kendini hissettirmektedir. SSD ve sas disk yapilari file cache icin en uygun olanlari ancak bunun eksikliginde sizlere sql cacheyi tavsiye edecegim. Mysql yapisi hizli islem yapmaya cok musait, file cacheden daha hizli ve aktif sekilde kullanim alani yaratir size.

Normalde localhostda sql cache yazisi icin denemeler ve testler yapiyordum, bunun icin bir kalip hazirladim, bu kalibi kullanarak birden fazla alan icin cache olusturabilirsiniz. Hazirladigim kalipda sadece cache alinacak alanin ismi ve cachede bekletilecegi suresini girmeniz yeterli olacak. Ve cache alinacak alanida belirttikten sonra hic ellemeden zamani geldiginde o bolum kendini guncellemis olacak. Mantik olarak cache alinan alanin ne kadar cachede kalacagi ve ne kadar ayni sorgunun gosterilecegini belirtebiliyoruz. boylece cache almadan onceki 50,100lerce sorguyu tek sorguya indirgemis olacagiz.

Uygulama iki bolumden olusuyor:

1: Fonksiyon bolumu, sizin duzenlemenize gerek olmayan bolum.

2: Cache icin kullanacaginiz kalip kod yigini.

Anlatima baslarken bunun biraz karisik gelebilecegini ancak mantik yuruttugunuzde gayet basarili bir calisma oldugunu anlayacaksiniz. Ayni tarz sistemi ayri tablo acmadan, sadece hazirladigim kod yiginini kullanarak wordpress de de istediginiz alani (buyuk sorguya neden olan yerleri) cache ye alabileceksiniz ki bu wordpress icin olan dokumani bir sonraki yazimda yazacagim.

Oncelikle kodu uygulayacaginiz sayfada mysql baglantisinin saglanmis olmasi gerekli, eger mysql baglantisi saglanmamis ve yeni basliyorsaniz asagidaki mysql baglanma kod yapisini kullanabilirsiniz, tabi oncesinde bu islem icin database olusturmaniz gerekli, yada var olan databaseye baglanti acmaniz gerekli asagidaki kod ile:

$conn = mysql_connect("localhost", "KULLANICI", "SIFRE");

if (!$conn) {
echo "baglantida sorun var: " . mysql_error();
exit;
}

if (!mysql_select_db("DATABASE")) {
echo "kullanilamiyor bu database: " . mysql_error();
exit;
}

Kendinize gore duzenlemeyi unutmayin.

Bu islemin hemen ardindan cache verilerini tutacagimiz tablomuzu mevcut databasemize eklememiz gerekli. Asagidaki kodu phpmyadmin den sorgu kismindan uygulayin:

CREATE TABLE IF NOT EXISTS kuaza_sqlcache (

id bigint(20) unsigned NOT NULL AUTO_INCREMENT,
cache_ismi varchar(64) NOT NULL DEFAULT '',
cache_icerik longtext NOT NULL,
cache_zamani varchar(30) NOT NULL DEFAULT '',
cache_suresi int(10) NOT NULL DEFAULT '60',
PRIMARY KEY (id),
UNIQUE KEY cache_ismi (cache_ismi)
) ENGINE=InnoDB DEFAULT CHARSET=utf8 ;

Sorguladiginiz bu tabloya cache alanlari icin bize gerekli olan bilgileri kaydedecegiz, ve tekrar sonrasinda ekrana yazdiracagiz.

Simdi sira fonksiyonlarimiza geldi. Normalde fonksiyonlari kullanmamistim testlere ilk basladigimda, ancak hem kolaylik saglamasi hemde yeni arkadaslarin fonksiyonla olan baglarini guclendirmek adina boyle bir yol sectim. Hemde cache alacagimiz kalip kod yigini daha temiz ve sade bir duruma geldi. yinede bunu yazdigima bakmayin, anlayanlar icin basit, anlamayanlar icin biraz fazla gorunebilir :)

Bu fonksiyonlari ister ayri sayfadan, istersenizde cache alacaginiz sayfada bir yere ekleyin. Eger coklu bir sistemde calisiyorsaniz her sayfaya include ettiginiz belli dosyalariniz vardir, bu include ettiginiz dosyanin icerisine eklemeniz daha mantikli olacaktir.

/* Cache kontrol alani, buradan once kontrol yaptirip, sonrasinda gerekli islemlere baslayacagiz. */
function c_cachekontrol($cacheismi,$bilgiiste=""){
$sorgu=mysql_query("select cache_ismi,cache_icerik,cache_zamani,cache_suresi from kuaza_sqlcache where cache_ismi = '$cacheismi'");
$bilgi = mysql_fetch_array($sorgu);
if($bilgi > 0)
{
if($bilgiiste == "cache_zamani"){
return $bilgi["cache_zamani"];
}elseif($bilgiiste == "cache_suresi"){
return $bilgi["cache_suresi"];
}elseif($bilgiiste == "cache_icerik"){
return $bilgi["cache_icerik"];
}
}else{
return "tabloyok";
}
}

/* eger mysql tablomuz yoksa yeni tablo ve cache alinan kodlari tabloya yazdiracagiz,
boylece sonraki calistirmamizda bu kaydettigimiz tablodan cache alinacak.
*/
function c_yenicacheac($cacheismi,$cacheicerik,$cachesuresi="60"){
$alhepsini = $cacheicerik;
$zaman = time();
$yeniekle = mysql_query("INSERT INTO kuaza_sqlcache
(cache_ismi, cache_icerik, cache_zamani, cache_suresi)
VALUES ('$cacheismi', '$alhepsini', '$zaman','$cachesuresi')");
/*
Bu alanida sorgunun gerceklesip gerceklesmedini arka planda yani kullanici arayuzunde gostermeden ekrana basiyoruz.
Bunu gormek icin kaynak kod kismina bakmaniz yeterli olacaktir.
*/
if($yeniekle) {
return "";
} else {
return "";
}
}

/* Eger cache suresi belirledigimizden eski ise bu alan ilede varolan cache alanini guncelliyoruz. */
function c_cacheguncelle($cacheismi,$cacheicerik,$cachesuresi="60"){
$alhepsini = $cacheicerik;
$zaman = time();
$guncelle = mysql_query("UPDATE kuaza_sqlcache SET cache_icerik = '$alhepsini', cache_zamani = '$zaman', cache_suresi = '$cachesuresi' WHERE cache_ismi = '$cacheismi'");
/*
Bu alanida sorgunun gerceklesip gerceklesmedini arka planda yani kullanici arayuzunde gostermeden ekrana basiyoruz.
Bunu gormek icin kaynak kod kismina bakmaniz yeterli olacaktir.
*/
if($guncelle) {
return "";
} else {
return "";
}
}

Kod icerisinde ki alanlari anlayabileceginiz sekilde yorumlamaya calistim.

Simdi ise en can alici noktaya geldik diyebilirim. Cache almamizda bize en cok yardimci olacak alanlardan birisi, kalip kod yigini alanina geldik. Bunu sisteminize entegre etmeyi basardiginiz,da sonraki uygulamalarda zorluk cekmeyeceginize eminim. Bir kere yapan, sonraki eklemelerde zorlanmayacaktir.

Kod icerisinde gerekli aciklamalari yaptim, ancak sonrasinda da olayi daha iyi kavrayabilmeniz icin onemli bolumleri detayli sekilde yazacagim:

/*
cacheye alacaginiz bolum icin bir isim girin, 
boylece birden fazla alani cache alacaginizda farkli isimlerle 
yeni alanlar acabilirsiniz.
*/
$cacheismi = "cachedeneme4"; 

/*
Cacheye aldiginiz kodlarin ne SIKLIKLA yenilenecegini,
guncellenecegini buradan belirtebilirsiniz. Dakika cinsinden bir sayi girmeniz yeterli.
5 = 5 dakika, 60 = 1 saat.
*/
$cachesuresi = "160";

/*belirledigimiz cache ismini kontrol ettiriyoruz, varsa sonraki islemlere geciyoruz, yoksa yeni alan girip cache bolumu olusturuyoruz.*/
$bilgi = c_cachekontrol($cacheismi);

/* if ile daha once cache tablosunun acilip acilmadigini kontrol ediyoruz, eger tablo var ise sonraki adima geciyoruz. */
if($bilgi != "tabloyok"){

/* Buradan bize yardimci olacak cache zamanini ve belirlediginiz suresini aliyoruz. */
$db_cache_zamani = c_cachekontrol($cacheismi,"cache_zamani");
$db_cache_suresi = c_cachekontrol($cacheismi,"cache_suresi");

$cachetime = 60 * $db_cache_suresi; // 60 ile belirledigimiz cache suresini carparak suanki zamandan cikartacagiz, bir sonraki adimda.

/* 
if ile cachelenen icerigin zamanini hesapliyoruz ve 
daha once belirttigimiz dakikadan daha az ise (yani cache zamani icerisinde ise) cache zamani, 
direk cacheli alani ekrana yazdiriyoruz.
*/
if (time() - $cachetime < $db_cache_zamani) {

# cache belirttigimiz zaman icerisinde ise ekrana bastiriyoruz. Boylece tek sorguda hersey halletmis olduk.
echo unserialize(base64_decode(c_cachekontrol($cacheismi,"cache_icerik")));
echo "";
}else{
/*Eger cachenin suresi belirledigimiz dakikayi asmis ise, 
o zaman burdan yeniden normal kodlarimizi calistiriyoruz ve 
cache alanini guncellemesini sagliyoruz. */
ob_start();




// Cachelenecek kodlar ve sorgular alani (aynisi)





/* Ekrana basilan alanin kodlarini html alarak, var olan tabloyu yeniden guncelliyoruz. */
 echo c_cacheguncelle($cacheismi,base64_encode(serialize(ob_get_contents())),$cachesuresi); 
 
 ob_end_flush();
 }
 /* Zaman kontrol if fonksiyonu alani bitti, daha once actigimiz ve 
 tablo var yok kontrolu yaptigimiz if icin else alanina geciyoruz
 */

 }else{
 /* Eger sql cache alaninda belirledigimiz isimde bir cache alani yoksa, 
 buradan kodlarin html yapisini alarak yeni cache alanini ekliyoruz. 
 */
 ob_start();




// Cachelenecek kodlar ve sorgular alani (aynisi)





/* Alinan html kodlari yeni eklenecek tablomuza ekliyoruz. */
 echo c_yenicacheac($cacheismi,base64_encode(serialize(ob_get_contents())),$cachesuresi); 

 ob_end_flush();
 }
 /* Ve gerekli if kontrolleri bitti, yaptigimiz sorgu sayilari 1000 ken 2 oldu, hayirli olsun :) */

Kodlarin icerisinde butun alanlarin ne islem ve ne fonksiyon gorevi gordugunu belirttim.

Yinede unutmamaniz gereken kalip kod yigini alanindaki “Cachelenecek kodlar ve sorgular alani (aynisi)” kismi ikiside ayni olacak, yani bu alana cache alinmasini istediginiz sorgularinizi, kodlarinizi girmeniz gerekli. Genelde yuksek soegular oluyor, 50,60 sorgu gibi, o zaman buradaki uygulama ile sorgu sayisi 2 ye kadar dusecektir. Boylece gerek acilislarda olsun, gereksede sonraki sayfa gezintilerinde sitenizde gozle gorulur hizlanma olacaktir. bunun yaninda sunucunuzu yada hostunuzu rahatlatmasida cabasi :)

Bu uygulamanin faydasi bir tek mysql sorgularinda olmuyor arkadaslar, sistemi zorlayacak php sorgularinda veya fonksiyonlarinda da cache alma islemi uygulandigi icin ciddi derecede sisteminizi rahatlatacaktir.

Sitenizin hizlanacaginida hesaba katarsaniz hem kullanici sitenize girdiginde keyifli zaman gecirir, hemde arama motorlari icin cazip bir alan haline gelir. Guncellik konusuna deginmiyorum, orasi size bagli. Ancak hic bir kullanici, siz bile bir sayfanin acilmasini 5 saniye beklemek istemezsiniz :)

Uygulamayi gelistirmeye yetecek zamanim olursa el atar arada bir yenilikler eklemeye calisirim, bunun haricinde gelistirme amacli kodlari kullanacak arkadaslara simdiden basarilar diliyorum. Anlamadiginiz bir yer olursa konu altindan yorum ile beni uykumdan edip, pc basina cagirabilirsiniz.

Sevgiyle kalin, bol kodlu gunler :)

Kategoriler
Php fonksiyonlari Webmaster yardım

Php ile cache sistemi [Basit ve degisken File cache]

Daha oncede yazdigim bir konuydu, simdi sizlere iki baslik altinda konu hakkinda detay verecegim.
1 – Sabit ve degismeyen sayfa cacheleme
2 – >devamli degisen ayni kalmayan sayfalari cacheleme

1. konudaki cache ile 1-2 sayfanizin cachesini almak istediginizde kullanabileceginiz bir sistem olarak karsiniza cikacak. Cok fazla degisen siteniz yoksa, belli sayfalarda cok fazla sorgu varsa veya fonksiyon, bunlarin sunucuya yuk oranini en aza indirgemek icin kullanilabilir.

Bu 1. konudaki basit cache olayina ornek vermek gerekirse bu siteye bakabilirsiniz: http://www.videolin.com

sadece ana sayfasinda kullandigim cache kodlari hem acilisin hizini hemde kullandigim bir kac php ve sql sorgusunun siteye yuk getirmesi, yavas acilmasi gibi bizi zor duruma dusurecek sorunlardan kurtarmaktadir.

Basit Cache Mantigi:

Kullanacagimiz cache sisteminin nasil isledigini anlatarak baslamakta yarar var. Kisaca sayfanin uzerine ve altina yerlestirdigimiz bir kac php kodu sayesinde orta kisimda olusan sorgular, fonksiyolar gibi olaylari tek bir dosyada toplayarak, 2. kez cagrildiginda bu dosyadan yardim almasi diyebiliriz.

Ozetle mantigin basit isleyisi:

Ziyaretci siteye girer —-> sayfayi once cache varmi kontrol eder —-> cache yoksa cache alir, varsa cache dosyasindan yukler

FAydasi: 2. kez cagliral sayfa cachelendigi icin php ve sql sorgularini calistirmadand irek cacheye alinan sabit html kodlarini cagiracak ve sayfaya isleyerek bize gosterecektir.

bu sayfa acilisini %50 sunucuyu yorma, kasma gibi olaylarida %60 azaltir..

Tek sayfalik Basit Cacheye ornek:

yukarida bahsettigim 1. konuda ve basit cache mantiginda kullanilacak kodlar asagida verilmistir:

$cachedosyasi = "cache/index.kuaza";
if (file_exists($cachedosyasi)) {
include($cachedosyasi);
exit;
}
ob_start();
<!-- Php kodlari ve mysql sorgulari -->
$ch = fopen($cachedosyasi, 'w');
fwrite($ch, ob_get_contents());
fclose($ch);
ob_end_flush();

 

yukaridaki kod genel olarak bir cache alma sisteminin ana mantigini olusturmaktadir.
sirasiyla:
cache dosyasini tanimliyoruz
cache dosyasini kontrol ediyoruz
varsa cacheyi cagiriyoruz ve islemi sonlandiriyoruz
cache yoksa kodlar arasindakileri html olarak cacheliyoruz
sonrasinda islem en basa doner..

Eger bu cachede zaman siniri eklemek istiyorsaniz, yani belli araliklarla dosya belirlediginiz sureden eski ise yenilenmesini saglamak isterseniz kucuk bir zaman kontrol kodu ile islemi basarili bir sekilde saglamis olursunuz. Bu ornekde asagida renklendirilerek verilmistir:

$cachedosyasi = "cache/index.kuaza";
if (file_exists($cachedosyasi) && (time() - 2700 < filemtime($cachedosyasi))) {
include($cachedosyasi);
exit;
}
ob_start();
<!-- Php kodlari ve mysql sorgulari -->
$ch = fopen($cachedosyasi, 'w');
fwrite($ch, ob_get_contents());
fclose($ch);
ob_end_flush();

 

Yukaridaki renkli kisimda bulunan 2700 ibaresi saniye cinsinden hesaplamak icindir. eger cache alindan dosya 2700 saniyeden eski ise yenisini olusturmaktadir.

cachelenecek alanida ob_start(); acip ob_end_flush(); kodlariyla bitiriyoruz, ve arada kalan sorgular, fonksiyonlar saf htmlye cevrilerek cache alinmis olur.

Degisen Sayfalar icin cache mantigi:

SAbit kalmayan ve devamli olarak get, post methoduyla degisesen sayfalariniz olabilir. Yada bu metodlarin disinda TEK bir dosyadan birdan fazla icerige hukmediyorsaniz basit cache sistemi etkisiz kalacaktir. Cunku ayni dosya uzerinden cachelenen dosya 1 tane olacagindan ve ayni isimde kalacagindan, baska konuda sayfa cagirdiginda onceki cache alinan sayfayi gostereceginden isinize yaramayacaktir. Ancak cachelenen dosya ismini adres satirindaki urlye yada sayfaniza gelen get,post metodundaki bir veriye gore yaptirabilirsiniz. boylece her sayfa degistiginde o sayfaya ait cache alinir. Ornek vermek gerekirse video siteniz var ve bu video sitesinde tek dosyadan islem yaptirarak milyonlarca video gosteriyorsunuz ziyaretcilerinize.
soyle ornek bir kac link gostereyim ben size:

  1. http://www.videof.net/video/kffacxfA7G4/Justin_Bieber__Baby_ft_Ludacris.html
  2. http://www.videof.net/video/uhLhdKGINzU/Usher__OMG_Official_Video.html
  3. http://www.videof.net/video/ZM3CYEdr5fA/Bruce_Springsteen__Eyes_on_the_prize_LIVE_in_DUBLIN.html
  4. http://www.videof.net/video/Pdw27j_usP0/maNga__We_Could_Be_The_Same_Turkey.html

yukarida verdigim linkler tek bir dosya uzerinden gosterilmektetir ve bu tarz siteler ve sistemler icin kullanilacak en guzel cache yontemi url yada adres satirindan gelen isteklerin cache edilen dosyaya eklenmesidir. Ben bu sitede verdigim ornek linklerde cache kullanmiyorum, cunku sunucu kasacak bir yapida degil. ancak sunucuyu mahfedecek duzeyde fonksiyon ve sql sorgusu barindiran sistemlerde kullanmanizi oneririm. Dilerseniz boyle bir sistemde kullanilacak cache kodlarini paylasarak aciklamaya gecelim.

$cachedosyasi = "cache/".md5($_SERVER['REQUEST_URI']).".kuaza";
if (file_exists($cachedosyasi) && (time() - 2700 < filemtime($cachedosyasi))) {
include($cachedosyasi);
exit;
}
ob_start();

<!-- Php kodlari ve mysql sorgulari -->
$ch = fopen($cachedosyasi, 'w');
fwrite($ch, ob_get_contents());
fclose($ch);
ob_end_flush();

 

Yukaridaki ornek benim kullandigim mantikla ayni urlden aldigim bilgiyi md5 ile sifreleyip cache ediyorum. Boylece sacma karakterler varsa cache ederken sorun cikartmasini engelliyoruz.

Eger adres satirindaki urlye gore degilde gelen get yada post daki bilgilere gore cache yapmak isterseniz yukaridaki koddaki: $_SERVER[‘REQUEST_URI’] kismini bunlardan biriyle degismeniz yeterli:
$_GET[‘GETMETODU’] yada $_POST[‘POSTMETODU’]

Boylece cache alirken ayni adres urlsiyle yada ayni get veya post bilgisiyle karsilastiginda cache ettigi onceki dosyayi cagirecektir. ve boylece herzaman ayni dosyayi ziyaretciye gostermeyecektir..

Koydugumuz zaman sinirinida dilediginiz sekilde dusurebilir yada uzatabilirsiniz. Ben saniye cinsinden yazdim. Varin siz hesaplayin gerisini :)

Bu arada kodlari kullarnirken dosya yolunu gosterirken kullandigim cache/… yolunu olusturmaniz gerek yoksa cache almaz, hatada verebilir. olusturduktan sonra cache klasorunuze chmod 777 ayarini verirseniz sorunsuz sekilde cache olusturup, silip yeniden kaydedebilir..

***

Bu dokumanda herhangi bir yanlis bilgi yada tutarsiz gordugunuz yerler varsa yorum olarak duserseniz en kisa surede duzenlemeye calisirim..

Yanlisim olduysa simdiden kusuruma bakmayin..

Kategoriler
Deneme Yazıları Eğitim - öğretim İnternet Dünyası Ivır Zıvır Php fonksiyonlari

Cache sisteminizi kendiniz hazirlayin! [PHP]

Konunun detaylarina baslamadan once webmaster arkadaslara bir kac goudum ve nasihatim olacak. Haddim olmayabilir ancak bunu bir nevi dikkate almaniz hepinizin yararina olacaktir.

Webmaster: Bir script kodlarken, hazirlarken mumkun oldugunca sorgu sayisini kisitli tutun yada bu tarz sistemlerde hava, su kadar degerli olan cache sistemlerini kullanin. Yoksa kendini hazirlayin. Bir kac mantikla yapilmayacak sey yoktur.

Alici: Bir script alirken, dikkat edin, yaptigi sorgu sayisi baslarda farkedilmeyecek kadar az olabilir, ancak yuksek hitlerde sunucunuz dahi dayanamayacak noktaya gelecektir. Ya kilitlenecek yada is yapamaz halde yavaslayacaktir.

Yanlis kodlama, php’nin urettigi hata kodlari, yuksek boyutlarda sorgu sayisi, mysql sorgularindan bahsediyorum, baslarda hitiniz 10-20 kisiyken farkedilmezdir. ancak hitiniz 500-1000 tekil e ciktiginda, anlik olarak gelen her kisi scriptteki hatali kodlari tekrar calistiracaktir, yada cok fazla sorgu varsa her kiside ayri sorgu sayisi ortaya cikacagindan sunucunuz, hostunuz kisa surede susptende olur, yani kapanir.

Buna ornek vermek gerekirse sistemine asina oldugum wordpress i secmek istiyorum: WordPress sistemini aslinda herkes yuksek hitlerde sistemi kastigi, zorladigi, kilitledigi sekillerde bilirsiniz. Aslinda oyle degildir. Standart wordpress temasinda ana sayfa sorgu sayisi 25 lerde iken, prof. bir magazine temasinda bu sayi 150-200 lere kadar cikar.. bu ornektir, 50 de olur, 100 de. Burada anlik hitiniz 50 ise sunucunuz aninda kilitlenecektir, yada inanilmaz bir yavaslama olacaktir. sebebi ise cok fazla sorgu sayisi ile hem apache ye, hemde apacheden cok mysql programina yuklenmeniz. sonucunda bunu makine kaldiramaz ve kilitlenir. sitenize bir sure ulasilamaz.

Bu kadar uzun bir baslangic yazmamin sebebi, konuyu daha iyi kavrayabilmeniz arkadaslar. Yuksek sorgular hostu oldurur, o olurkende siz bitersiniz.. Bunu dedigim gibi baslarda anlamazsiniz, ama ilerde cok kotu sekilde hissedersiniz..

Yakin zamana kadar bende bu konuda sorgu azaltma calismalari yapiyordum, ancak cache sistemi bu konuda tam aradigim seydi. sitenize giren bir kisi 200 sorgu varsa temada onu calistirir, sonrasinda cache ile sayfa komle cacheye alinir. sonrasinda girenlerin hepsi sorgu calistirmaz, cache edilen HTML dosyasini calistirir. Bu sekilde anlik 50 kisi varsa 50 kiside HTML bir dokuman calistiracaktir, yani mysql ye yuklenmede %85 e varan dususler olacaktir. Bu sitenizin guncelligine gore degisir, cok az guncellenen bir siteniz varsa cache sistemi sizin can damariniz olacaktir.

Yuksek sorgulu temalardan birisi de KuazaHaber temasidir. bunu farkettigimde sorgu azaltma yoluna gittim, bu seferde tema temaliktan cikmak uzereydi, neden cache denemeyeyim diye icimden gecirdim. Hali hazirda cache eklentileri istedigim gibi degildi, sistemi kasmasinin yaninda pekde gozle gorulur bir faydasini farkedemedim ben.

Sonuc olarak 150 ye varan sorgu sayisi cache sistemi sayesinde 11 e dustu. Bu 11 sorguda sitenin en ust kismindakiler, menuler. ondan asagisini cache ile sayfaladigim icin her giren HTML olarak bunu goruyor, ve sorgu yapmiyor sunucumuza..

Tamam kuaza uzatma dediginizi duyar gibiyim, yukarida yazdiklarimi kavradiginizi umid ederek asil konumuz olan sisteminizi cache ile kurtarabileceginiz konuya giriyorum..

CAche sistemine giris:

Cache kodlari 2 kisimdan olusur.

  1. kisim en ustte cacheye alinan, baslanan yer.
  2. kisim cachenin kapatildigi yer.

eger cache ile calisiyorsaniz 2. kisimdan sonrasini sitede gosteremeyeceginizi bilmenizi isterim. bu sebeple mantik kullanarak kendi sisteminizi gelistirebilirsiniz

Yani daha kolay anlayabilmeniz icin bir ornek vermek istiyorum:

<Cache kodlari>

kodlariniz, sorgulariniz

</cache kodlari>

bu sekilde kodlarinizi yerlestirdiginizde aradaki sorgular cache ye alinir. En guzelide cache ye sure koyabiliyorsunuz. yani cache edilen dosya 15 dk dan eski ise yenisi ile degistirilir.

ben size dakikali olarak cache alma kodlarini paylasacagim, sonrasinda aciklamasini yapacagim, dikkatle takip edin:

Cache ust kisim kodlari:

$cache_dosyasi= “kuaza_anasayfa”;
$cachefile = “cache/”.$cache_dosyasi.”.html”;
$cachetime = 60 * 60; // 60 * 60 = 1 saat
if (file_exists($cachefile) && (time() – $cachetime < filemtime($cachefile))) {
include($cachefile);
echo “<!– Kuaza onbellek sistemi “.date(‘jS F Y H:i’, filemtime($cachefile)).” –>n”;
exit;
}
ob_start();

yukaridaki kod dan sonras cache almak istediginiz kodlar geliyor.

en alt kismida asagidakileri ekleyerek cache leme islemi icin sayfa araligimizi belirliyoruz:

Cache alt kisim kodlari:

$fp = fopen($cachefile, ‘w’);
fwrite($fp, ob_get_contents());
fclose($fp);
ob_end_flush();

Iki kodu birlestirerek bir ornek vermek istiyorum. Eminim sonrasinda mantigi anlamis olursunuz:

$cache_dosyasi= “kuaza_anasayfa”;
$cachefile = “cache/”.$cache_dosyasi.”.html”;
$cachetime = 60 * 60; // 60 * 60 = 1 saat
if (file_exists($cachefile) && (time() – $cachetime < filemtime($cachefile))) {
include($cachefile);
echo “<!– Kuaza onbellek sistemi “.date(‘jS F Y H:i’, filemtime($cachefile)).” –>n”;
exit;
}
ob_start();

echo “kuazadan selamlar arkadaslar. bu echo ettigimiz yazi cache sistemi sayesinde cache klasorune html olarak kaydedilecek. burada php yada sql sorgularida kullanabilirsiniz, sizin gordugunuz sekilde cachelendigi icin sonraki acilmasinda sorgu degil html sayfa karsiniza cikacaktir :)”;

$fp = fopen($cachefile, ‘w’);
fwrite($fp, ob_get_contents());
fclose($fp);
ob_end_flush();

bu kodlari tabiki <? php …. ?> kodlari arasina almaniz gerek sonrasinda calistirdiginizda orta kisimda echo ettigimiz yazi daha acmis oldugunuz cache klasorune html seklinde yani bu isimde: kuaza_anasayfa.html kaydedilecektir.

bu islemin saglikli yapilabilmesi icin, oncelikle cache klasorunun chmod ayarinin 777 olmasi gerek.

Birazda kodlardaki alanlardan bahsedelim:

$cache_dosyasi= “kuaza_anasayfa”;

Yukaridaki alinti yaptigim kod kisminda kuaza_anasayfa ismini degiskene atiyoruz ve sonrasinda bunu cachefile degiskeni kisminda kullaniyoruz. Bunu bu sekilde eklememdeki sebep wordpress yada farkli bir scripte daha cabuk uyarlanabilmesidir. Girilen sitedeki get yada post methodu ile gelen bir veriyi alarak degiskene atarsiniz sonrasinda bunun isminde cache dosyasi yaratilir. sonraki zamanlarda ayni post yada get metodundan ayni bilgi gelirse cache dosyasi gosterilecektir. hayir farkli bir sey gelirse o isimde yeni bir cache olusturacaktir.

Ben bunu tam anlayabilmeniz icin wordpress den ornek vermek istiyorum: WordPress de yazi okuma sayfasina girdiginizde aslinda p=YAZI IDSI seklinde bir link olusur.. Siz buradaki p= den sonrasini get metodu ile cache kismana alip degiskenimize yazdirirsaniz, o yaziya ait cachemiz olmus olur. Sonrasinda girilen diger yazilar icinde o ID de farkli bir cache olusturacagi icin sitenizin cogu sayfasi cachelenecek ve gelen ziyaretciler size zarar degil, kar getirecektir..

Ornegin kendi sitem olarak hdvideoclip.com da ana sayfa ve video izleme kisimlarinda cache kullaniyorum, yukaida bahsettigim sekilde ve inanilmaz hizli aciliyor sayfalar. Sonucda sorgu olmadigi icin html sayfa aciliyor. Bu hem ziyaretciyi size baglar, hemde hostunuz, sunucunuz sorgu sayisinin fazlaligindan kasilmaz.

o sitede ornek bir videoya bakin: timbaland-scream-ft-keri-hilson-nicole-scherzinger-9319.html

acilisi nasil ? Turkiyede iseniz youtube yasak oldugu icin yavaslamalar olabilir, yada siz acarken biz saldiri aliyorsak yavas acilabilir. onun haricinde hizini gormenizi isterim.

sistem wordpress bu sebeple once o sayfanin ID sini degiskene atiyorum. Ornek:

$cache_dosyasi = $konuIDSI;

Sonasinda da bu sekilde kullaniyorum:

$cachefile = “cache/yazi-“.$cache_dosyasi.”.html”;

ve cacheye kaydetmesi bu sekilde oluyor: yazi-KONU IDsi.html

Cache dosyasinin ne kadar surede CACHE de kalacagini ise burada belirliyoruz:

$cachetime = 60 * 60; // 60 * 60 = 1 saat

10 dk da bir cache alsin istiyorsaniz bu sekilde yapin:

$cachetime = 10 * 60; // 10 * 60 = 10 dakika

Buradaki 60 = 60 saniyedir, yani 1 dakikadir. bu sekilde hesaplamanizi yapabilirsiniz.

sonrasinda da cacheden aldigimiz saat bilgisini belirledigimiz sure ile karsilastiriyoruz ve gecmis ise yeni cache almasini, gecmemis ise cacheyi gostermesini istiyoruz:

if (file_exists($cachefile) && (time() – $cachetime < filemtime($cachefile))) {
include($cachefile);
echo “<!– Kuaza onbellek sistemi “.date(‘jS F Y H:i’, filemtime($cachefile)).” –>n”;

Yukarida da yazdigim gibi, yukaridaki kod tarihleri ve saatleri karsilastiriyor, belirledigimiz dakikanin ustunde degil ise cacheyi gosteriyor, ustunde ise buradan tekrar basliyor cache almaya: ob_start(); ve buradan da bitiriyor: ob_end_flush();

Ben wordpress den ornek verdim, kullandiginiz her sisteme entegresi cok basit bir kod uygulamasidir bu. Bu kalibi kullanarak sizde sistemlerinizi Cacheleye bilir. Sunucunuzun rahatlamasini %50 ye varan performans artisini saglayabilirsiniz..

Bu cache uygulamasinin, hem size, hem hostinginize, hemde varsa sunucunuza yarari cok olacaktir. Bunun yaninda sitenizin arama motorlarinca daha cok indexlenmesine, hizli acildigi icin arama motorlarinin daha cok sitenizi ziyaret etmesine, hizli acildigi icin ziyaretcinin sitenize bir daha gelmesine ve daha bir cok konuya arti olarak etkisi vardir. Bu sebeple uyglarken, yada gelistirirken bildiklerinizi ogrendiklerinizi diger webmaster arkadaslarla paylasmayi unutmayin. Birbirimizin kuyusunu kasmak yerine bilgiyi paylastikca buyumeyi ogrenmenin vakti geldi sanirim..

Konuyu kapatmadan yukaridaki kodlar ile cache kullandigim sistemlere goz atarak sonucu gorebilirsiniz:

hdvideoclip.com: Ana sayfa ve video izleme kismi

makaleci.org: Ana sayfa ve haber okuma kismi

Farkli konularda yine yazacagim, simdilik esenlikle kalin..