Korzystam z serwera Ubuntu. Kiedy próbowałem zalogować się do mysql (który był uruchomiony), otrzymałem następujący błąd
ERROR 2002 (HY000): Can't connect to local MySQL server through socket '/var/run/mysqld/mysqld.sock' (2)
Ale plik mysqld.sock nie istnieje w /var/run/mysqld
folderze. Po uruchomieniu ps aux | grep mysql
polecenia zrozumiałem, że serwer mysql nie działa.
Następnie spróbowałem zrestartować serwer mysql przy użyciu
service mysql start
service mysql restart
/etc/init.d/mysql start
Ale proces uruchamiania nie powiódł się we wszystkich 3 przypadkach.
/var/log/mysql/mysql.log
i /var/log/mysql/mysql.err
pliki są puste.
Ale /var/log/error.log
pokazuje następujące informacje:
140425 12:49:05 [Warning] Using unique option prefix myisam-recover instead of myisam-recover-options is deprecated and will be removed in a future release. Please use the full name instead.
140425 12:49:05 [Note] Plugin 'FEDERATED' is disabled.
140425 12:49:05 InnoDB: The InnoDB memory heap is disabled
140425 12:49:05 InnoDB: Mutexes and rw_locks use GCC atomic builtins
140425 12:49:05 InnoDB: Compressed tables use zlib 1.2.8
140425 12:49:05 InnoDB: Using Linux native AIO
140425 12:49:05 InnoDB: Initializing buffer pool, size = 3.0G
140425 12:49:05 InnoDB: Completed initialization of buffer pool
InnoDB: Error: log file ./ib_logfile0 is of different size 0 5242880 bytes
InnoDB: than specified in the .cnf file 0 26214400 bytes!
140425 12:49:05 [ERROR] Plugin 'InnoDB' init function returned error.
140425 12:49:05 [ERROR] Plugin 'InnoDB' registration as a STORAGE ENGINE failed.
140425 12:49:05 [ERROR] /usr/sbin/mysqld: unknown variable 'record_buffer=64M'
140425 12:49:05 [ERROR] Aborting
140425 12:49:05 [Note] /usr/sbin/mysqld: Shutdown complete
ls /var/lib/mysql/ib_logfile*
?Odpowiedzi:
Otwórz terminal ( Ctrl+ Alt+ t) i wykonaj następujące czynności:
i skomentuj wiersz
record_buffer=64M
w/etc/mysql/my.cnf
[1]a następnie uruchom ponownie msyql, używając:
(Źródło)
źródło
sudo service mysql start
?To rozwiązało mój problem:
mkdir /var/run/mysqld
touch /var/run/mysqld/mysqld.sock
chown -R mysql /var/run/mysqld
/etc/init.d/mysql restart
źródło
Rozwiązałem problem w następujący sposób:
W innym kontekście napotkałem to, ponieważ uruchomienie demona mysql nie powiodło się. Uruchom demona za pomocą polecenia -
mysqld start
a następnie spróbuj uruchomić usługę.źródło
Miałem ten sam komunikat o błędzie i tę samą pustkę w plikach dziennika. W moim pliku konfiguracyjnym (my.cnf) podałem, że chcę używać tabel myisam, dodając ten wiersz w sekcji [mysqld]:
Po aktualizacji mysql wydaje się, że powoduje to, że mysql się nie uruchamia. Zmieniłem to na:
a teraz wszystko działa dobrze.
źródło
Pomocne może być również zwiększenie dostępnej pamięci RAM poprzez dodanie nowej przestrzeni wymiany. Kroki są tutaj
Upewnij się, że utworzyłeś / zamieniasz plik o rozmiarze mniejszym niż dostępne miejsce pokazane przez
Na przykład dla mnie wynikiem działania df-h było:
Więc stworzyłem używając 2 G.
A potem po prostu uruchom usługę
Mam nadzieję że to pomoże. Wszystkiego najlepszego.
źródło
Moje rozwiązanie:
Sprawdź, czy we wszystkich /etc/rc1.d ... /etc/rc5.d skrypt mysql zaczyna się od S (Ex S10mysql), a nie K AS K10mysql.
Objaśnienie: K prefiks K ładuje się z zatrzymaniem, rodzaj usługi zabijania; a prefiks S zaczyna się od parametru początkowego.
źródło
W moim przypadku była to kwestia miejsca. Sprawdź, czy masz wystarczająco dużo miejsca.
od
/var/log/mysql/error.log
Dostałem kilka wskazówek z dwóch linii:Widziałem, że to kwestia miejsca.
Stąd widziałem, że na serwerze wirtualnym nie ma wystarczającej ilości miejsca
/dev/mapper/server1--osticket--vg-root 8.3G 7.9G 0 100% /
. Pomyślałem o migracji lub powiększeniu dysku wirtualnego, ale postanowiłem najpierw usunąć niepotrzebne pliki.Musiałem więc wyczyścić pamięć podręczną i pliki, które nie były potrzebne:
Następnie nie zapomnij usunąć uszkodzonych plików dziennika mysql. Zostaną wygenerowane ponownie po ponownym uruchomieniu mysql
Sprawdź swoją usługę serwera mysql i prawdopodobnie jest ona uruchomiona
Sprawa zamknięta. Mam nadzieję, że to pomoże.
źródło
Usuń plik /var/lib/mysql/.run-mysql_upgrade i powinien się uruchomić
;)
"Z dużą mocą przychodzi duża odpowiedzialność"
źródło
Miałem ten problem kiedy ustawić
max_allowed_packet = 0.5M
w/etc/mysql/my.cnf
.Rozwiązałem to, zmieniając
max_allowed_packet
na1M
.źródło
Następujące polecenie rozwiązuje mój problem i mysql może się po nim uruchomić. (W niektórych przypadkach może być użyteczny)
źródło