माई एसक्यूएल। यूनिक्स सॉकेट पर बांधें: अनुमति से इनकार किया


12

के साथ mysql शुरू नहीं कर सकते:

130408 11:31:22 mysqld_safe Starting mysqld daemon with databases from /var/lib/mysql
/usr/libexec/mysqld: Table 'plugin' is read only
130408 11:31:22 [ERROR] Can't open the mysql.plugin table. Please run mysql_upgrade to create it.
130408 11:31:22  InnoDB: Initializing buffer pool, size = 8.0M
130408 11:31:22  InnoDB: Completed initialization of buffer pool
130408 11:31:23  InnoDB: Started; log sequence number 0 19514977
130408 11:31:23 [ERROR] Can't start server : Bind on unix socket: Permission denied
130408 11:31:23 [ERROR] Do you already have another mysqld server running on socket: /var/lib/mysql/mysql.sock ?
130408 11:31:23 [ERROR] Aborting

130408 11:31:23  InnoDB: Starting shutdown...
130408 11:31:28  InnoDB: Shutdown completed; log sequence number 0 19514977
130408 11:31:28 [Note] /usr/libexec/mysqld: Shutdown complete
130408 11:31:28 mysqld_safe mysqld from pid file /var/run/mysqld/mysqld.pid ended

एक अन्य mysql runnig नहीं है:

[root@triton667 etc]# ps ax | grep mysql
 9195 pts/1    S+     0:00 grep mysql

my.cnf:

    [mysqld]
    datadir=/var/lib/mysql
    socket=/var/lib/mysql/mysql.sock
    user=mysql
    tmpdir=/tmp
    # Disabling symbolic-links is recommended to prevent assorted security risks
    symbolic-links=0
    max_allowed_packet=256M

    [mysqld_safe]

    log-error=/var/log/mysqld.log
    pid-file=/var/run/mysqld/mysqld.pid

"/ Tmp" और "/ var / lib / mysql" पर अनुमतियाँ 777 / हैं

कोई सुझाव?

UPD1 :

[root@triton667 etc]# mysql_upgrade
Looking for 'mysql' as: mysql
Looking for 'mysqlcheck' as: mysqlcheck
Running 'mysqlcheck with default connection arguments
mysqlcheck: Got error: 2002: Can't connect to local MySQL server through socket '/var/lib/mysql/mysql.sock' (2) trying to connect
FATAL ERROR: Upgrade failed

UPD2 : plugin.MYD, plugin.MYI और plugin.frm / var / lib / mysql / mysql / में मौजूद हैं।

पोर्ट 3306 पर कुछ भी नहीं चल रहा है।

mysql.sock मौजूद नहीं है। मैंने इसे स्वयं बनाने का प्रयास किया, लेकिन पुनः आरंभ करने के बाद इसे हटा दिया गया।

माउंट (सभी आरडब्ल्यू):

[root@triton667 mysql]# mount
/dev/md1 on / type ext4 (rw,noatime,usrjquota=aquota.user,grpjquota=aquota.group,jqfmt=vfsv0)
proc on /proc type proc (rw)
sysfs on /sys type sysfs (rw)
devpts on /dev/pts type devpts (rw,gid=5,mode=620)
tmpfs on /dev/shm type tmpfs (rw)
/dev/md0 on /boot type ext2 (rw)
none on /proc/sys/fs/binfmt_misc type binfmt_misc (rw)
sunrpc on /var/lib/nfs/rpc_pipefs type rpc_pipefs (rw)
nfsd on /proc/fs/nfsd type nfsd (rw)

यह समस्या आज दिखाई दी जब मैंने एक उपडोमेन पर अपनी साइट को क्लोन करने की कोशिश की।


mysql_upgradeसुझाव के अनुसार चलाएं ?
निकव

नहीं स्पर्श /वर / लिब/mysql/mysql.sock - इसके अलावा काम नहीं करता है
Aldwin

क्या कोई plugin.MYD, plugin.MYI और plugin.frm फ़ाइल है / var / lib / mysql / mykql के तहत?
निकव

इसके अलावा, क्या mysql.sock फ़ाइल / var / lib / mysql निर्देशिका में मौजूद है?
निकव

क्या पहले से ही 3306 पोर्ट पर कुछ चल रहा है?
अद्र्वार्क

जवाबों:


15

1) पहले सुनिश्चित करें कि आप rm कमांड का उपयोग करके मौजूदा सॉकेट फ़ाइल को हटा दें।

rm /var/lib/mysql/mysql.sock

2) निम्नलिखित कमांड के माध्यम से सभी मौजूदा MySQL प्रक्रियाओं को मारें।

service mysql stop

3) बहुत महत्वपूर्ण: सुनिश्चित करें कि /var/lib/फ़ोल्डर के तहत MySQL डेटाबेस डायरेक्टरी की अनुमति mysql: root होनी चाहिए

chown -R mysql:root /var/lib/mysql

4) उपरोक्त जानकारी के साथ आपको MySQL को सफलतापूर्वक शुरू करने में सक्षम होना चाहिए और डेटाबेस निर्देशिका के तहत सॉकेट फ़ाइल को सफलतापूर्वक बनाया जाना चाहिए।

service mysql start

मैं एक Ubuntu सर्वर का उपयोग करता हूं, और यह काम नहीं किया।
विटोर मजूको

6

@ अभिषेक के जवाब के साथ mysqld आउटपुट के साथ संयुक्त धन्यवाद (मैं /var/run/mysqld/mysqld.sock का उपयोग नहीं कर सकता) मैं इसे एक आदेश के साथ हल करने में कामयाब रहा:

chown -R mysql:root /var/run/mysqld

फिर यह ठीक से शुरू होता है:

root@***:~# service mysql start
df: Warning: cannot read table of mounted file systems: No such file or directory
[ ok ] Starting MySQL database server: mysqld ..
[info] Checking for tables which need an upgrade, are corrupt or were 
not closed cleanly..

1
भविष्य से आपका स्वागत है :)
डैनियल Kmak

3

आपकी समस्या किसी भी स्थिति के कारण हो सकती है जो MySQL डेमन को सॉकेट फ़ाइल को पथ पर लिखने से रोकती है /var/lib/mysql। अन्य उत्तर, जैसे कि केवल-पढ़ने के लिए फ़ाइल सिस्टम या गलत निर्देशिका स्वामित्व, विभिन्न कारणों को संबोधित करते हैं जो MySQL सॉकेट में लिखने में सक्षम नहीं हो सकते हैं।

दूसरा संभावित कारण /var/lib/mysqlगलत SELinux संदर्भ हो सकता है। MySQL डेमॉन शुरू करने के प्रयास के बाद हाल ही में SELinux AVC इनकार के लिए जाँच कर आप इस स्थिति का निदान कर सकते हैं:

ausearch -m avc --start recent

यदि SELinux सॉकेट फ़ाइल बनाने के लिए पहुँच से इनकार कर रहा है, तो आपको इस तरह एक त्रुटि संदेश दिखाई देगा:

time->Thu Feb  2 03:46:27 2017
type=SYSCALL msg=audit(1566106187.784:152): arch=c000004e syscall=49 success=no exit=-13 a0=4f a1=7ff3fd652e80 a2=6e a3=7fcd2d6523d40 items=0 ppid=1 pid=1820 auid=4294967295 uid=996 gid=994 euid=996 suid=996 fsuid=996 egid=994 sgid=994 fsgid=994 tty=(none) ses=4294967295 comm="mysqld" exe="/usr/sbin/mysqld" subj=system_u:system_r:mysqld_t:s0 key=(null)
type=AVC msg=audit(1566106187.784:152): avc:  denied  { create } for  pid=1820 comm="mysqld" name="mysql.sock" scontext=system_u:system_r:mysqld_t:s0 tcontext=system_u:object_r:var_log_t:s0 tclass=sock_file

SELinux इनकार को हल करने के लिए, निर्देशिका के डिफ़ॉल्ट संदर्भ को पुनर्स्थापित करने का प्रयास करें (आपका वितरण mysqld_db_tMySQL या MariaDB स्थापित करते समय सही संदर्भ सेट करना चाहिए ):

restorecon -R -v -f /var/lib/mysql

यदि आपने अपने सिस्टम पर संदर्भों को अनुकूलित किया है, तो समस्या को ठीक करना इस पद के दायरे से परे है।


SELOS के साथ CentOS 7 पर यह वही है जो मैं सामना कर रहा था और इसे ठीक करने वाले संदर्भ को पुनर्स्थापित कर रहा था।
केन जे

1

आप जो लिखते हैं उसके आधार पर, मैं आपको सुझाव दूंगा कि आप जांच करें कि क्या आपका फाइल-सिस्टम केवल पढ़ने योग्य है।

130408 ​​11:31:22 mysqld_safe / var / lib / mysql / usr / libexec / mysqld से डेटाबेस के साथ mysqld डेमन शुरू करना: टेबल 'प्लगइन' केवल पढ़ा जाता है


0

मैंने अन्य सभी उत्तरों को हल करने की कोशिश की। ऐसा प्रतीत होता है कि जब मैंने अनुमेय को सेलिनक्स सेट किया: setenforce 0मैं सर्वर को शुरू कर सकता था।

मैंने तब निर्देशिका में /var/lib/mysqlselinux अनुमतियाँ देने वाली जुर्राब निर्देशिका में संशोधन किया :

semanage fcontext -a -t mysqld_db_t "/var/lib/mysql(/.*)?"
restorecon -R -v -f /var/lib/mysql

एक बार किया, मैं selinux सक्षम setenforce 1mysql सेवा का उपयोग कर शुरू किया और सब कुछ ठीक था।

आशा है कि यह दूसरों की मदद करता है।

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