মাইএসকিএল ডাটাবেসে অনেকগুলি টেবিলের কার্যকারিতা প্রভাবিত করতে পারে?


10

একটি একক মাইএসকিএল ডাটাবেসের উদাহরণে খুব বেশি টেবিল (উদাহরণস্বরূপ 200) থাকা কি এটির কার্যকারিতা হ্রাস করতে পারে?

উত্তর:


8

সাধারণভাবে, আপনার কাছে যত কিছু আছে তার কার্যকারিতা হ্রাস পাবে। তবে, 200 মোটামুটি ছোট সংখ্যার মতো বলে মনে হচ্ছে। 2,000 একটি বাস্তব পারফরম্যান্স হিট এবং অবশ্যই 20,000 হতে পারে। যদিও সাধারণভাবে, আপনার নিজের টেবিলের সংখ্যা ছোট রাখতে হবে যেহেতু মাইএসকিউএল টেবিলে খুব বড় সংখ্যক সারি পরিচালনা করতে পারে।


7
আপনার অ্যাপ্লিকেশন যদি 'তথ্য_সেমিমা' ব্যবহার করে তবে একটি বিশাল সংখ্যক সারণী বিশাল পার্থক্য আনতে পারে। 'ইনফরমেশন_সেমিমা'-তে কিছুই ক্যাশে হয় না। বেশ কয়েকটি বিভিন্ন ওআরএম সিস্টেম এটির ভারী ব্যবহার করে।
জোড়াদেচে


4

সারণীর সংখ্যা এতটা গুরুত্ব দেয় না:

  1. আপনি কী জিজ্ঞাসাবাদ চালাচ্ছেন - আপনি একক ক্যোয়ারির মধ্যে সমস্ত 200 জিজ্ঞাসা করছেন না
  2. সময়ে কোনও নির্দিষ্ট সময়ে সিস্টেমে সামগ্রিক ক্যোয়ারী লোড

অতিরিক্ত টেবিল থাকার অর্থ মেমরি এবং হার্ড ড্রাইভের জায়গা যা আবার ফিরে পাওয়া যায় এবং অন্যান্য জিনিসের জন্য ব্যবহার করা যায়। মনে রাখবেন যে আপনার টেবিলগুলি অস্বীকার করা খারাপ ডেটার ঝুঁকি বাড়ায় কারণ আপনি রেফারেন্সিয়াল অখণ্ডতা থেকে মুক্তি পাচ্ছেন rid


4

সাধারণভাবে 200 টি সারণী কোনও সমস্যা হওয়া উচিত নয় তবে এটি বেশ কয়েকটি বিষয়ের উপর নির্ভর করে।

ডেডিকেটেড মাইএসকিউএল সার্ভার বনাম সার্ভার অন্যান্য সফ্টওয়্যার, 128 এমবি বনাম 128 গিগাবাইট র‌্যাম ইত্যাদির সাথে ভাগ করেছে, কয়েকটি রেকর্ডের সাথে ছোট টেবিলগুলি ব্লবগুলি এবং কয়েক মিলিয়ন সারিগুলির সাথে টেবিল বনাম।

মাইএসকিউএলে প্রতিটি সেটিং টেবিলের কার্যকারিতা বিভিন্ন উপায়ে সেটিংস এবং একাধিক ইঞ্জিন থাকতে পারে।

মাইআইএসএএম এর প্রতি টেবিল .frm, .MYD, .MYI প্রতি সাধারণত তিনটি ফাইল থাকে

সাধারণ মোডে INNODB এর কেন্দ্রীয় ফাইলে সঞ্চিত সমস্ত ডেটা সহ .frm রয়েছে

টেবিল মোডে একটি ফাইলের INNODB এর .frm, .idb রয়েছে

টেবিল_পেন_ক্যাচ হ'ল টেবিলের সংখ্যা যা একবারে খোলা যায় (ডিফল্ট 64)। এটি আপনার স্কিমাতে সারণীর সংখ্যার চেয়ে বড় হতে পারে কারণ এটি কত সংযোগ ডিবি কে জিজ্ঞাসা করছে। 100 টি সংযোগ 3 টি টেবিলের সাথে যুক্ত হতে পারে আপনার কাছে 300 টি টেবিল ক্যাশেড এবং কোনও অস্থায়ী টেবিল রয়েছে। সাধারণত আরও জটিল একটি স্কিমা বা সংযোগ বৃহত্তর সংখ্যা।

ওপেন-ফাইলস-সীমা আমি এটি 4x টেবিল_পেন_ক্যাচে সেট করার ঝোঁক রাখি যা একটি সঠিক মান খুঁজে বের করার জন্য বিরক্ত করার চেয়ে উদার হওয়া উচিত।

মাইএসকিএল ব্যবহারকারীর জন্য অপারেটিং সিস্টেমগুলির ফাইল হ্যান্ডেল সীমাটিও একটি সমস্যা হতে পারে (লিনাক্সে ডিফল্টটি প্রায়শই 1024 হতে পারে, ব্যবহারকারীর সীমা দেখানোর জন্য উলামিট করতে পারে) এটি সংখ্যার চেয়ে কম টেবিলের সাথে সমস্যা তৈরি করতে পারে যখন সংখ্যাটি কম থাকে mysql প্রয়োজন। এটি কমপক্ষে ওপেন-ফাইল-সীমা হিসাবে একই হওয়া উচিত।

কোনও ডাটাবেসের মতোই এখানে কয়েকশো টিউনিং প্যারামিটার রয়েছে যা আপনি আপনার নির্দিষ্ট স্কিমার জন্য ডাটাবেসটিকে অনুকূল করতে সমন্বয় করতে পারেন। আপনি যদি এনডিবি ক্লাস্টার ইঞ্জিন চান তবে অতিরিক্ত ইঞ্জিনগুলি প্লাগ করতে পারেন মাইএসকিউএল এটির চেয়ে সবচেয়ে খারাপ।

http://dev.mysql.com/doc/refman/5.1/en/table-cache.html

আশা করি এটা সাহায্য করবে


2

প্রতিটি টেবিলের সূচকের জন্য মাইএসকিউএল এর নিজস্ব সূচক রয়েছে। সূচক ধরে রাখতে এবং ব্যবহার করতে মেমরি লাগে এবং সূচকের জন্য বিশ্বব্যাপী সীমা রয়েছে। যখন অনেকগুলি টেবিল থাকে সূচিগুলি সমস্ত র‍্যামে থাকতে পারে না, তাই তারা ডিস্কে যায় যা সরাসরি পারফরম্যান্সকে প্রভাবিত করে। এই উত্থাপন করার চেষ্টা করুন my.cnf: key_buffer_size=256M: এই সূচক তথ্য অধিষ্ঠিত জন্য একপাশে সরিয়ে রাখা RAM এর পরিমাণ।


1

পারি এটা? অবশ্যই। তবে আপনার অ্যাপ্লিকেশন এবং এটির অ্যাক্সেসের ধরণগুলির উপর এবং আপনি যদি মাইসাম বা ইনোডাব ব্যবহার করছেন এবং যদি ইনোডাবটি ফাইল-প্রতি-টেবিল মোডে রয়েছে এবং ইনডোডব লগের আকার কতটা নির্ভর করে। তার চেয়ে আপনার আরও বিশদ আমাদের দিতে হবে।


1

না - আমি মনে করি না যে সারণীর সংখ্যাটি আপনার সিস্টেমে পারফরম্যান্সের বাধা হয়ে দাঁড়াবে। সর্বোপরি, এগুলি আপনার ফাইল সিস্টেমে কেবল ফাইল। একটি ডাটাবেসে শত শত টেবিল থাকার বিষয়ে অস্বাভাবিক কিছু নেই।

এর চেয়ে বেশি সম্ভবত আপনার প্রশ্নগুলি সঠিকভাবে অনুকূলিত হয় নি are আমি log-slow-queriesএবং চালু করার পরামর্শ দেব log-queries-not-using-indexes। আপনি যখন ধীর explainঅনুসন্ধানগুলি শনাক্ত করেন, সূচিগুলি অনুপস্থিত রয়েছে এমন জায়গাগুলি সনাক্ত করতে এই প্রশ্নের জন্য ক্যোয়ারী পরিকল্পনাটি দেখার জন্য বিকল্পটি ব্যবহার করুন ।

আরও তথ্যের জন্য http://dev.mysql.com/doc/refman/5.0/en/slow-query-log.html দেখুন ।

আমাদের সাইট ব্যবহার করে, আপনি স্বীকার করেছেন যে আপনি আমাদের কুকি নীতি এবং গোপনীয়তা নীতিটি পড়েছেন এবং বুঝতে পেরেছেন ।
Licensed under cc by-sa 3.0 with attribution required.