]> granicus.if.org Git - apache/blob - docs/manual/caching.html.tr.utf8
Help doc writer to spot places where:
[apache] / docs / manual / caching.html.tr.utf8
1 <?xml version="1.0" encoding="UTF-8"?>
2 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
3 <html xmlns="http://www.w3.org/1999/xhtml" lang="tr" xml:lang="tr"><head>
4 <meta content="text/html; charset=UTF-8" http-equiv="Content-Type" />
5 <!--
6         XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX
7               This file is generated from xml source: DO NOT EDIT
8         XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX
9       -->
10 <title>Önbellek Kullanım Kılavuzu - Apache HTTP Sunucusu Sürüm 2.5</title>
11 <link href="./style/css/manual.css" rel="stylesheet" media="all" type="text/css" title="Main stylesheet" />
12 <link href="./style/css/manual-loose-100pc.css" rel="alternate stylesheet" media="all" type="text/css" title="No Sidebar - Default font size" />
13 <link href="./style/css/manual-print.css" rel="stylesheet" media="print" type="text/css" /><link rel="stylesheet" type="text/css" href="./style/css/prettify.css" />
14 <script src="./style/scripts/prettify.min.js" type="text/javascript">
15 </script>
16
17 <link href="./images/favicon.ico" rel="shortcut icon" /></head>
18 <body id="manual-page"><div id="page-header">
19 <p class="menu"><a href="./mod/">Modüller</a> | <a href="./mod/quickreference.html">Yönergeler</a> | <a href="http://wiki.apache.org/httpd/FAQ">SSS</a> | <a href="./glossary.html">Terimler</a> | <a href="./sitemap.html">Site Haritası</a></p>
20 <p class="apache">Apache HTTP Sunucusu Sürüm 2.5</p>
21 <img alt="" src="./images/feather.png" /></div>
22 <div class="up"><a href="./"><img title="&lt;-" alt="&lt;-" src="./images/left.gif" /></a></div>
23 <div id="path">
24 <a href="http://www.apache.org/">Apache</a> &gt; <a href="http://httpd.apache.org/">HTTP Sunucusu</a> &gt; <a href="http://httpd.apache.org/docs/">Belgeleme</a> &gt; <a href="./">Sürüm 2.5</a></div><div id="page-content"><div id="preamble"><h1>Önbellek Kullanım Kılavuzu</h1>
25 <div class="toplang">
26 <p><span>Mevcut Diller: </span><a href="./en/caching.html" hreflang="en" rel="alternate" title="English">&nbsp;en&nbsp;</a> |
27 <a href="./fr/caching.html" hreflang="fr" rel="alternate" title="Français">&nbsp;fr&nbsp;</a> |
28 <a href="./tr/caching.html" title="Türkçe">&nbsp;tr&nbsp;</a></p>
29 </div>
30 <div class="outofdate">Bu çeviri güncel olmayabilir. Son değişiklikler için İngilizce sürüm geçerlidir.</div>
31
32     <p>Bu belge <code class="module"><a href="./mod/mod_cache.html">mod_cache</a></code>,
33       <code class="module"><a href="./mod/mod_cache_disk.html">mod_cache_disk</a></code>, <code class="module"><a href="./mod/mod_file_cache.html">mod_file_cache</a></code>
34       modülleri ve <a href="programs/htcacheclean.html">htcacheclean</a>
35       için bir başvuru kılavuzu niteliğindedir. HTTP sunucusu ve vekil
36       olarak çalışmada işlemleri hızlandırmak için bilinen sorunlar ve
37       yanlış yapılandırmalardan kaçınarak Apache HTTPD sunucusunun önbellekleme
38       özelliklerinin nasıl kullanılacağı açıklanmıştır.</p>
39   </div>
40 <div id="quickview"><ul id="toc"><li><img alt="" src="./images/down.gif" /> <a href="#introduction">Giriş</a></li>
41 <li><img alt="" src="./images/down.gif" /> <a href="#http-caching">Üç durumlu RFC2616 HTTP önbelleklemesi</a></li>
42 <li><img alt="" src="./images/down.gif" /> <a href="#socache-caching">İki durumlu Anahtar/Değer Paylaşımlı Nesne Önbellekleme</a></li>
43 <li><img alt="" src="./images/down.gif" /> <a href="#file-caching">Uzmanlaşmış Dosya Önbellekleme</a></li>
44 <li><img alt="" src="./images/down.gif" /> <a href="#security">Güvenlik Kaygıları</a></li>
45 </ul><h3>Ayrıca bakınız:</h3><ul class="seealso"><li><a href="#comments_section">Yorum</a></li></ul></div>
46 <div class="top"><a href="#page-header"><img alt="top" src="./images/up.gif" /></a></div>
47 <div class="section">
48 <h2><a name="introduction" id="introduction">Giriş</a> <a title="Permanent link" href="#introduction" class="permalink">&para;</a></h2>
49     
50
51     <p>Apache HTTP sunucusu, sunucunun başarımını çeşitli yollarla arttırmak
52       üzere tasarlanmış bir dizi önbellekleme özelliğine sahiptir.</p>
53
54     <dl>
55         <dt>Üç durumlu RFC2616 HTTP önbelleklemesi</dt>
56         <dd>
57             <code class="module"><a href="./mod/mod_cache.html">mod_cache</a></code> ve destek modülü
58             <code class="module"><a href="./mod/mod_cache_disk.html">mod_cache_disk</a></code> akılcı ve HTTP'ye uygun
59             önbellekleme sağlar. İçeriğin kendisi önbellekte saklanır ve
60             <code class="module"><a href="./mod/mod_cache.html">mod_cache</a></code>, <a href="http://www.w3.org/Protocols/rfc2616/rfc2616-sec13.html">RFC2616'nın 13. bölümü</a>nde açıklandığı gibi, içeriğin
61             önbelleklenebilirliğini denetleyen çeşitli HTTP başlıklarının ve
62             seçeneklerinin tümünü onurlandırmayı hedefler.
63             Devingen yerel içerik veya vekalet edilen içerik ile ilgilendiğiniz
64             durumda veya muhtemel bir yavaş disk üzerinde yerel dosyalara
65             erişimi hızlandırmak ihtiyacında olduğunuz durumda
66             <code class="module"><a href="./mod/mod_cache.html">mod_cache</a></code> hem basit hem de karmaşık önbellekleme
67             yapılandırmalarını hedefler.
68         </dd>
69         <dt>İki durumlu anahtar/değer paylaşımlı nesne önbellekleme</dt>
70         <dd>
71             <a href="socache.html">Paylaşımlı nesne önbellek API'si</a>
72             (socache) ve destek modülleri sunucu taraflı bir anahtar/değer
73             paylaşımlı nesne önbelleklemesi sağlar. Bu modüller SSL oturumları
74             ve kimlik doğrulama bilgileri gibi düşük seviyeli verileri
75             önbelleklemek için tasarlanmıştır. Destek modülleri verinin sunucu
76             tarafı bir paylaşımlı bellekte veya veri merkezi tarafı memcache
77             veya distcache gibi bir önbellekte saklanmasını mümkün kılar.
78         </dd>
79         <dt>Uzmanlaşmış dosya önbellekleme</dt>
80         <dd>
81             <code class="module"><a href="./mod/mod_file_cache.html">mod_file_cache</a></code> dosyaların sunucunun başlatılması
82             sırasında  belleğe yüklenmesi ile ilgilenir. Böylece dosyalara
83             erişim zamanını kısaltabilir, sıkça erişilen dosyaların dosya
84             tanıtıcılarını kaydedebilir, her istekte diske gitme ihtiyacını
85             ortadan kaldırır.
86         </dd>
87     </dl>
88
89     <p>Bu belgeden azami yararı sağlayabilmek için temel bir HTTP bilginizin
90       olması ve <a href="urlmapping.html">URL’lerin Dosya Sistemine
91       Eşlenmesi</a> ile <a href="content-negotiation.html">İçerik Uzlaşımı</a>
92       belgelerini okumuş olmanız gerekir.</p>
93
94   </div><div class="top"><a href="#page-header"><img alt="top" src="./images/up.gif" /></a></div>
95 <div class="section">
96 <h2><a name="http-caching" id="http-caching">Üç durumlu RFC2616 HTTP önbelleklemesi</a> <a title="Permanent link" href="#http-caching" class="permalink">&para;</a></h2>
97
98     
99
100     <table class="related"><tr><th>İlgili Modüller</th><th>İlgili Yönergeler</th></tr><tr><td><ul><li><code class="module"><a href="./mod/mod_cache.html">mod_cache</a></code></li><li><code class="module"><a href="./mod/mod_cache_disk.html">mod_cache_disk</a></code></li></ul></td><td><ul><li><code class="directive"><a href="./mod/mod_cache.html#cacheenable">CacheEnable</a></code></li><li><code class="directive"><a href="./mod/mod_cache.html#cachedisable">CacheDisable</a></code></li><li><code class="directive"><a href="./mod/core.html#usecanonicalname">UseCanonicalName</a></code></li><li><code class="directive"><a href="./mod/mod_negotiation.html#cachenegotiateddocs">CacheNegotiatedDocs</a></code></li></ul></td></tr></table>
101
102     <p>HTTP protokolü
103       <a href="http://www.w3.org/Protocols/rfc2616/rfc2616-sec13.html">RFC2616'nın 13. bölümü</a>nde açıklanan satıriçi önbellekleme
104       mekanizması için yerleşik bir destek içerir ve bunun getirilerinden
105       yararlanmak için <code class="module"><a href="./mod/mod_cache.html">mod_cache</a></code> modülü kullanılabilir.</p>
106
107     <p>İçeriğin taze olmadığı durumda içeriğin kaybolmasına sebep olan basit
108       iki durumlu anahtar/değer önbelleklemesinin tersine, HTTP önbelleği
109       eskimiş içeriği tutan ve bu eski içeriğin değişip değişmediğini özgün
110       sunucuya soran ve duruma göre onu tekrar taze duruma getiren bir
111       mekanizma içerir.</p>
112
113     <p>HTTP önbelleğinde bulunan bir girdi şu üç durumdan birinde olabilir:</p>
114
115     <dl>
116     <dt>Taze</dt>
117     <dd>
118         İçerik yeteri kadar yeni (<strong>tazelik ömrü</strong>nden daha genç)
119         ise <strong>taze</strong> sayılır. Bir HTTP önbelleği böyle bir içeriği
120         özgün sunucuya birşey sormadan sunabilir.
121     </dd>
122     <dt>Bayat</dt>
123     <dd>
124         <p>İçerik çok eski (<strong>tazelik ömrü</strong>nden daha yaşlı)
125         ise <strong>bayat</strong> sayılır. Bir HTTP önbelleği böyle bir
126         içeriği istemciye sunmadan önce özgün sunucuya bağlanıp bayat içeriğin
127         hala yeterince taze olup olmadığına bakmalıdır. Özgün sunucu, içerik
128         geçersizse yenisini gönderecektir, aksi takdirde, (ideal olanı budur)
129         içeriğin hala geçerli olduğunu belirten bir kod ile yanıt verecektir.
130         İçerik tekrar taze hale gelince süreç kaldığı yerden devam eder.</p>
131
132         <p>HTTP protokolü belli koşullar altında önbelleğin bayat içeriği
133         sunmasına izin vermez. Örneğin, bir içeriği özgün sunucuda tazeleme
134         çabasının bir 5xx hatasıyla başarısız olması veya başka bir tazeleme
135         isteğinin henüz sonuçlanmamış olması bu çeşit koşullardandır. Bu
136         durumlarda yanıta bir <code>Warning</code> başlığı eklenir.</p>
137     </dd>
138     <dt>Yok</dt>
139     <dd>
140         Önbellekte yer kalmazsa yer açmak için içeriğin silinmesi seçenek
141         dahilindedir. İçerik taze olsun olmasın her zaman silinebilir. Önlem
142         olarak <code class="program"><a href="./programs/htcacheclean.html">htcacheclean</a></code> elle veya bir artalan süreci
143         olarak çalıştırılabilir. Böylece önbelleğin boyutunun belirtilen
144         boyutta veya belirtilen dosya düğümü sayısında kalması sağlanabilir.
145         Araç içeriği silerken bayat içeriğe öncelik verir.
146     </dd>
147     </dl>
148
149     <p>HTTP önbelleklemesinin çalışması ile ilgili bütün ayrıntılar
150     <a href="http://www.w3.org/Protocols/rfc2616/rfc2616-sec13.html">RFC2616'nın 13. bölümünde</a> bulunabilir.</p>
151
152     <h3>Sunucu ile etkileşim</h3>
153       
154
155       <p><code class="module"><a href="./mod/mod_cache.html">mod_cache</a></code> modülü
156       <code class="directive"><a href="./mod/mod_cache.html#cachequickhandler">CacheQuickHandler</a></code> yönergesinin
157       değerine bağlı olarak iki olası yerde sunucuya bağlanır:
158       </p>
159
160       <dl>
161       <dt>Çabuk eylem aşaması</dt>
162       <dd>
163           <p>Bu aşama çok erken gerçekleşen bir aşama olup isteğin işlenmesi
164           sırasında isteğin çözümlenmesinin hemen sonrasıdır. İçerik
165           önbellekte mevcutsa hemen sunulur ve geri kalan istek işleme işlemi
166           iptal edilir.</p>
167
168           <p>Bu senaryoda önbellek sunucunun önüne vidalanmış gibi
169           davranır.</p>
170
171           <p>Sunucuda gerçekleşecek bir dizi işlemin büyük çoğunluğunun
172           yapılmadan geçilmesi nedeniyle bu en yüksek başarımlı kiptir.
173           Bu kip ayrıca, sunucu işlemlerinin kimlik doğrulama ve yetkilendirme
174           aşamalarının da yapılmadan geçilmesini sağlar. Bu bakımdan bu kip
175           seçilirken bu durum dikkate alınmalıdır.</p>
176       </dd>
177       <dt>Normal eylem aşaması</dt>
178       <dd>
179           <p>Bu aşama geç bir aşama olup, isteğin tamamen işlenmesinin
180           sonrasıdır.</p>
181
182           <p>Bu senaryoda önbellek sunucunun arkasına vidalanmış gibi
183           davranır.</p>
184
185           <p>Bu kip en esneğidir. Önbelleğin, süzme zincirinin hassas olarak
186           denetlenen bir noktasında oluşması sağlanabilir ve önbelleklenen
187           içerik istemciye gönderilmeden önce süzülüp
188           kişiselleştirilebilir.</p>
189           </dd>
190         </dl>
191
192         <p>URL önbellekte yoksa <code class="module"><a href="./mod/mod_cache.html">mod_cache</a></code> modülü yanıtı
193           önbelleğe kaydetme aşamasında süzgeç yığıtına bir
194           <a href="filter.html">süzgeç</a> ekler ve geri çekilerek normal istek
195           işlemlerinin devam etmesine izin verir. İçeriğin önbelleklenebilir
196           olduğu saptanırsa içerik gelecekte sunulmak üzere önbelleğe
197           kaydedilir, aksi takdirde içerik yok sayılır.</p>
198
199         <p>Önbellekteki içerik bayatsa, <code class="module"><a href="./mod/mod_cache.html">mod_cache</a></code> modülü
200           isteği bir <strong>koşullu istek</strong> haline getirir. Özgün
201           sunucu normal bir yanıt verirse bu yanıt mevcut içeriğin yerine
202           önbelleklenir. Özgün sunucu bir <code>304 Not Modified</code> yanıtı
203           verirse içerik tekrar taze olarak imlenir ve önbellekteki içerik
204           süzgeç tarafından kaydedilmeden sunulur.</p>
205     
206
207     <h3>Önbelleğin Hızlandırılması</h3>
208       
209
210       <p>Bir sanal konak birçok farklı sunucu takma adından biri olarak
211         bilindiği takdirde <code class="directive"><a href="./mod/core.html#usecanonicalname">UseCanonicalName</a></code> yönergesine <code>On</code>
212         değeri atanmışsa önbellekten sunulan sayfa sayısında büyük bir artış
213         olduğu görülür. Bunun sebebi içeriği sunan sanal konağın isminin
214         önbellek anahtarının içinde kullanılmasıdır. Yönergeye
215         <code>On</code> değerini atamak suretiyle çok isimli ve rumuzlu sanal
216         konaklar için farklı önbellek girdileri oluşturulmaz, bunun yerine her
217         meşru sanal konak için ayrı bir önbellek tutulur.</p>
218     
219
220     <h3>Tazelik Ömrü</h3>
221       
222
223       <p>Önbelleklenmek üzere tasarlanmış iyi biçimli bir içerik tazelik ömrünü
224         <code>Cache-Control</code> başlığının  <code>max-age</code> veya
225         <code>s-maxage</code> alanlarıyla ya da bir <code>Expires</code>
226         başlığını içererek bildirmelidir.</p>
227
228       <p>Aynı zamanda, özgün sunucunun tanımladığı tazelik ömrü, bir istemci
229         tarafından istekte bir <code>Cache-Control</code> başlığı kullanılarak
230         geçersiz kılınmak istenebilir. Bu durumda hangi tazelik ömrü daha
231         kısaysa o geçerli olur.</p>
232
233       <p>Tazelik ömrü istekte veya yanıtta mevcut değilse öntanımlı bir tazelik
234         ömrü kullanılır. Öntanımlı tazelik ömrü önbellekli içerik için bir saat
235         olmakla birlikte <code class="directive"><a href="./mod/mod_cache.html#cachedefaultexpire">CacheDefaultExpire</a></code> yönergesi
236         kullanılarak kolayca değiştirilebilir.</p>
237
238       <p>Bir yanıt <code>Expires</code> başlığını değil de
239         <code>Last-Modified</code> başlığını içeriyorsa
240         <code class="module"><a href="./mod/mod_cache.html">mod_cache</a></code> tazelik ömrünü <code class="directive"><a href="./mod/mod_cache.html#cachelastmodifiedfactor">CacheLastModifiedFactor</a></code> yönergesine
241         bakarak saptar.</p>
242
243       <p>Yerel içerik için, ya da kendi <code>Expires</code> başlığını
244         tanımlamayan uzak içerik için tazelik ömrünü <code>max-age</code> ve
245         <code>Expires</code> ekleyerek hassas olarak ayarlamak
246         için <code class="module"><a href="./mod/mod_expires.html">mod_expires</a></code> kullanılabilir.</p>
247
248       <p>Tazelik ömrünün üst sınırı <code class="directive"><a href="./mod/mod_cache.html#cachemaxexpire">CacheMaxExpire</a></code> yönergesi ile
249         belirlenebilir.</p>
250     
251
252     <h3>Şartlı İstekler için Özlü Kılavuz</h3>
253       
254
255       <p>Önbellekteki içeriğin zaman aşımına uğrayıp bayat hale gelmesi,
256         httpd’nin özgün isteği aktarmak yerine isteği değişikliğe uğratarak
257         şartlı bir istek yapması sonucunu doğurur.</p>
258
259       <p>Özgün önbellekli yanıtta bir <code>ETag</code> başlığı mevcutsa,
260         <code class="module"><a href="./mod/mod_cache.html">mod_cache</a></code> modülü özgün sunucuya yapılan isteğe
261         bir <code>If-None-Match</code> başlığı ekler.
262         Özgün önbellekli yanıtta bir <code>Last-Modified</code> başlığı
263         mevcutsa, <code class="module"><a href="./mod/mod_cache.html">mod_cache</a></code> modülü özgün sunucuya yapılan
264         isteğe bir <code>If-Modified-Since</code> başlığı ekler. Bunlardan
265         birinin varlığı isteği <strong>koşullu</strong> yapar.</p>
266
267       <p>Bir koşullu istek özgün sunucu tarafından alındığında, özgün sunucu
268         <code>ETag</code> veya <code>Last-Modified</code> başlığının isteğe
269         uygun olarak değişip değişmediğine bakmalıdır. Değişmemişse, özgün
270         sunucu kısa ve öz bir "304 Not Modified" yanıtı ile yanıt vermelidir.
271         Bunun önbellekteki anlamı şudur: Eskimiş içerik hala tazedir ve içerik
272         yeni tazelik ömrüne ulaşıncaya kadar sonraki isteklerde
273         kullanılmalıdır.</p>
274
275       <p>İçerik değişmişse, bir şartlı istek yapılmamış gibi içeriğin kendisi
276         sunulur.</p>
277
278       <p>Şartlı istekler çifte yarar sağlar. Birinci olarak, böyle bir istek
279         özgün sunucuya yapılıyorsa ve iki içerik de aynıysa bunu saptamak kolay
280         olur ve özkaynağın tamamını aktarma külfetinden kurtulunur.</p>
281
282       <p>İkinci olarak, iyi tasarlanmış bir özgün sunucu, koşullu istekler tam
283         bir yanıt üretmekten önemli ölçüde ucuz olacak şekilde tasarlanmış
284         olacaktır. Durağan dosyalar için bu genellikle
285         <code>stat()</code> veya  benzeri bir sistem çağrısıyla dosya
286         boyutları ve değişiklik zamanına bakmak şeklinde gerçekleşir.
287         Böylelikle, yerel içeriği bir değişiklik olmadığı takdirde önbellekten
288         sunmak daha hızlı olacaktır.</p>
289
290       <p>Özgün sunucular koşullu istekleri desteklemek için her türlü çabayı
291         göstermelidir. Ancak, koşullu istekler desteklenmiyorsa, özgün sunucu
292         istek koşullu değilmiş gibi yanıt vermeli, önbellek ise, içerik
293         değişmiş ve yani içerik önbelleğe kaydedilmiş gibi yanıt vermelidir. Bu
294         durumda, önbellek basit bir iki durumlu (içerik ya tazedir ya da
295         silinmiş) önbellek gibi davranacaktır.</p>
296     
297
298     <h3>Neler Önbelleklenebilir?</h3>
299       
300
301       <p>HTTP önbelleğin tarafından önbelleklenebilecek içerik
302 <a href="http://www.w3.org/Protocols/rfc2616/rfc2616-sec13.html#sec13.4">
303        RFC2616 Section 13.4 Response Cacheability</a> belgesinde tanımlanmış
304        olup, bunlar şöyle özetlenebilir:</p>
305
306       <ol>
307         <li>Önbellekleme bu URL ile etkin kılınabilmelidir. <code class="directive"><a href="./mod/mod_cache.html#cacheenable">CacheEnable</a></code> ve <code class="directive"><a href="./mod/mod_cache.html#cachedisable">CacheDisable</a></code> yönergelerine bakınız.</li>
308
309         <li>Yanıtın HTTP durum kodu 200, 203, 300, 301 veya 410 olmalıdır.</li>
310
311         <li>İstek bir HTTP GET isteği olmalıdır.</li>
312
313         <li>Eğer yanıt bir "Authorization:" başlığı içeriyorsa ayrıca
314           "Cache-Control:" başlığında da "s-maxage", "must-revalidate" veya
315           "public" değerlerinden birini içermelidir, aksi takdirde
316           önbelleklenmez.</li>
317
318         <li>Eğer URL (GET yöntemi kullanan bir HTML formunun yaptığı gibi) bir
319           sorgu dizgesi içeriyorsa  yanıt, RFC2616’nın 13.9. bölümünde
320           açıklandığı gibi bir "Expires:" başlığı içermedikçe veya
321           "Cache-Control:" başlığının max-age veya max-age yönergesini
322           içermedikçe yanıt içeriği önbelleğe alınmayacaktır.</li>
323
324         <li><code class="directive"><a href="./mod/mod_cache.html#cacheignorenolastmod">CacheIgnoreNoLastMod</a></code>
325           yönergesinin kullanımını gerektiren bir durum olmadıkça 200 durum
326           koduna sahip bir yanıtın "Etag", "Last-Modified" ve "Expires"
327           başlıklarından birini veya "Cache-Control:" başlığının "max-age" veya
328           "s-maxage" yönergelerinden birini (en azından) içermesi gerekir.</li>
329
330         <li><code class="directive"><a href="./mod/mod_cache.html#cachestoreprivate">CacheStorePrivate</a></code>
331           yönergesinin kullanımını gerektiren bir durum olmadıkça yanıt
332           "private" değerli bir "Cache-Control:" başlığı içerdiği takdirde
333           yanıtın içeriği önbelleğe alınmayacaktır.</li>
334
335         <li>Benzer şekilde, <code class="directive"><a href="./mod/mod_cache.html#cachestorenostore">CacheStoreNoStore</a></code> yönergesi kullanılmamışsa yanıt
336           "no-store" değerli bir "Cache-Control:" başlığı içeriyorsa yanıt
337           içeriği önbelleğe alınmayacaktır.</li>
338
339         <li>Herşeyle eşleşen "*" değerli bir "Vary:" başlığı içeren bir
340           yanıtın içeriği önbelleğe alınmaz.</li>
341       </ol>
342     
343
344     <h3>Neler Önbelleklenmemeli?</h3>
345       
346
347       <p>İçerik zamana bağımlıysa ya da istek kısmen bile olsa HTTP uzlaşımıyla
348         bağdaşmıyorsa önbelleğe alınmamalıdır. Bu içerik önbelleklenemeyeceğini
349         <code>Cache-Control</code> başlığını kullanarak sunucuya
350         bildirmelidir.</p>
351
352       <p>İçerik sıkça değişiyorsa, tazelik ömrü dakikalar veya saniyelerle
353         ifade ediliyorsa, içerik yine de önbelleklenebilir. Ancak, tam
354         yanıtların düzenli olarak üretilmemesinin temini için  özgün sunucunun
355         <strong>koşullu istekleri</strong> doğru olarak desteklemesi
356         sağlanmalıdır.</p>
357
358       <p>İstemcinin sağladığı istek başlıklarına dayanarak değişen içerik,
359         <code>Vary</code> yanıt başlığının akıllıca kullanımıyla
360         önbelleklenebilir.</p>
361     
362
363     <h3>Değişken/Uzlaşımlı İçerik</h3>
364       
365
366       <p>Özgün sunucu, istekteki başlık değerlerine dayanarak farklı
367         içeriklerle yanıt vermeye ayarlandığı takdirde, örneğin aynı URL'de
368         farklı dillerde içerik sunmak gibi, HTTP'nin önbellekleme mekanizması
369         aynı URL'de aynı sayfanın değişik sürümlerini önbelleklemeyi mümkün
370         kılar.</p>
371
372       <p>Bu özgün sunucu tarafından bir <code>Vary</code> başlığı eklenerek
373         yapılır. Bir sayfanın farklı sürümleri arasındaki farkları saptarken
374         önbellek tarafından hangi başlıkların hesaba katılacağını
375         <code>Vary</code> başlığı belirler.</p>
376
377       <p>Örneğin, bir yanıt şöyle bir başlık ile alınmışsa,</p>
378
379       <div class="example"><p><code>
380         Vary: negotiate,accept-language,accept-charset
381       </code></p></div>
382
383       <p><code class="module"><a href="./mod/mod_cache.html">mod_cache</a></code> sadece accept-language ve accept-charset
384         başlıkları özgün istekle eşleşen önbellekli içeriği sunacaktır.</p>
385
386       <p>İçeriğin farklı sürümleri yan yana önbelleklenebilir.
387         <code class="module"><a href="./mod/mod_cache.html">mod_cache</a></code> modülü <code>Vary</code> başlığını
388         kullanarak başlıkta listelenmiş istek başlıklarının uygun değerlerini
389         saptar ve istemciye hangi sürümle yanıt verileceğine karar verir.</p>
390     
391
392     <h3><a name="disk" id="disk">Disk Üzerinde Önbellekleme</a></h3>
393       
394
395       <p><code class="module"><a href="./mod/mod_cache.html">mod_cache</a></code> modülü önbelleği yönetmek için çeşitli
396       depolama ortamlarına özgü gerçeklenimleri kullanır. Diske önbellekleme
397       desteğini <code class="module"><a href="./mod/mod_cache_disk.html">mod_cache_disk</a></code> sağlar.</p>
398
399       <p>Tipik olarak modül şöyle yapılandırılır:</p>
400
401       <div class="example"><p><code>
402 CacheRoot   /var/cache/apache/<br />
403 CacheEnable disk /<br />
404 CacheDirLevels 2<br />
405 CacheDirLength 1
406       </code></p></div>
407
408       <p>En önemlisi önbelleklenen dosyaların yerel olarak saklanması olup
409         işletim sisteminin sağladığı bellekiçi önbelleklemeden de ayrıca
410         faydalanılmış olur. Bu bakımdan, dosyalar disk üzerinde saklansa bile
411         sıkça erişilen dosyalar işletim sistemi sayesinde aslında bellekten
412         sunulmuş olacaklardır.</p>
413     
414
415     <h3>Önbellekte Saklamanın Anlamı</h3>
416       
417
418       <p><code class="module"><a href="./mod/mod_cache_disk.html">mod_cache_disk</a></code> öğeleri önbellekte saklamak için
419         istek yapılan URL’nin 22 karakterlik özetini oluşturur. Bu özet, çok
420         sayıda URL’nin aynı özeti oluşturmaması için konak ismi, protokol,
421         port ve varsa CGI argümanlarından başka <code>Vary</code> başlığında
422         tanımlı elemanlardan oluşur.</p>
423
424       <p>Özeti oluşturan karakterler 64 karakterlik bir karakter kümesinden
425         seçildiğinden oluşturulması olası farklı özet sayısı 64^22’dir.
426         Örneğin, bir URL’nin <code>xyTGxSMO2b68mBCykqkp1w</code> gibi bir
427         özeti olabilir. Bu özet, bu URL ile erişilen dosyalar önbellek içinde
428         saklanırken dosya ismi öneki olarak kullanılır. Ancak bununla
429         yetinilmez ve içerik <code class="directive"><a href="./mod/mod_cache_disk.html#cachedirlevels">CacheDirLevels</a></code> ve <code class="directive"><a href="./mod/mod_cache_disk.html#cachedirlength">CacheDirLength</a></code> yönergelerinin
430         değerlerine göre önce dizinlere ayrılır.</p>
431
432       <p><code class="directive"><a href="./mod/mod_cache_disk.html#cachedirlevels">CacheDirLevels</a></code>
433         yönergesi kaç alt seviye dizin olacağını ve <code class="directive"><a href="./mod/mod_cache_disk.html#cachedirlength">CacheDirLength</a></code> her dizinde kaç
434         karakter olacağını belirler. Örneğin, yukarıdaki
435         özete sahip bir dosyanın isminin başına yukarıdaki yapılandırma
436         örneğine uygun olarak
437         <code>/var/cache/apache/x/y/TGxSMO2b68mBCykqkp1w</code> gibi bir önek
438         getirilebilirdi.</p>
439
440       <p>Bu tekniğin asıl amacı belli bir dizin içinde bulunabilecek
441         dosyaların ve alt dizinlerin sayısını düşük tutmaktır. Bu sayının
442         büyük olması çoğu işletim sisteminde başarımın düşmesine sebep olur.
443         <code class="directive"><a href="./mod/mod_cache_disk.html#cachedirlength">CacheDirLength</a></code>
444         yönergesi "1" değeriyle kullanıldığında her dizin altında en fazla 64
445         alt dizin veya dosya açılabilir. "2" değeriyle kullanıldığında ise bu
446         sayı 64^2’ye yükselir ve böyle artarak gider. İyi bir sebebiniz
447         olmadıkça <code class="directive"><a href="./mod/mod_cache_disk.html#cachedirlength">CacheDirLength</a></code> için değer olarak
448         "1" belirtmenizi öneririz.</p>
449
450       <p><code class="directive"><a href="./mod/mod_cache_disk.html#cachedirlevels">CacheDirLevels</a></code>
451         yönergesine atanacak değer önbellekte saklamayı düşündüğünüz olası
452         dosya sayısı ile ilgilidir. Yukarıdaki örnekte olduğu gibi "2"
453         değerini belirtirseniz, toplamda en fazla 4096 dizin oluşturulabilir.
454         1 milyon dosyanın önbelleklendiği bir durumda bu, her dizinde yaklaşık
455         olarak 245 önbelleklenmiş URL demektir.</p>
456
457       <p>Her URL için önbellekte en az iki dosya saklanır. Biri genellikle URL
458         hakkındaki temel verilerden oluşan ".header" dosyasıdır, diğeri ise
459         sunulacak içeriğin bire bir kopyası olan ".data" dosyasıdır.</p>
460
461       <p>"Vary" başlığı üzerinden içeriğin uzlaşıldığı durumda URL için bir
462         ".vary" dizini oluşturulur. Bu dizin her biri farklı bir uzlaşıma ait
463         çok sayıda ".data" dosyası içerebilir.</p>
464     
465
466     <h3>Disk Önbelleğinin Bakımı</h3>
467       
468
469       <p><code class="module"><a href="./mod/mod_cache_disk.html">mod_cache_disk</a></code> zaman aşımına uğrayan önbellekli
470         içeriği silse de önbelleğin toplam boyu ve ne kadar boş bellek kaldığı
471         hakkında bilgi vermez.</p>
472
473       <p>Bunun yerine httpd önbellek içeriğini düzenli aralıklarla
474         temizleyebilmeniz için <code class="program"><a href="./programs/htcacheclean.html">htcacheclean</a></code> adında bir araç
475         içerir.  Önbellek için azami ne kadar yer kullanılacağının ve bunun
476         üzerinde <code class="program"><a href="./programs/htcacheclean.html">htcacheclean</a></code>’i hangi sıklıkta
477         çalıştırılacağının tespiti biraz karmaşık bir işlem olup uygun değerler
478         genellikle deneme yanılma yoluyla bulunur.</p>
479
480       <p><code class="program"><a href="./programs/htcacheclean.html">htcacheclean</a></code> iki işlem kipine sahiptir. Kalıcı bir
481         artalan süreci olarak çalışabileceği gibi cron üzerinden belli
482         aralıklarla da çalıştırılabilir. Çok büyük (onlarca GB) önbelleklerde
483         <code class="program"><a href="./programs/htcacheclean.html">htcacheclean</a></code>’in işini bitirmesi 1 saatten fazla
484         sürebileceğinden, cron ile çalıştırma durumunda aynı anda birden fazla
485         kopyanın çalışıyor durumda olmaması için
486         <code class="program"><a href="./programs/htcacheclean.html">htcacheclean</a></code>’in çalıştırılma aralığını iyi
487         belirlemek gerekir.</p>
488
489       <p>Ayrıca, <code class="program"><a href="./programs/htcacheclean.html">htcacheclean</a></code> için uygun bir "nice" seviyesi
490         seçilmesi önerilr. Böylece, sunucu çalışırken aracın ölçüsüz disk g/ç
491         yapmasına sebebiyet verilmemiş olur.</p>
492
493       <p class="figure">
494       <img src="images/caching_fig1.tr.png" alt="" width="600" height="406" /><br />
495       <a id="figure1" name="figure1"><dfn>Şekil 1</dfn></a>:
496  Önbelleğin büyümesi ve düzenli aralıklarla temizlenmesi.</p>
497
498       <p><code class="module"><a href="./mod/mod_cache_disk.html">mod_cache_disk</a></code> ne kadar bellek kullanıldığı hakkında
499         bilgi vermediğinden, <code class="program"><a href="./programs/htcacheclean.html">htcacheclean</a></code>'in bir temizliğin
500         ardından yeterli bir büyüme alanı kalacak şekilde yapılandırılması
501         temin edilmelidir.</p>
502     
503
504   </div><div class="top"><a href="#page-header"><img alt="top" src="./images/up.gif" /></a></div>
505 <div class="section">
506 <h2><a name="socache-caching" id="socache-caching">İki durumlu Anahtar/Değer Paylaşımlı Nesne Önbellekleme</a> <a title="Permanent link" href="#socache-caching" class="permalink">&para;</a></h2>
507     
508
509     <table class="related"><tr><th>İlgili Modüller</th><th>İlgili Yönergeler</th></tr><tr><td><ul><li><code class="module"><a href="./mod/mod_authn_socache.html">mod_authn_socache</a></code></li><li><code class="module"><a href="./mod/mod_socache_dbm.html">mod_socache_dbm</a></code></li><li><code class="module"><a href="./mod/mod_socache_dc.html">mod_socache_dc</a></code></li><li><code class="module"><a href="./mod/mod_socache_memcache.html">mod_socache_memcache</a></code></li><li><code class="module"><a href="./mod/mod_socache_shmcb.html">mod_socache_shmcb</a></code></li><li><code class="module"><a href="./mod/mod_ssl.html">mod_ssl</a></code></li></ul></td><td><ul><li><code class="directive"><a href="./mod/mod_authn_socache.html#authncachesocache">AuthnCacheSOCache</a></code></li><li><code class="directive"><a href="./mod/mod_ssl.html#sslsessioncache">SSLSessionCache</a></code></li><li><code class="directive"><a href="./mod/mod_ssl.html#sslstaplingcache">SSLStaplingCache</a></code></li></ul></td></tr></table>
510
511     <p>Apache HTTP sunucusu, SSL oturumları, kimlik doğrulama bilgileri gibi
512       önbelleklenebilen özel bilgiler için <a href="socache.html">socache</a>
513       arayüzü içinde düşük seviyeli bir paylaşımlı nesne önbelleğine
514       sahiptir.</p>
515
516     <p>Her gerçeklenime uygun ek modüller de sağlanmıştır:</p>
517
518     <dl>
519     <dt><code class="module"><a href="./mod/mod_socache_dbm.html">mod_socache_dbm</a></code></dt>
520     <dd>DBM tabanlı paylaşımlı nesne önbelleklemesi.</dd>
521     <dt><code class="module"><a href="./mod/mod_socache_dc.html">mod_socache_dc</a></code></dt>
522     <dd>Distcache tabanlı paylaşımlı nesne önbelleklemesi.</dd>
523     <dt><code class="module"><a href="./mod/mod_socache_memcache.html">mod_socache_memcache</a></code></dt>
524     <dd>Memcache tabanlı paylaşımlı nesne önbelleklemesi.</dd>
525     <dt><code class="module"><a href="./mod/mod_socache_shmcb.html">mod_socache_shmcb</a></code></dt>
526     <dd>Paylaşımlı belleğe dayalı paylaşımlı nesne önbelleklemesi.</dd>
527     </dl>
528
529     <h3><a name="mod_authn_socache-caching" id="mod_authn_socache-caching">Kimlik Doğrulama Bilgilerinin Önbelleklenmesi</a></h3>
530       
531
532       <table class="related"><tr><th>İlgili Modüller</th><th>İlgili Yönergeler</th></tr><tr><td><ul><li><code class="module"><a href="./mod/mod_authn_socache.html">mod_authn_socache</a></code></li></ul></td><td><ul><li><code class="directive"><a href="./mod/mod_authn_socache.html#authncachesocache">AuthnCacheSOCache</a></code></li></ul></td></tr></table>
533
534       <p><code class="module"><a href="./mod/mod_authn_socache.html">mod_authn_socache</a></code> modülü kimlik doğrulama araçlarının
535         yükünün hafifletilmesini, kimlik doğrulama sonucunun önbelleklenmesini
536         sağlar.</p>
537     
538
539     <h3><a name="mod_ssl-caching" id="mod_ssl-caching">SSL Oturumlarının Önbelleklenmesi</a></h3>
540       
541
542       <table class="related"><tr><th>İlgili Modüller</th><th>İlgili Yönergeler</th></tr><tr><td><ul><li><code class="module"><a href="./mod/mod_ssl.html">mod_ssl</a></code></li></ul></td><td><ul><li><code class="directive"><a href="./mod/mod_ssl.html#sslsessioncache">SSLSessionCache</a></code></li><li><code class="directive"><a href="./mod/mod_ssl.html#sslstaplingcache">SSLStaplingCache</a></code></li></ul></td></tr></table>
543
544       <p><code class="module"><a href="./mod/mod_ssl.html">mod_ssl</a></code> modülü, oturum önbelleği ve önbellek
545        zımbalaması sağlamak için <code>socache</code> arayüzünü kullanır.</p>
546     
547   </div><div class="top"><a href="#page-header"><img alt="top" src="./images/up.gif" /></a></div>
548 <div class="section">
549 <h2><a name="file-caching" id="file-caching">Uzmanlaşmış Dosya Önbellekleme</a> <a title="Permanent link" href="#file-caching" class="permalink">&para;</a></h2>
550     
551
552      <table class="related"><tr><th>İlgili Modüller</th><th>İlgili Yönergeler</th></tr><tr><td><ul><li><code class="module"><a href="./mod/mod_file_cache.html">mod_file_cache</a></code></li></ul></td><td><ul><li><code class="directive"><a href="./mod/mod_file_cache.html#cachefile">CacheFile</a></code></li><li><code class="directive"><a href="./mod/mod_file_cache.html#mmapfile">MMapFile</a></code></li></ul></td></tr></table>
553
554     <p>Dosya sisteminin yavaş olabildiği veya dosya tanıtıcılarının
555       kullanımının pahalıya mal olduğu sistemlerde, sunucunun başlatılması
556       sırasında dosyaların belleğe yüklenmesi seçeneği vardır.</p>
557
558     <p>Dosyaların açılmasının yavaş olduğu sistemlerde, dosyaların sunucunun
559       başlatılması sırasında açılması ve dosya tanıtıcısını önbelleklenmesi
560       seçeneği vardır. Bu seçeneklerin duruk dosyalara erişimin yavaş olduğu
561       sistemlere de bir yardımı olabilir.</p>
562
563     <h3><a name="filehandle" id="filehandle">Dosya Tanıtıcı Önbelleklemesi</a></h3>
564       
565
566       <p>Bir dosyanın açılması işlemi, özellikle de ağ dosya sistemlerinde
567         bulunan dosyalar için önemli bir gecikme kaynağı olabilir. Önbellekte,
568         çok sunulan dosyaların kendilerinin değil, açık dosya tanıtıcılarının
569         saklanması httpd’yi bu tür gecikmelerden koruyabilir. httpd’de tek
570         türde dosya tanıtıcı önbelleklemesi yapılabilmektedir.</p>
571
572       <h4><code>CacheFile</code> yönergesi ile</h4>
573         
574
575         <p>httpd’de mevcut önbelleklemenin en temel şekli
576           <code class="module"><a href="./mod/mod_file_cache.html">mod_file_cache</a></code> tarafından sağlanan dosya tanıtıcı
577           önbelleklemesidir. Bu önbellek türü dosyaların kendilerini değil açık
578           dosya tanıtıcılarının bir listesini saklar. Dosyaların bu anlamda
579           önbelleklenmesi, <code class="directive"><a href="./mod/mod_file_cache.html#cachefile">CacheFile</a></code> yönergesi yapılandırma dosyasında belirtilerek
580           sağlanabilir.</p>
581
582         <p><code class="directive"><a href="./mod/mod_file_cache.html#cachefile">CacheFile</a></code> yönergesi
583           belirtilen dosyanın httpd başlatıldığında açılmasını ve dosya için
584           yapılan sonraki her istekte bu dosya tanıtıcısının kullanılmasını
585           sağlar.</p>
586
587         <div class="example"><p><code>
588           CacheFile /usr/local/apache2/htdocs/index.html
589         </code></p></div>
590
591         <p>Büyük miktarda dosyayı bu anlamda önbelleklemeyi tasarlıyorsanız
592           işletim sisteminizin açık dosya tanıtıcılarının sayısı ile ilgili
593           sınırlamasını uygun bir değere ayarlamanız gerekebilir.</p>
594
595         <p><code class="directive"><a href="./mod/mod_file_cache.html#cachefile">CacheFile</a></code> yönergesini
596           kullandığınız takdirde dosya içeriğindeki değişiklikleri anında
597           isteğe yansıtamazsınız. httpd dosyayı ilk başlatıldığındaki haliyle
598           sunar.</p>
599
600         <p>Eğer httpd çalışırken dosya silinmişse httpd ilk başlatıldığındaki
601           haline ilişkin dosya tanıtıcıyı sağlamaya ve dolayısıyla dosya
602           içeriğini sunmaya devam edecektir. Yani, dosya silinmiş ve artık
603           dosya sisteminde görünmüyor olsa bile httpd durdurulup dosya
604           tanıtıcıları kapanmadıkça dosyaların silinmesiyle açılan yer serbest
605           kalmayacaktır.</p>
606       
607
608     
609
610     <h3><a name="inmemory" id="inmemory">Sistem Belleğinde Önbellekleme</a></h3>
611       
612
613       <p>İçeriğin sistem belleğinden sunulması içerik sunmanın evrensel olarak
614       en hızlı yoludur. Dosyaların bir disk denetleyiciden okunması ya da daha
615       kötüsü uzak bir ağdan okunması bellekten okumayla karşılaştırılamayacak
616       ölçüde yavaş işlemlerdir. Disk denetleyiciler genellikle fiziksel
617       süreçleri denetlerler. Ağ erişimi ise band genişliği sınırlamalarından
618       etkilenir. Halbuki bellek erişimi sadece nano saniyeler mertebesinde
619       gerçekleşir.</p>
620
621       <p>Sistem belleği en pahalı saklama ortamı olması sebebiyle en verimli
622       şekilde kullanımı önemlidir. Dosyaları sistem belleğinde saklamakla
623       sistemin kullanabileceği bellek miktarını azaltmış olursunuz. İşletim
624       sistemi önbelleklemesinde göreceğiniz gibi bu öyle basit bir konu
625       değildir. httpd’nin kendi kullandığı belleğin bir kısmını önbellek
626       olarak ayırırken çok fazla bellek kullanmamak önemlidir. Aksi takdirde
627       işletim sistemi belleğin yetmediği noktada belleği diske
628       takaslayacağından istenen başarım artışı sağlanamayacaktır.</p>
629
630       <h4>İşletim Sistemi Önbelleklemesi</h4>
631         
632
633         <p>Günümüz iştetim sistemlerinin hemen hemen tamamında bellek içi
634         dosya/veri saklama işlemlerini çekirdek yönetir. Bu güçlü bir
635         özelliktir ve işletim sistemlerinin büyük çoğunluğu bunu böyle yapar.
636         Örneğin, Linux’ta bir dosyanın ilk defa okunduğunda ve ikinci kez
637         okunduğunda işlemcinin ne kadar meşgul edildiğine bakalım:</p>
638
639         <div class="example"><p><code>
640           colm@coroebus:~$ time cat testfile &gt; /dev/null<br />
641           real    0m0.065s<br />
642           user    0m0.000s<br />
643           sys     0m0.001s<br />
644           colm@coroebus:~$ time cat testfile &gt; /dev/null<br />
645           real    0m0.003s<br />
646           user    0m0.003s<br />
647           sys     0m0.000s
648         </code></p></div>
649
650         <p>Küçük bir dosya için bile okuma süresi bakımından büyük fark ortaya
651           çıkmaktadır. Bunun sebebi çekirdeğin dosya içeriğini bellek daha
652           güncel amaçlar için lazım olana dek bellek içinde saklamasıdır.</p>
653
654         <p>Sisteminizde yeterince yedek bellek olduğundan eminseniz, bu
655           önbellekte daha fazla dosya saklanacağından emin olabilirsiniz.
656           Bundan, önbelleğin sistem belleğinde verimli biçimde tutulması için
657           httpd’de ek bir yapılandırmaya gidilmesinin gerekmediği sonucu
658           çıkarılabilir.</p>
659
660         <p>Bundan başka, işletim sistemi dosyaların değiştiği ve silindiği
661           zamanları bildiğinden bu tür dosyaların içerikleri gerektiğinde
662           önbellekten kendiliğinden silinmiş olur. Bellek içinde dosya
663           saklarken dosyaların değiştirilme zamanlarını bilme olanağı
664           olmadığından bu durum httpd’ye büyük yarar sağlar.</p>
665       
666
667       <p>İşletim sisteminin dosyaların önbelleklenmesi için sağladığı bunca
668         yarara ve başarım artışına karşın bellek içinde dosya önbelleklemenin
669         httpd tarafından yerine getirilmesinin daha iyi olacağı bazı durumlar
670         vardır.</p>
671
672       <h4><code>MMapFile</code> yönergesi ile</h4>
673         
674
675         <p><code class="module"><a href="./mod/mod_file_cache.html">mod_file_cache</a></code> modülü, bir durağan dosyanın
676           içeriğini sunucunun başlatılması sırasında (mmap sistem çağrısıyla)
677           belleğe eşlenmesini mümkün kılmak için <code class="directive"><a href="./mod/mod_file_cache.html#mmapfile">MMapFile</a></code> yönergesini sağlar.
678           httpd bu dosyaya gelecek sonraki istekler için dosyanın bellekiçi
679           içeriğini kullanacaktır.</p>
680
681         <div class="example"><p><code>
682           MMapFile /usr/local/apache2/htdocs/index.html
683         </code></p></div>
684
685         <p><code class="directive"><a href="./mod/mod_file_cache.html#cachefile">CacheFile</a></code>
686           yönergesinde olduğu gibi bu dosyalarda httpd başlatıldıktan sonra
687           yapılacak bir değişiklikten httpd’nin haberi olmayacaktır.</p>
688
689         <p><code class="directive"><a href="./mod/mod_file_cache.html#mmapfile">MMapFile</a></code> yönergesi
690           ayırdığı belleğin toplam miktarı ile ilgilenmez, dolayısıyla
691           yönergenin aşırı kullanımından kaçınmalısınız. httpd’nin çocuk
692           süreçlerinin her biri bu belleğin kendilerine ait birer kopyasını
693           yapacağından belleğe eşlenen dosyaların çok yer kaplamaması büyük
694           önem taşımaktadır; aksi takdirde işletim sistemi belleği diske
695           takaslayacağından beklenen fayda sağlanamayacaktır.</p>
696       
697     
698   </div><div class="top"><a href="#page-header"><img alt="top" src="./images/up.gif" /></a></div>
699 <div class="section">
700 <h2><a name="security" id="security">Güvenlik Kaygıları</a> <a title="Permanent link" href="#security" class="permalink">&para;</a></h2>
701     
702
703     <h3>Erişim Denetimi ve Yetkilendirme</h3>
704       
705
706       <p><code class="directive"><a href="./mod/mod_cache.html#cachequickhandler">CacheQuickHandler</a></code>
707         yönergesine <code>On</code> değerinin atandığı öntanımlı durumda
708         <code class="module"><a href="./mod/mod_cache.html">mod_cache</a></code> kullanımı, daha çok sunucunun önüne
709         vidalanmış önbelleklemeli bir karşı vekile sahip olmak gibidir. Özgün
710         sunucunun bir harici önbellekmiş gibi sorgulanmasını gerektirmeyen tüm
711         istekler önbellekleme modülü tarafından karşılanacaktır. Bu durum
712         httpd'nin güvenlik modelini büyük ölçüde değiştirir.</p>
713
714       <p>Olası <code>.htaccess</code> dosyalarının dosya sisteminin tamamında
715         taranması çok pahalı bir işlem olduğundan <code class="module"><a href="./mod/mod_cache.html">mod_cache</a></code>,
716         (işlemi hızlandırmak için) önbelleğe almanın temel amacını kısmen
717         gözardı ederek, önbellekteki içeriğin sunumu için gerekli
718         yetkilendirmenin olup olmadığı konusunda bir karar üretmez. Başka bir
719         deyişle, eğer <code class="module"><a href="./mod/mod_cache.html">mod_cache</a></code> bir kısım içeriği önbelleğe
720         almışsa içerik zaman aşımına uğramadığı sürece bu içerik önbellekten
721         sunulacaktır.</p>
722
723       <p>Örneğin, yapılandırmanız bir özkaynağa IP adresine göre erişime izin
724         veriyorsa bu içeriğin önbelleğe alınmayacağından emin olmalısınız.
725         Bunu <code class="directive"><a href="./mod/mod_cache.html#cachedisable">CacheDisable</a></code>
726         yönergesini veya <code class="module"><a href="./mod/mod_expires.html">mod_expires</a></code> modülünü kullanarak
727         yapabilirsiniz. Bunu yapmaz, olayı kendi haline bırakırsanız
728         <code class="module"><a href="./mod/mod_cache.html">mod_cache</a></code> bir karşı vekil gibi çalışarak sunulan her
729         içeriği önbelleğe alacak ve hangi IP adresinden gelirse gelsin her
730         istemciye bunu sunacaktır.</p>
731
732       <p><code class="directive"><a href="./mod/mod_cache.html#cachequickhandler">CacheQuickHandler</a></code>
733         yönergesine <code>Off</code> atandığı takdirde, istek işleme
734         aşamalarının tamamı yerine getirilir ve güvenlik modeli değişmeden
735         kalır.</p>
736     
737
738     <h3>Yerel İstismarcılar</h3>
739       
740
741       <p>Son kullanıcılarıın isteklerine önbellekten hizmet sunulduğundan
742         önbelleğin kendisi içerikle etkileşime geçmek isteyenlerin veya
743         içeriği tahrif etmek isteyenlerin hedefi haline gelebilir. httpd’yi
744         çalıştıran kullanıcı tarafından her zaman önbelleğe yazılabileceğini
745         akıldan çıkarmamak önemlidir. Bu durumda alışılmışın tersine tüm
746         içeriğin Apache kullanıcısı tarafından yazılamamasının sağlanması
747         önerilir.</p>
748
749       <p>Eğer Apache kullanıcısı, örneğin bir CGI sürecindeki açık nedeniyle
750         tehlikeye atılırsa, önbellek hedef alınabilir.
751         <code class="module"><a href="./mod/mod_cache_disk.html">mod_cache_disk</a></code> kullanılırken önbellekteki bir öğeyi
752         değiştirmek veya önbelleğe yeni bir öğe eklemek görece daha
753         kolaydır.</p>
754
755       <p>Bu risk, Apache kullanıcısını kullanan diğer saldırı türleriyle
756         karşılaştırıldığında daha yüksektir. <code class="module"><a href="./mod/mod_cache_disk.html">mod_cache_disk</a></code>
757         kullanıyorsanız şunları aklınızdan çıkarmayın: (1) httpd güvenlik
758         güncellemelerini takip edin ve sunucunuzu buna göre güncelleyin. (2)
759         Mümkünse <a href="suexec.html">suEXEC</a> kullanarak CGI süreçlerini
760         Apache kullanıcısı olmayan bir kullanıcının aidiyetinde çalıştırın.</p>
761     
762
763     <h3>Önbellek Zehirlenmeleri</h3>
764       
765
766       <p>httpd bir önbellekli vekil sunucu olarak çalıştığında önbellek
767         zehirlenmesi adı verilen sorunla karşılaşılma olasılığı vardır.
768         Önbellek zehirlenmesi, vekil sunucunun özgün sunucudan yanlış (ve
769         genellikle istenmeyen) içerik almasına sebep olan bir saldırı türünü
770         betimlemek için yaygın olarak kullanılan bir terimdir.</p>
771
772       <p>Örneğin httpd’nin çalıştığı sistemin kullandığı DNS sunucuları DNS
773         önbellek zehirlenmesinden etkilenebilecek durumdaysa, bir saldırgan
774         httpd’nin istekleri almak için başvuracağı kaynak sunucunun yerini
775         değiştirebilir. Diğer bir örnek, HTTP istek kaçakçılığı adı verilen
776         bir saldırı türüdür.</p>
777
778       <p>Bu belge HTTP istek kaçakçılığını derinliğine incelenmesi için uygun
779         yer değildir (böyle kaynaklara arama motorunuzla erişebilirsiniz).
780         Bununla birlikte, vekil tarafından kaynak sunucudan alınan içeriği
781         tamamen denetim altına almak amacıyla kaynak sunucudaki bir açığı
782         istismar etmeye yönelik bir dizi istek yapılabileceğinin olasılık
783         dahilinde olduğunu bilmenizde yarar vardır.</p>
784     
785
786     <h3>Hizmet Reddi / Önbelleğin Engellenmesi</h3>
787       
788
789       <p>Vary mekanizması aynı URL'nin çok sayıda sürümünün yan yana
790         önbelleklenmesini mümkün kılar. İstemci tarafından sağlanan başlık
791         değerlerine bağlı olarak, önbellek istemciye gönderilecek doğru yanıtı
792         bulacaktır. Normal kullanımda olası değerlerin çok geniş olduğunun
793         bilindiği durumda bir başlığı (örn, <code>User-Agent</code>)
794         değişikliğe uğratma çabası bu mekanizmayı bir sorun haline getirebilir.
795         Sitenin tanınırlığına bağlı olarak aynı URL'nin binlerce hatta
796         milyonlarca önbellek girdisi oluşabilir ve bunlar önbellekteki diğer
797         girdilerin yerini alabilir.</p>
798
799       <p>Diğer yandan, belli bir özkaynağın URL'sinin her istekte
800       değiştirilmesi ihtiyacı ortaya çıkabilir. Bu normalde URL dizgesine bir
801       "cachebuster" dizgesi eklenerek yapılır. Bu içerik sunucu tarafından
802       anlamlı bir tazelik ömrüyle önbelleklenebilir olarak imlenmişse bu
803       girdiler kısa zamanda önbellekteki meşru girdilerin yerini alabilir.
804       <code class="module"><a href="./mod/mod_cache.html">mod_cache</a></code> modülü bunun önlenmesi için <code class="directive"><a href="./mod/mod_cache.html#cacheignoreurlsessionidentifiers">CacheIgnoreURLSessionIdentifiers</a></code>
805       yönergesine sahipse de bu yönerge, yoldaki vekillerin veya tarayıcı
806       önbelleklerinin aynı hizmet reddi saldırısına maruz kalmamaları için
807       dikkatle kullanılmalıdır.</p>
808     
809   </div></div>
810 <div class="bottomlang">
811 <p><span>Mevcut Diller: </span><a href="./en/caching.html" hreflang="en" rel="alternate" title="English">&nbsp;en&nbsp;</a> |
812 <a href="./fr/caching.html" hreflang="fr" rel="alternate" title="Français">&nbsp;fr&nbsp;</a> |
813 <a href="./tr/caching.html" title="Türkçe">&nbsp;tr&nbsp;</a></p>
814 </div><div class="top"><a href="#page-header"><img src="./images/up.gif" alt="top" /></a></div><div class="section"><h2><a id="comments_section" name="comments_section">Yorum</a></h2><div class="warning"><strong>Notice:</strong><br />This is not a Q&amp;A section. Comments placed here should be pointed towards suggestions on improving the documentation or server, and may be removed again by our moderators if they are either implemented or considered invalid/off-topic. Questions on how to manage the Apache HTTP Server should be directed at either our IRC channel, #httpd, on Freenode, or sent to our <a href="http://httpd.apache.org/lists.html">mailing lists</a>.</div>
815 <script type="text/javascript"><!--//--><![CDATA[//><!--
816 var comments_shortname = 'httpd';
817 var comments_identifier = 'http://httpd.apache.org/docs/trunk/caching.html';
818 (function(w, d) {
819     if (w.location.hostname.toLowerCase() == "httpd.apache.org") {
820         d.write('<div id="comments_thread"><\/div>');
821         var s = d.createElement('script');
822         s.type = 'text/javascript';
823         s.async = true;
824         s.src = 'https://comments.apache.org/show_comments.lua?site=' + comments_shortname + '&page=' + comments_identifier;
825         (d.getElementsByTagName('head')[0] || d.getElementsByTagName('body')[0]).appendChild(s);
826     }
827     else {
828         d.write('<div id="comments_thread">Comments are disabled for this page at the moment.<\/div>');
829     }
830 })(window, document);
831 //--><!]]></script></div><div id="footer">
832 <p class="apache">Copyright 2019 The Apache Software Foundation.<br /><a href="http://www.apache.org/licenses/LICENSE-2.0">Apache License, Version 2.0</a> altında lisanslıdır.</p>
833 <p class="menu"><a href="./mod/">Modüller</a> | <a href="./mod/quickreference.html">Yönergeler</a> | <a href="http://wiki.apache.org/httpd/FAQ">SSS</a> | <a href="./glossary.html">Terimler</a> | <a href="./sitemap.html">Site Haritası</a></p></div><script type="text/javascript"><!--//--><![CDATA[//><!--
834 if (typeof(prettyPrint) !== 'undefined') {
835     prettyPrint();
836 }
837 //--><!]]></script>
838 </body></html>