मेरे पास पूरी तरह से InnoDB तालिकाओं के साथ एक व्यस्त डेटाबेस है जो आकार में लगभग 5GB है। डेटाबेस SSD डिस्क का उपयोग करते हुए एक डेबियन सर्वर पर चलता है और मैंने अधिकतम कनेक्शन = 800 सेट किया है जो कभी-कभी संतृप्त होता है और सर्वर को रोकने के लिए पीसता है। प्रति सेकंड औसत क्वेरी लगभग 2.5K है। इसलिए मुझे अधिकतम संभव कनेक्शन के लिए जगह बनाने के लिए मेमोरी उपयोग को अनुकूलित करना होगा।
मैंने सुझाव दिया है कि innodb_buffer_pool_size कुल मेमोरी का 80% तक होना चाहिए। दूसरी ओर मुझे ट्यूनिंग-प्राइमर स्क्रिप्ट से यह चेतावनी मिलती है:
Max Memory Ever Allocated : 91.97 G
Configured Max Per-thread Buffers : 72.02 G
Configured Max Global Buffers : 19.86 G
Configured Max Memory Limit : 91.88 G
Physical Memory : 94.58 G
यहाँ मेरे वर्तमान असंख्य चर हैं:
| innodb_adaptive_flushing | ON |
| innodb_adaptive_hash_index | ON |
| innodb_additional_mem_pool_size | 20971520 |
| innodb_autoextend_increment | 8 |
| innodb_autoinc_lock_mode | 1 |
| innodb_buffer_pool_instances | 1 |
| innodb_buffer_pool_size | 20971520000 |
| innodb_change_buffering | all |
| innodb_checksums | ON |
| innodb_commit_concurrency | 0 |
| innodb_concurrency_tickets | 500 |
| innodb_data_file_path | ibdata1:10M:autoextend |
| innodb_data_home_dir | |
| innodb_doublewrite | ON |
| innodb_fast_shutdown | 1 |
| innodb_file_format | Antelope |
| innodb_file_format_check | ON |
| innodb_file_format_max | Antelope |
| innodb_file_per_table | ON |
| innodb_flush_log_at_trx_commit | 2 |
| innodb_flush_method | O_DIRECT |
| innodb_force_load_corrupted | OFF |
| innodb_force_recovery | 0 |
| innodb_io_capacity | 200 |
| innodb_large_prefix | OFF |
| innodb_lock_wait_timeout | 50 |
| innodb_locks_unsafe_for_binlog | OFF |
| innodb_log_buffer_size | 4194304 |
| innodb_log_file_size | 524288000 |
| innodb_log_files_in_group | 2 |
| innodb_log_group_home_dir | ./ |
| innodb_max_dirty_pages_pct | 75 |
| innodb_max_purge_lag | 0 |
| innodb_mirrored_log_groups | 1 |
| innodb_old_blocks_pct | 37 |
| innodb_old_blocks_time | 0 |
| innodb_open_files | 300 |
| innodb_purge_batch_size | 20 |
| innodb_purge_threads | 0 |
| innodb_random_read_ahead | OFF |
| innodb_read_ahead_threshold | 56 |
| innodb_read_io_threads | 4 |
| innodb_replication_delay | 0 |
| innodb_rollback_on_timeout | OFF |
| innodb_rollback_segments | 128 |
| innodb_spin_wait_delay | 6 |
| innodb_stats_method | nulls_equal |
| innodb_stats_on_metadata | ON |
| innodb_stats_sample_pages | 8 |
| innodb_strict_mode | OFF |
| innodb_support_xa | ON |
| innodb_sync_spin_loops | 30 |
| innodb_table_locks | ON |
| innodb_thread_concurrency | 4 |
| innodb_thread_sleep_delay | 10000 |
| innodb_use_native_aio | ON |
| innodb_use_sys_malloc | ON |
| innodb_version | 1.1.8 |
| innodb_write_io_threads | 4 |
एक साइड नोट जो प्रासंगिक हो सकता है: मैं देखता हूं कि जब मैं एक बड़े पोस्ट (10KB से अधिक) को Drupal (जो एक अलग वेब सर्वर पर बैठता है) से डेटाबेस में डालने की कोशिश करता हूं, तो यह हमेशा के लिए रहता है और पेज सही से वापस नहीं आता है।
इन के बारे में, मैं सोच रहा हूँ कि इष्टतम प्रदर्शन के लिए मेरा innodb_buffer_pool_size क्या होना चाहिए। मैं इस परिदृश्य के लिए इस और अन्य मापदंडों को निर्धारित करने के लिए आपके सुझावों की सराहना करता हूं।
SELECT (PagesData*PageSize)/POWER(1024,3) DataGB FROM...
MySQL 5.7 पर निम्न त्रुटि उत्पन्न करता है: " 'INFORMATION_SCHEMA.GLOBAL_STATUS' सुविधा अक्षम है, 'show_compatibility_56' के लिए दस्तावेज़ देखें "। क्या आपके पास किसी भी संयोग से एक अद्यतन संस्करण होगा?