ক্যোয়ারী ক্যাশে খুব সুন্দর বৈশিষ্ট্য, তবে এটির দিকে খুব বেশি মনোযোগ দেওয়ার জন্য প্রলোভিত হবেন না এবং এটি খুব বড় করে তোলার জন্য প্রলোভিত হন না। এর অভ্যন্তরীণ কিছু বোঝা সম্ভবত সে ক্ষেত্রে সহায়তা করবে।
ক্যোয়ারী ক্যাশে উপলব্ধ মেমরির এক বৃহত্তর সংলগ্ন অংশ হিসাবে শুরু হয়। তারপরে এই "বড়" ব্লকটি "ব্লকগুলি" তৈরি হয়েছে:
- প্রতিটি ক্যাশেড ক্যোয়ারী একটি ব্লক নেয়
- এর সহযোগী রেজাল্টটি একটি ব্লক নেয়
- প্রতিটি টেবিলের কোনও ক্যাশেড ক্যোয়ারী দ্বারা রেফারেন্স (যে টেবিলটি ক্যাশে রয়েছে তা উল্লেখ করে কতগুলি প্রশ্নই নেই) এছাড়াও প্রতি টেবিলের মধ্যে একটি ব্লক নেয়।
ব্লকের আকার গতিশীল, তবে সার্ভারটি query_cache_min_res_unit
4096 বাইটের ডিফল্ট ডিফল্ট সহ প্রতি ব্লকের সর্বনিম্ন বাইটগুলি বরাদ্দ করে ।
যে কোনও সময় অনুসন্ধান, তার সাথে আসা ফলাফল এবং সারণী উল্লেখগুলি ক্যাশে থেকে সরিয়ে ফেলা হয়, অন্তর্নিহিত টেবিলগুলি অকার্যকর করে নতুন প্রশ্নগুলির জন্য জায়গা তৈরি করার দ্বারা, এটি নতুন গর্তগুলি ছেড়ে দেয় তবে সেই ব্লকগুলির আকার বড়, এবং "ফ্রি ব্লক" এর সংখ্যা সাধারণত বৃদ্ধি পায় ... যদিও দুই বা ততোধিক স্বতন্ত্র ব্লকগুলি মুক্ত করা হয় তবে "ফ্রি ব্লক" এর সংখ্যা কেবল 1 দ্বারা বৃদ্ধি পায়, এবং "ফ্রি ব্লক" মোটেও বাড়বে না যদি নতুন- মুক্ত ব্লকগুলি ইতিমধ্যে নিখরচায় ব্লকের সাথে সামঞ্জস্যপূর্ণ - সেই ফ্রি ব্লকের আকারটি আরও বড় হয়ে যায়। ক্যোয়ারী ক্যাশে নিখরচায় মেমরির যে কোনও উন্মুক্ত ব্লক 1 টি বিনামূল্যে ব্লক হিসাবে গণ্য করা হয়।
অবশ্যই, এর চেয়ে ছোট একটি মুক্ত ব্লক query_cache_min_res_unit
মোটেও ব্যবহৃত হবে না।
সুতরাং, ক্যোয়ারী ক্যাশে টুকরো টুকরো। যদি সার্ভারটি একটি নতুন ক্যোয়ারী ক্যাশে করতে চায় এবং পর্যাপ্ত আকারের কোনও নিখরচায় ব্লকগুলি ব্যবস্থা করা যায় না (সেই বিবরণটি ছদ্মবেশী সহজ, কারণ অন্তর্নিহিত অ্যালগরিদম জটিল) তবে অন্য কিছু ছাঁটাই করতে হবে ... এটি আপনার Qcache_lowmem_prunes
। একটি "স্বল্প-সাম্প্রতিক-ব্যবহৃত" (এলআরইউ) অ্যালগরিদম রয়েছে যা সিদ্ধান্ত নেয় যে ছাঁটাই হবে।
এটি জিজ্ঞাসা করা বুদ্ধিমানের কাজ হবে কেন সার্ভার মেমরিটিকে ডিফ্র্যাম্ট করে না ... তবে তা বোঝা যাবে না। ক্যোয়ারী ক্যাশে সাহায্য করতে পারে যখন এটি করতে পারে তবে এটি কোনও কৌশলগত নয়। অপ্রয়োজনীয় রক্ষণাবেক্ষণের কার্যক্রমে আপনি প্রক্রিয়াকরণের সময় (বিশেষত বিশ্বব্যাপী লক এ ব্যয় করা সময়) বিনিয়োগ করতে চান না।
ক্যোয়ারী ক্যাশে মেমরিটিকে পুনরায় সাজানো - ডিফ্র্যাগমেন্টিং - ব্যয় করা সার্ভারের পক্ষে প্রতি-উত্পাদনশীল হবে, যেহেতু ক্যাশেড ফলাফলগুলি প্রতিনিয়ত পরিবর্তিত হয় এবং ক্যাশেটির পুরো বিন্দুটি কর্মক্ষমতা উন্নত করে।
আপনি অতিরিক্ত পরিমাণে ক্যোয়ারী ক্যাশে ব্যবহার করতে চান না সে কারণেই বিশ্বব্যাপী লকটি হ'ল একটি খুব ভাল কারণ ... সার্ভারগুলি সেখানে খুব বেশি সময় ব্যয় করবে কারণ ক্যোয়ারীগুলি ক্যাশে হচ্ছে কিনা তা দেখার জন্য ক্যারিরা তাদের পালা অপেক্ষা করে এবং আপনার কার্য সম্পাদন ক্ষতিগ্রস্থ হবে there ।
তবে qcache_free_blocks
মূলত হ'ল ফাঁকা স্থান বিভাজনের একটি সূচক। এটি এখন ক্যোয়ারী ক্যাশে উপলব্ধ মেমরির অনেকগুলি অবিসংবাদিত ব্লক বিদ্যমান। একটি নতুন ক্যোয়ারী ক্যাশে toোকানোর জন্য, ক্যোয়ারী, এর ফলাফলগুলি এবং (কখনও কখনও) এর সারণি উল্লেখগুলি অন্তর্ভুক্ত করার জন্য এআরএ যথেষ্ট পরিমাণ খালি স্থান থাকতে হবে। যদি সেখানে না থাকে, তবে অন্য কিছু যেতে হবে ... যা আপনি দেখছেন। আবার নোট করুন, যে উপলভ্য স্থানটি সর্বদা অবিচ্ছিন্নভাবে হয় না (উত্স কোডটি পড়ে আমি যা বলতে পারি তা থেকে) তবে খণ্ড খণ্ডিত হলে প্রতিটি গর্ত পূরণ হবে না।
তবে বিভাজনটি সময়ের সাথে সাথে একটি নির্দিষ্ট কাজের চাপের বাইরে চলে যায়, যেহেতু আপনি যতক্ষণ আশা করতে পারেন কিছুই সাধারণত ক্যোয়ারী ক্যাশে থাকে না।
এটি কারণ, কিছু উপায়ে ক্যোয়ারী ক্যাশে তার সরলতায় উজ্জ্বল।
কোনও ক্যাশেড ক্যোয়ারী দ্বারা রেফারেন্সিত কোনও সারণীতে থাকা ডেটা যে কোনও সময় পরিবর্তিত হয়, সেই টেবিলের সাথে জড়িত সমস্ত প্রশ্নের সমস্ত ক্যাশে থেকে সরানো হয় - এমনকি যদি পরিবর্তনটি ক্যাশেড ফলাফলগুলিকে প্রভাবিত করে না। এটি এমনকি সত্য যদি কোনও টেবিল পরিবর্তন হয় তবে পরিবর্তন হয় না, যেমন কোনও InnoDB লেনদেনের ক্ষেত্রে ফিরে আসে। এই টেবিলটি উল্লেখ করে ক্যোয়ারী ক্যাশে এন্ট্রি ইতিমধ্যে মুছে ফেলা হয়েছে।
এছাড়াও, সার্ভারটি আসলে ক্যোরিটিকে পার্স করার আগে প্রতিটি আগত ক্যোয়ারির জন্য ক্যোয়ারী ক্যাশে পরীক্ষা করা হয় । একমাত্র জিনিসটি যা মিলবে তা হ'ল আরেকটি ক্যোয়ারী যা অবিকল ছিল একই, বাইট-বাই-বাইট। SELECT * FROM my_table
এবং select * from my_table
বাইট-বাই বাইট অভিন্ন নয়, সুতরাং ক্যোয়ারী ক্যাশে বুঝতে পারে না যে তারা একই কোয়েরি।
FLUSH QUERY CACHE
ক্যোয়ারী ক্যাশে খালি করে না। এটি ক্যোয়ারী ক্যাশেটিকে ডিফ্র্যাগমেন্ট করে, যে কারণে Qcache_free_blocks
"১" হয় why সমস্ত মুক্ত স্থান একীভূত।
RESET QUERY CACHE
আসলে ক্যোয়ারী ক্যাশে ফ্লাশ হয় (এর সমস্ত বিষয়বস্তু পরিষ্কার করে)।
FLUSH STATUS
কাউন্টারগুলি সাফ করে, তবে এটি আপনি নিয়মিত করতে চান এমন কিছু নয় কারণ এই স্থিতিটির বেশিরভাগ ভেরিয়েবলগুলি জিরো করে SHOW STATUS
।
এখানে কিছু দ্রুত বিক্ষোভ রয়েছে।
বেসলাইন:
mysql> show status like '%qcache%';
+-------------------------+----------+
| Variable_name | Value |
+-------------------------+----------+
| Qcache_free_blocks | 1 |
| Qcache_free_memory | 67091120 |
| Qcache_hits | 0 |
| Qcache_inserts | 0 |
| Qcache_lowmem_prunes | 0 |
| Qcache_not_cached | 1 |
| Qcache_queries_in_cache | 0 |
| Qcache_total_blocks | 1 |
+-------------------------+----------+
একটি কোয়েরি চালান ...
mysql> select * from junk where id = 2;
মোট ব্লকগুলি বৃদ্ধি পেয়েছে 3, সন্নিবেশ 1 এবং ক্যাশে কোয়েরি 1।
+-------------------------+----------+
| Variable_name | Value |
+-------------------------+----------+
| Qcache_free_blocks | 1 |
| Qcache_free_memory | 67089584 |
| Qcache_inserts | 1 |
| Qcache_queries_in_cache | 1 |
| Qcache_total_blocks | 4 |
+-------------------------+----------+
একই ক্যোয়ারী চালান, তবে বিভিন্ন মূলধন দিয়ে ...
mysql> SELECT * FROM junk where id = 2;
এই ক্যোয়ারীটি আলাদাভাবে ক্যাশে করা হয়েছিল। মোট ব্লকগুলি কেবলমাত্র 2 টি বৃদ্ধি পেয়েছে কারণ আমাদের কাছে ইতিমধ্যে টেবিলের জন্য একটি ব্লক বরাদ্দ ছিল।
+-------------------------+----------+
| Variable_name | Value |
+-------------------------+----------+
| Qcache_free_blocks | 1 |
| Qcache_free_memory | 67088560 |
| Qcache_inserts | 2 |
| Qcache_queries_in_cache | 2 |
| Qcache_total_blocks | 6 |
+-------------------------+----------+
এখন, আমরা টেবিলের একটি পৃথক সারি পরিবর্তন করি ।
mysql> update junk set things = 'items' where id = 1;
উভয় জিজ্ঞাসা এবং সারণী রেফারেন্স ক্যাশে থেকে অবৈধ হয়, আমাদের 1 টি স্বতন্ত্র ফ্রি ব্লক, সমস্ত ক্যাশে মেমরি মুক্ত করে এবং সমস্ত ব্লক একত্রিত করে সমস্ত ফাঁকা স্থান রেখে দেয়।
+-------------------------+----------+
| Variable_name | Value |
+-------------------------+----------+
| Qcache_free_blocks | 1 |
| Qcache_free_memory | 67091120 |
| Qcache_queries_in_cache | 0 |
| Qcache_total_blocks | 1 |
+-------------------------+----------+
মাইএসকিউএল ক্যাশে এমন কোনও ক্যোয়ারী সংরক্ষণ করবে না যা নির্জনবাদী নয় - যেমন SELECT NOW();
বা এমন কোনও কোয়েরি যা আপনি এটি বিশেষভাবে ক্যাশে না বলুন। SELECT SQL_NO_CACHE ...
ক্যাশে ফলাফল সংরক্ষণ না করার জন্য সার্ভারকে বলা নির্দেশ is ক্যাশে আপনাকে পরবর্তী মৃত্যুদন্ড কার্যকর করার ক্ষেত্রে একটি ছদ্মবেশী দ্রুত প্রতিক্রিয়া দিচ্ছিল যখন কোনও প্রশ্নের সত্যিকারের মৃত্যুদণ্ডের সময়কে বেঞ্চমার্ক করার জন্য এটি দরকারী।