2010-10-12 11 views
10

मैं अपने MySQL प्रक्रिया के साथ एक 'बहुत सारे कनेक्शन' समस्या लड़ रहा हूं और मुझे बात करने के लिए मिल गया है जब mysqladmin processlist -uroot -pXXXXX परिणामों में:मैं यूनिक्स प्रक्रिया को कैसे ढूंढ सकता हूं जो स्थानीय स्लीपिंग MySQL कनेक्शन का मालिक है?

+------+------------+-----------+------------+---------+------+-------+------------------+ 
| Id | User  | Host  | db   | Command | Time | State | Info    | 
+------+------------+-----------+------------+---------+------+-------+------------------+ 
| 842 | svcControl | localhost | svcObjects | Sleep | 1772 |  |     | 
| 875 | svcControl | localhost | svcObjects | Sleep | 1773 |  |     | 
| 884 | svcControl | localhost | svcObjects | Sleep | 1770 |  |     | 
| 896 | svcControl | localhost | svcObjects | Sleep | 1540 |  |     | 
| 951 | svcControl | localhost | svcObjects | Sleep | 709 |  |     | 
| 1023 | svcControl | localhost | svcObjects | Sleep | 708 |  |     | 
| 1063 | svcControl | localhost | svcObjects | Sleep | 708 |  |     | 
| 1069 | svcControl | localhost | svcObjects | Sleep | 708 |  |     | 
| 1075 | svcControl | localhost | svcObjects | Sleep | 707 |  |     | 
| 1083 | svcControl | localhost | svcObjects | Sleep | 707 |  |     | 
| 1091 | svcControl | localhost | svcObjects | Sleep | 706 |  |     | 
| 1097 | svcControl | localhost | svcObjects | Sleep | 706 |  |     | 
| 1107 | svcControl | localhost | svcObjects | Sleep | 705 |  |     | 
| 1112 | svcControl | localhost | svcObjects | Sleep | 702 |  |     | 
| 1120 | svcControl | localhost | svcObjects | Sleep | 704 |  |     | 
| 1127 | svcControl | localhost | svcObjects | Sleep | 704 |  |     | 
| 1136 | svcControl | localhost | svcObjects | Sleep | 704 |  |     | 
| 1141 | svcControl | localhost | svcObjects | Sleep | 644 |  |     | 
| 1202 | svcControl | localhost | svcObjects | Sleep | 268 |  |     | 
| 1222 | svcView | localhost | svcObjects | Sleep | 8 |  |     | 
| 1224 | svcControl | localhost | svcObjects | Sleep | 280 |  |     | 
| 1225 | svcControl | localhost | svcObjects | Sleep | 8 |  |     | 
| 1265 | root  | localhost |   | Query | 0 |  | show processlist | 
+------+------------+-----------+------------+---------+------+-------+------------------+ 

तो, स्पष्ट रूप से, मैं कनेक्शन कहीं लीक कर रहा हूँ, लेकिन मैं कहां से पता नहीं लगा सकता। मैं उन स्रोतों की तलाश कर रहा हूं जो मुझे बताते हैं कि कनेक्शन आईडी से यूनिक्स प्रोसेस आईडी में कैसे पहुंचे, लेकिन अधिकांश दृष्टिकोण कनेक्शन को दूरस्थ सर्वर से होने की उम्मीद करते हैं, जिससे आप उन्हें डीबग करने के लिए नेटस्टैट का उपयोग कर सकते हैं। या तो, या उन्हें आपके कोडबेस को प्रत्येक प्रयास किए गए कनेक्शन को लॉग इन करने के लिए संशोधित करने की आवश्यकता होती है, जो कि ओवरकिल की तरह थोड़ा लगता है।

तो ... क्या कोई दृष्टिकोण है जिसके बारे में कोई जानता है? कोई भी फाइल जो इस नींद कनेक्शन को खुलेगी, ताकि मैं फ्यूसर का उपयोग कर सकूं, उदाहरण के लिए? या ... क्या यह संभव है कि ये ज़ोंबी कनेक्शन हैं जिनके पास कोई स्वामित्व वाली प्रक्रिया नहीं है?

अगर मैं ps -ef | grep mysql चलाने नीचे जवाब के जवाब में, मैं देख रहा हूँ:

root  5960  1 0 Oct14 ?  00:00:00 /bin/sh /usr/bin/mysqld_safe --datadir=/var/lib/mysql --socket=/var/lib/mysql/mysql.sock --log-error=/var/log/mysqld.log --pid-file=/var/run/mysqld/mysqld.pid --user=mysql 
mysql  6007 5960 0 Oct14 ?  00:24:12 /usr/libexec/mysqld --basedir=/usr --datadir=/var/lib/mysql --user=mysql --pid-file=/var/run/mysqld/mysqld.pid --skip-external-locking --socket=/var/lib/mysql/mysql.sock 

का सुझाव आदेशों चल रहा है, मैं:

# fuser -u /var/lib/mysql/mysql.sock 
/var/lib/mysql/mysql.sock: 6007(mysql) 

# lsof -p 5960 
COMMAND PID USER FD TYPE DEVICE  SIZE NODE NAME 
mysqld_sa 5960 root cwd DIR 8,1  4096  2/
mysqld_sa 5960 root rtd DIR 8,1  4096  2/
mysqld_sa 5960 root txt REG 8,1 735004 117216 /bin/bash 
mysqld_sa 5960 root mem REG 8,1 50848 9/lib/libnss_files-2.5.so 
mysqld_sa 5960 root mem REG 8,1 129832 87812 /lib/ld-2.5.so 
mysqld_sa 5960 root mem REG 8,1 1689388 90858 /lib/libc-2.5.so 
mysqld_sa 5960 root mem REG 8,1 20668 90874 /lib/libdl-2.5.so 
mysqld_sa 5960 root mem REG 8,1 13276 91815 /lib/libtermcap.so.2.0.8 
mysqld_sa 5960 root mem REG 253,18 56418144 656494 /usr/lib/locale/locale-archive 
mysqld_sa 5960 root mem REG 253,18 25462 1573763 /usr/lib/gconv/gconv-modules.cache 
mysqld_sa 5960 root 0r CHR 1,3    1432 /dev/null 
mysqld_sa 5960 root 1w CHR 1,3    1432 /dev/null 
mysqld_sa 5960 root 2w CHR 1,3    1432 /dev/null 
mysqld_sa 5960 root 255r REG 253,18 13077 1181028 /usr/bin/mysqld_safe 

lsof -p 6007 
COMMAND PID USER FD TYPE  DEVICE  SIZE  NODE NAME 
mysqld 6007 mysql cwd DIR  253,19  4096 33005 /var/lib/mysql 
mysqld 6007 mysql rtd DIR  8,1  4096  2/
mysqld 6007 mysql txt REG  253,18 7413588 1998921 /usr/libexec/mysqld 
mysqld 6007 mysql mem REG  8,1 1296932 91720 /lib/libcrypto.so.0.9.8e 
mysqld 6007 mysql mem REG  253,18 612180 1514570 /usr/lib/libkrb5.so.3.3 
mysqld 6007 mysql mem REG  8,1 293108 91722 /lib/libssl.so.0.9.8e 
mysqld 6007 mysql mem REG  8,1 3200288 87758 /lib/libnss_ldap-2.5.so 
mysqld 6007 mysql mem REG  8,1  21948 90121 /lib/libnss_dns-2.5.so 
mysqld 6007 mysql mem REG  8,1 129832 87812 /lib/ld-2.5.so 
mysqld 6007 mysql mem REG  8,1 1689388 90858 /lib/libc-2.5.so 
mysqld 6007 mysql mem REG  8,1 216544 90877 /lib/libm-2.5.so 
mysqld 6007 mysql mem REG  8,1  20668 90874 /lib/libdl-2.5.so 
mysqld 6007 mysql mem REG  8,1 137908 90866 /lib/libpthread-2.5.so 
mysqld 6007 mysql mem REG  253,18  75284 1514584 /usr/lib/libz.so.1.2.3 
mysqld 6007 mysql mem REG  8,1  48156 90867 /lib/librt-2.5.so 
mysqld 6007 mysql mem REG  8,1  50848 9/lib/libnss_files-2.5.so 
mysqld 6007 mysql mem REG  8,1 245376 90881 /lib/libsepol.so.1 
mysqld 6007 mysql mem REG  8,1  93508 91676 /lib/libselinux.so.1 
mysqld 6007 mysql mem REG  8,1  46636 90847 /lib/libgcc_s-4.1.2-20080825.so.1 
mysqld 6007 mysql mem REG  253,18 936908 1514611 /usr/lib/libstdc++.so.6.0.8 
mysqld 6007 mysql mem REG  8,1 109740 90873 /lib/libnsl-2.5.so 
mysqld 6007 mysql mem REG  8,1  80636 90879 /lib/libresolv-2.5.so 
mysqld 6007 mysql mem REG  8,1  7748 91684 /lib/libcom_err.so.2.1 
mysqld 6007 mysql mem REG  253,18 190712 1514583 /usr/lib/libgssapi_krb5.so.2.2 
mysqld 6007 mysql mem REG  253,18 157304 1514569 /usr/lib/libk5crypto.so.3.1 
mysqld 6007 mysql mem REG  8,1  8072 90878 /lib/libkeyutils-1.2.so 
mysqld 6007 mysql mem REG  253,18  33712 1509918 /usr/lib/libkrb5support.so.0.1 
mysqld 6007 mysql mem REG  8,1  45432 90876 /lib/libcrypt-2.5.so 
mysqld 6007 mysql 0r CHR  1,3    1432 /dev/null 
mysqld 6007 mysql 1w REG  253,19 251337 163863 /var/log/mysqld.log 
mysqld 6007 mysql 2w REG  253,19 251337 163863 /var/log/mysqld.log 
mysqld 6007 mysql 3u IPv4 26825288    TCP monstermunch.ssd.hursley.ibm.com:59850->hurgsa.hursley.uk.ibm.com:ldap (CLOSE_WAIT) 
mysqld 6007 mysql 4uW REG  253,19 161480704 33142 /var/lib/mysql/ibdata1 
mysqld 6007 mysql 5u REG  253,16   0  13 /tmp/ibmydRNj (deleted) 
mysqld 6007 mysql 6u REG  253,16  20  14 /tmp/ib59yuxj (deleted) 
mysqld 6007 mysql 7u REG  253,16   0  15 /tmp/ib0Vp8gj (deleted) 
mysqld 6007 mysql 8u REG  253,16   0  16 /tmp/ibjkCG1i (deleted) 
mysqld 6007 mysql 9uW REG  253,19 5242880 33143 /var/lib/mysql/ib_logfile0 
mysqld 6007 mysql 10uW REG  253,19 5242880 33144 /var/lib/mysql/ib_logfile1 
mysqld 6007 mysql 11u IPv4 26825294    TCP *:mysql (LISTEN) 
mysqld 6007 mysql 12u REG  253,16   0  17 /tmp/ibKpCJ1i (deleted) 
mysqld 6007 mysql 13u unix 0xea432900   26825295 /var/lib/mysql/mysql.sock 
mysqld 6007 mysql 14u REG  253,19  30720 65557 <DB Table> 
mysqld 6007 mysql 15u unix 0xf5188c80   30430332 /var/lib/mysql/mysql.sock 
mysqld 6007 mysql 16u REG  253,19  3072 98468 <DB Table> 
mysqld 6007 mysql 17u unix 0xf5925680   30433174 /var/lib/mysql/mysql.sock 
mysqld 6007 mysql 18u REG  253,19  1024 65605 <DB Table> 
mysqld 6007 mysql 19u unix 0xf5188880   30430336 /var/lib/mysql/mysql.sock 
mysqld 6007 mysql 20u REG  253,19  40 98469 <DB Table> 
mysqld 6007 mysql 21u unix 0xf5925280   30433176 /var/lib/mysql/mysql.sock 
mysqld 6007 mysql 22u REG  253,19  39344 65558 <DB Table> 
mysqld 6007 mysql 23u REG  253,19  1024 65623 <DB Table> 
mysqld 6007 mysql 24u REG  253,19   0 65624 <DB Table> 
mysqld 6007 mysql 25u unix 0xf51f6880   30430339 /var/lib/mysql/mysql.sock 

ऊपर उत्पादन में, <DB Table> मेरा संपादन है।

मुझे कुछ याद आ रहा है, लेकिन मुझे वहां कुछ भी दिखाई नहीं दे रहा है जो मेरा कनेक्शन खोलने की प्रक्रिया है ... जब तक कि हटाई गई/टीएमपी फाइलें महत्वपूर्ण न हों।

उत्तर

5

यदि कनेक्शन स्थानीय सॉकेट पर बनाए गए थे, तो आपके पास sudo fuser -u /tmp/mysql.sock के साथ कुछ भाग्य हो सकता है। आप MySQL की प्रक्रिया आईडी भी ढूंढ सकते हैं (चलो इसे $MYSQL_PID पर कॉल करें) और फिर sudo lsof -p $MYSQL_PID चलाएं, जिसमें सभी खुले सॉकेट शामिल होंगे।

+0

कृपया प्रश्न करने के लिए अपने को अपडेट हुआ; इससे मदद नहीं मिली, जब तक कि मुझे कुछ याद नहीं आ रहा है। – Dancrumb

+0

'फ्यूसर' आउटपुट से पता चलता है कि 'mysqld' सॉकेट '/ var/lib/mysql/mysql.sock' पर सुन रहा है, लेकिन कोई स्थानीय प्रक्रिया नहीं खुलती है। –

+0

'mysqld' के लिए 'lsof' आउटपुट से पता चलता है कि यह एफडी 11 पर आने वाले आईपीवी 4 कनेक्शन के लिए सुन रहा है, लेकिन इसे प्राप्त कोई कनेक्शन अभी भी खुला नहीं है। MySQL सॉकेट के लिए 6 एफडीएस खुले हैं; मुझे नहीं पता कि वे क्या कर रहे हैं। 'lsof/var/lib/mysql/mysql.sock' को उस सॉकेट के साथ सभी प्रक्रियाओं को सूचीबद्ध करना चाहिए। –

-1

जांचें कि कौन सा एप्लिकेशन उपयोगकर्ता "svcControl" डेटाबेस के साथ "svcObjects" डेटाबेस का उपयोग करता है। इससे मुझे लगता है कि समस्या की जड़ आपको ले जाएगा।

1

यदि आप कर सकते हैं, तो स्थानीयहोस्ट के बजाय 127.0.0.1 का उपयोग करके आप MySQL सर्वर से कनेक्ट करने के तरीके को बदल सकते हैं।

ऐसा करके, एक टीसीपी/आईपी कनेक्शन का उपयोग किया जाएगा और आपके पास उस प्रक्रिया संख्या में प्रक्रिया होगी जो आप प्रक्रिया पर वापस जाने के लिए उपयोग कर सकते हैं।

एक टीसीपी/आईपी कनेक्शन यूनिक्स फ़ाइल सॉकेट कनेक्शन से धीमा है, लेकिन यह चाल करेगा।

संदर्भ:

http://dev.mysql.com/doc/refman/5.1/en/can-not-connect-to-server.html

http://dev.mysql.com/doc/refman/5.1/en/connecting.html

संबंधित मुद्दे