AMZ DIGICOM

Digital Communication

AMZ DIGICOM

Digital Communication

Ubuntu install MySQL: installation on Ubuntu 20.04

PARTAGEZ

MySQL is one of the most popular open source databases. She is known for her performance, reliability and scalability and is used in many areas, from small web hosting systems to large enterprise applications. We walk you through each step of the MySQL installation process on Ubuntu 20.04 to set up a reliable database management system.

What are the MySQL requirements for Ubuntu 20.04?

Overall, the system requirements for MySQL on Ubuntu 20.04 are relatively low and should be able to be met by most modern desktop or server systems. It is important to note that system requirements may vary depending on usage and database size. For example, if you are running an application that uses large databases or complex queries, higher RAM and CPU requirements are necessary. It is recommended that you have ample disk capacity to anticipate future growth and the addition of additional databases.

For seamless communication between MySQL server and clients, one should also carefully check the network configuration and firewall settings. The MySQL server should have a static IP address to avoid connection issues.

MySQL requires the following minimum requirements for your hardware and software:

  • Processor (CPU) : x86-64 architecture, min. 1 GHz (Dual-Core)
  • RAM :min. 1 GB
  • Operating system : Ubuntu 20.04, sudo user with root rights
  • Firewall : open MySQL port 3306
  • Hard disk space:min. 500 MB
  • Internet connection : to download packages and connect to the MySQL server

Dedicated servers with IONOS

At the crossroads of hardware and the Cloud: dedicated servers with Cloud integration and per-minute billing + personal advisor!

24/7 support

Unlimited traffic

SSL certificate

Step-by-step instructions: configure MySQL on Ubuntu 20.04

You can install MySQL on Ubuntu 20.04 using the Advanced Package Tool (APT) package management system. After installation, you must install and configure MySQL before you can use it in production. In this context, you must in particular define the root password and access for external clients. We show you in our tutorial, step by step, how to do it.

Step 1: Update the Package Index

Firstly, it is advisable to update the list of packages. To do this, run the following command:

Step 2: Install MySQL Server

Now install the MySQL server package with APT :

$ sudo apt install mysql-server

bash

To verify that the server is running, you can start it manually with the command systemctl :

$ sudo systemctl start mysql.service

bash

Step 3: Configure MySQL

After installation, MySQL does not yet meet the recommended security standards. To remedy this, MySQL offers a script which modifies the server protection settings. For example, it takes care of configuring the root password, removing anonymous users and limiting remote access.

However, certain precautions must be taken for the script to run correctly. Indeed, the application wants to modify the password of the root account, which is disabled by default under Ubuntu. To avoid an error, you must adapt the root user authentication method.

Launch the MySQL command prompt:

Use the command ALTER USER to set a password for the root administrator:

mysql> ALTER USER 'root'@'localhost' IDENTIFIED WITH mysql_native_password BY 'password';

bash

Close the MySQL prompt:

Run the security script:

$ sudo mysql_secure_installation

bash

To authenticate as root, enter the following information:

Once the script is finished, you can change the default authentication method again:

mysql> ALTER USER 'root'@'localhost' IDENTIFIED WITH auth_socket;

bash

This will allow you to log in again with the command sudo mysql.

Step 4: Create a MySQL User

Installing MySQL creates a root user who has full privileges for the MySQL server and has complete control over all databases, tables and users. For greater security, it is therefore advisable to create a user with limited rights.

To do this, call the MySQL command prompt:

If the authentication method is a password, use the following expression:

Now create a new user for MySQL:

mysql> CREATE USER 'username'@'host' IDENTIFIED WITH authentication_plugin BY 'password';

bash

Instead of “username”, enter your username and instead of “host”, enter the name of your host. If you are running Ubuntu locally, write localhost. The expression “WITH authentication_plugin” is optional. The “auth_socket” plugin has strong security settings and does not need a password to connect.

If nothing else is specified, MySQL uses the “caching_sha2_passwor” plugin for authentication. However, some versions of PHP are not compatible with the latter. Instead, you can use the older but proven “mysql_native_password” plugin:

mysql> CREATE USER 'username'@'host' IDENTIFIED WITH mysql_native_password BY 'password';

bash

Or use the “ALTER” function for an existing user:

mysql> ALTER 'username'@'host' IDENTIFIED WITH mysql_native_password BY 'password';

bash

Step 5: Assign rights

Now determine what privileges the new user should have. The general syntax is as follows:

mysql> GRANT PRIVILEGE ON database.table TO 'username'@'host';

bash

Multiple privileges are separated by a comma. To apply rights overallreplace “database.table” with an asterisk (“*”) each time.

In the following example, we give a user the right to create (CREATE), modify (ALTER), delete (DROP) databases and insert (INSERT), select (SELECT), (UPDATE) and delete (DELETE) data in a table).

mysql> GRANT CREATE, ALTER, DROP, INSERT, UPDATE, DELETE, SELECT on *.* TO 'user'@'host' WITH GRANT OPTION;

bash

With the “WITH GRANT OPTION” option, the user can also grant their rights to other people.

Now clear the cache with “FLUSH PRIVILEGES”:

mysql> FLUSH PRIVILEGES;

bash

You can then close the MySQL command prompt:

Log in with your new username:

$ mysql -u username -p

bash

Step 6: Test MySQL

Check that MySQL is running correctly, for example with System Manager Systemd:

$ systemctl status mysql.service

bash

You can also connect to the MySQL database. The following command connects to MySQL and displays the server version:

$ sudo mysqladmin -p -u username version

bash

Télécharger notre livre blanc

Comment construire une stratégie de marketing digital ?

Le guide indispensable pour promouvoir votre marque en ligne

En savoir plus

Souhaitez vous Booster votre Business?

écrivez-nous et restez en contact

Suivez-nous:

© 2024 AMZ DIGICOM All Rights Reserved