mysql:无法识别的服务

Fil*_*Fil 6 mariadb windows-subsystem-for-linux

按照以下步骤操作后,我按照此处的说明在 WSL 上安装 mariadb。我运行这个

sudo service mysql start

我有

mysql: unrecognized service

知道如何解决这个问题吗?

Fil*_*Fil 9

正如您所看到的,这只是一个简单的问题,但我花了 24 小时来诊断问题。

解决方案:我用这个命令卸载mariadb

sudo apt-get remove --auto-remove mariadb-server

并安装sudo apt install mysql-server,但这会导致更多问题

mysql安装成功但无法启动

dpkg: error processing package mysql-server (--configure):
dependency problems - leaving unconfigured
No apport report written because the error message indicates its a followup error from a previous failure.
                                                                                                          
Errors were encountered while processing:
mysql-server-5.7
mysql-server
E: Sub-process /usr/bin/dpkg returned an error code (1)
Run Code Online (Sandbox Code Playgroud)

因此,通过删除 mariadb 的 deb 源并清除 mysql-common,然后重新安装它。

做: sudo apt edit-sources

并查找包含 mariadb 的任何内容,例如:deb [arch=amd64,arm64,ppc64el] http://ftp.nluug.nl/db/mariadb/repo/10.3/ubuntu bionic main

#通过在其前面添加 来将其注释掉。然后运行

sudo apt update
sudo apt purge mysql-common
sudo apt install mysql-common
Run Code Online (Sandbox Code Playgroud)

之后,您可以通过 sudo apt install mysql-server 正确安装 mysql-server,然后执行以下操作:

sudo apt purge mysql-server mysql-server-5.7
sudo apt purge mysql-server mysql-client mysql-common mysql-server-core-5.7 mysql-client-core-5.7


sudo rm -rfv /etc/mysql /var/lib/mysql

sudo apt autoremove

sudo apt autoclean
Run Code Online (Sandbox Code Playgroud)

最后:

sudo apt update    
sudo apt install mysql-server mysql-client --fix-broken --fix-missing
Run Code Online (Sandbox Code Playgroud)

参考文献: https://askubuntu.com/questions/980314/cannot-install-mysql-server-in-ubuntu16-0-4 https://askubuntu.com/questions/763534/cannot-reinstall-mysql-server-after -其清除


Aks*_*rag 5

您在 WSL 上使用哪个 Linux 发行版?

首先,尝试以下操作:

systemctl {start|stop|restart|status} mysql

或者

service mysql {start|stop|restart|status}

管理 MySQL 服务。

原因可能有以下几点:

  1. 错误的服务名称

    在某些 Linux 发行版上,该服务被命名为 ,而mysqld不是mysql

    要检查:chkconfig --list在 WSL 上运行

  2. 文件权限问题

    请确保中的文件/var/lib/mysql具有770为用户设置的权限和所有权mysql

    修理:

    chmod -R 770 /var/lib/mysql
    chgrp -R mysql /var/lib/mysql
    
    Run Code Online (Sandbox Code Playgroud)

    除此之外,请确保该/etc/rc.d/init.d/mysqld脚本具有修改 mysqld 的可执行权限。

    修理:

    chmod 755 /etc/rc.d/init.d/mysqld
    
    Run Code Online (Sandbox Code Playgroud)
  3. MySQL 服务器包丢失/损坏

    重新安装MySQL!

  • chkconfig 无法识别 (2认同)
  • 无法找到软件包 sysv-rc-conf (2认同)