I'm trying to use a fresh installation of MySQL on Windows Subsystem for Linux (Ubuntu) and can't seem to ever connect to it. I always get the error:
WSL: Can't connect to local MySQL server through socket '/var/run/mysqld/mysqld.sock' (2)
I've tried:
--skip-grant-tables by editing /etc/mysql/mysql.conf.d/mysqld.cnf and restartingThe file /var/run/mysqld/mysqld.sock never shows up either, though I figure this is because WSL doesn't have perfect socket support to begin with but it should still work. I suspect the problem might be specific to WSL and maybe I should try updating to WSL2? I don't know what else the issue could be.
I have the same issue solved through the following steps.
Put these lines at the end of the file /etc/mysql/my.cnf:
[mysqld]
bind-address = 0.0.0.0
user=root
pid-file = /var/run/mysqld/mysqld.pid
socket = /var/run/mysqld/mysqld.sock
port = 3306
[client]
port = 3306
socket = /var/run/mysqld/mysqld.sock
Then put these commands on terminal (NOTE: if dir is not there then create one):
chmod 777 -R /var/run/mysqld
chmod 777 -R /var/lib/mysql
chmod 777 -R /var/log/mysql
Then start MySQL using below command:
mysqld
Then open a new terminal and connect using the below command:
mysql -uroot -pYourPass
I had the same issue.
Follow these steps provided by Microsoft: Add or connect a database with WSL
sudo apt updatesudo apt install mysql-serversudo /etc/init.d/mysql startsudo mysql_secure_installationsudo mysqlIf you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With