MySQL (MariaDB) अक्सर क्रैश हो जाता है


9

मैंने हाल ही में एक पुराने सर्वर को माइएसक्यूएल चलाकर एक नया वीपीएस चला रहा है जो कि मारबीडीबी 5.5 चला रहा है। मेरे पास सर्वर (सिर्फ कुछ PHP साइट्स) पर बहुत ज्यादा रनिंग नहीं है और फ्री मेमोरी ठीक लगती है, लेकिन डीबी क्रैश होता रहता है - कभी-कभी हर कुछ दिनों में, दूसरी बार कुछ घंटों में।

मुझे लॉग में निम्नलिखित त्रुटियां प्राप्त होती हैं:

131231  1:43:04 [ERROR] mysqld: Out of memory (Needed 128917504 bytes)
131231  1:43:04 [ERROR] mysqld: Out of memory (Needed 96681984 bytes)
131231  1:43:04 [ERROR] mysqld: Out of memory (Needed 72499200 bytes)
131231  1:43:04 [ERROR] mysqld: Out of memory (Needed 54362112 bytes)
131231  1:43:04 InnoDB: The InnoDB memory heap is disabled
131231  1:43:04 InnoDB: Mutexes and rw_locks use GCC atomic builtins
131231  1:43:04 InnoDB: Compressed tables use zlib 1.2.3.4
131231  1:43:04 InnoDB: Using Linux native AIO
131231  1:43:04 InnoDB: Initializing buffer pool, size = 128.0M
InnoDB: mmap(137756672 bytes) failed; errno 12
131231  1:43:04 InnoDB: Completed initialization of buffer pool
131231  1:43:04 InnoDB: Fatal error: cannot allocate memory for the buffer pool
131231  1:43:04 [ERROR] Plugin 'InnoDB' init function returned error.
131231  1:43:04 [ERROR] Plugin 'InnoDB' registration as a STORAGE ENGINE failed.
131231  1:43:04 [Note] Plugin 'FEEDBACK' is disabled.
131231  1:43:04 [ERROR] Unknown/unsupported storage engine: InnoDB
131231  1:43:04 [ERROR] Aborting

131231  1:43:04 [Note] /usr/sbin/mysqld: Shutdown complete

मैंने InnoDB हीप के लिए my.cnf सेटिंग्स के साथ खेला है, जो मदद के लिए प्रतीत नहीं होता है। यहाँ प्रासंगिक हिस्सा है:

innodb_buffer_pool_size = 128M
innodb_log_buffer_size  = 8M
innodb_file_per_table   = 1
innodb_open_files       = 400
innodb_io_capacity      = 400
innodb_flush_method     = O_DIRECT

मुझे लगता है कि मुफ्त रैम के "बहुत" हैं, और मेरे पास कुछ स्वैप भी उपलब्ध हैं:

root@phoenix:~# free -m
             total       used       free     shared    buffers     cached
Mem:           994        923         71          0         19        417
-/+ buffers/cache:        486        508
Swap:         1023        131        892

मैं इस समस्या को कैसे हल / निवारण कर सकता हूं? मैं सुराग के लिए interwebz scoured है, लेकिन कुछ भी मदद नहीं की है।


1
क्रैश होने से पहले मेमोरी ठीक क्या लगती है? [ERROR] mysqld: Out of memoryयकीन है कि लगता है एक मजबूत संकेत की तरह। क्या आपने यह देखने के लिए कि क्या कर्नेल (OOM) ने mysql को मारने का फैसला किया है, अपने सिस्टम लॉग्स की जाँच करें?
ज़ॉर्दाचे

आपको दुर्घटना से पहले और बाद में उपयोग किए जाने वाले फ़ाइल हैंडल को लॉग इन करना चाहिए और topदुर्घटना के कारण क्या हो सकता है, यह जानने के लिए दुर्घटना के बाद (शायद हर अंतराल के डंप भी )। आपके सर्वर में mysql (mariadb) जैसी कोई अन्य सेवाएं चलती हैं?
अश्विन कुमार

1
DBA पर एक बहुत अच्छा जवाब है जो मददगार लगता है: dba.stackexchange.com/questions/1927/…
मैट हैमन

प्रदर्शन_श्रेमा = बंद करके देखें?

जवाबों:


9

मुझे उम्मीद है कि यह आपके लिए उपयोगी होगा।

प्रयत्न

performance_schema = off

में [mysqld]आपके विन्यास की धारा।

https://mariadb.com/resources/blog/starting-mysql-on-low-memory-virtual-machines/


यह एक कोशिश दे रही है। रिपोर्ट जारी करने और कुछ दिन चलने के बाद सेवा वापस देने के तुरंत बाद रिपोर्ट करूंगा।
मैट हमन

लगता है काफी मदद की है। यकीन नहीं है कि 100% हल हो गया है, लेकिन जब से मैंने इसे समायोजित किया है, यह बहुत अच्छा चल रहा है। धन्यवाद।
मैट हमन
हमारी साइट का प्रयोग करके, आप स्वीकार करते हैं कि आपने हमारी Cookie Policy और निजता नीति को पढ़ और समझा लिया है।
Licensed under cc by-sa 3.0 with attribution required.