In this article, you will learn how to solve the “ERROR 1130 (HY000): Host x.x.x.x is not allowed to connect to this MySQL server” error in MySQL/MariaDB database deployment on a Linux system. This is one of the common remote database connection errors encountered by users.
Our Test Environment:
- Application Server IP: 10.24.96.5
- Database Server IP: 10.24.96.6
We encountered the error while testing database connection from one of our app servers to a database server, using the mysql client as shown.
# mysql -u database_username -p -h 10.24.96.6
data:image/s3,"s3://crabby-images/60a54/60a542219f4635673e24478c3eb40ba7270565c6" alt="MySQL Remote Database Connection Error"
On the database server, we have to check the host the user above is allowed to connect from.
# mysql -u root -p
Run the following SQL commands to check the user’s host:
MariaDB [(none)]> SELECT host FROM mysql.user WHERE user = "database_username";
data:image/s3,"s3://crabby-images/fc4a6/fc4a6f66a35733a744327a8ce50aa6d3a8b77da5" alt="Check MySQL User Host"
Run the following GRANT command to enable MySQL access for the remote user from a remote host. Make sure to replace “10.24.96.6” with the IP address of the remote system, and “database_password” to the password that you want “database_username” to use:
MariaDB [(none)]> GRANT ALL ON database_name.* to 'database_username'@'10.24.96.5' IDENTIFIED BY 'database_password'; MariaDB [(none)]> FLUSH PRIVILEGES; MariaDB [(none)]> SELECT host FROM mysql.user WHERE user = "database_username";
data:image/s3,"s3://crabby-images/d22b1/d22b1c491af52f8bd282fa176ad764e20152a8bb" alt="Enable Remote MySQL Database Access to User from Remote Host"
To give a user remote access from all host on a network, use the syntax below:
MariaDB [(none)]> GRANT ALL ON database_name.* to 'database_username'@'10.24.96.%' IDENTIFIED BY 'database_password';
After making the above changes, try to remotely connect to the MySQL database server once more. The connection should be successful as shown in the following screenshot.
# mysql -u database_username -p -h 10.24.96.6
data:image/s3,"s3://crabby-images/5fd43/5fd43572c73978137fedf1379332ec3c0ab01929" alt="Connect to Remote MySQL Database Server"
We hope this solution helped you in solving your Mysql remote connection error. If have any queries reach us via the feedback form below.