How do I install and configure MySQL/MariaDB on CentOS?
How do I install and configure MySQL/MariaDB on CentOS?
To install and configure MySQL/MariaDB on CentOS, follow these steps:
-
Update System Packages:
First, ensure your CentOS system is up to date. Open a terminal and run:<code>sudo yum update -y</code>
Copy after login -
Install MySQL or MariaDB:
-
For MySQL:
Add the MySQL repository to your system. You can download the appropriate release package from the MySQL website and install it. For example:<code>wget https://dev.mysql.com/get/mysql80-community-release-el7-3.noarch.rpm sudo rpm -ivh mysql80-community-release-el7-3.noarch.rpm sudo yum install mysql-server -y</code>
Copy after login -
For MariaDB:
Install MariaDB from the default CentOS repository:<code>sudo yum install mariadb-server -y</code>
Copy after login
-
-
Start and Enable the Service:
After installation, start the service and enable it to run on boot:<code>sudo systemctl start mysqld # For MySQL sudo systemctl start mariadb # For MariaDB sudo systemctl enable mysqld # For MySQL sudo systemctl enable mariadb # For MariaDB</code>
Copy after login -
Secure the Installation:
Run the security script provided by MySQL or MariaDB to secure your installation:<code>sudo mysql_secure_installation # For MySQL sudo mysql_secure_installation # For MariaDB</code>
Copy after loginFollow the prompts to set a root password, remove anonymous users, disallow root login remotely, and remove the test database.
-
Configure MySQL/MariaDB:
-
Edit the Configuration File:
The configuration file is usually located at/etc/my.cnf
or/etc/mysql/my.cnf
. You may need to adjust settings likebind-address
,max_connections
, andinnodb_buffer_pool_size
based on your requirements. -
Create a Database and User:
Access the MySQL/MariaDB shell:<code>sudo mysql # For MySQL sudo mysql # For MariaDB</code>
Copy after loginCreate a database and user:
<code>CREATE DATABASE your_database; CREATE USER 'your_user'@'localhost' IDENTIFIED BY 'your_password'; GRANT ALL PRIVILEGES ON your_database.* TO 'your_user'@'localhost'; FLUSH PRIVILEGES;</code>
Copy after login
-
Edit the Configuration File:
What are the system requirements for installing MySQL/MariaDB on CentOS?
The system requirements for installing MySQL/MariaDB on CentOS can vary based on the version and intended usage, but here are the general minimum requirements:
- Operating System: CentOS 7 or 8.
- Processor: 1 GHz or faster.
-
RAM:
- For small installations, 512 MB of RAM can be sufficient, but 1 GB or more is recommended.
- For production environments, at least 2 GB of RAM is recommended, with more depending on the workload.
-
Disk Space:
- MySQL/MariaDB requires at least 1 GB of disk space for the installation. However, additional space is needed for data storage, logs, and backups.
- For production systems, ensure you have sufficient space for data growth and backups.
- Network: Internet connectivity is required for installation from repositories and for updates.
These requirements may need to be adjusted based on your specific use case and the scale of your database operations.
How can I secure my MySQL/MariaDB installation on CentOS?
Securing your MySQL/MariaDB installation on CentOS involves several steps:
-
Run the Security Script:
Use themysql_secure_installation
script as mentioned earlier. This script helps to:- Set a root password.
- Remove anonymous users.
- Disallow root login remotely.
- Remove the test database.
-
Configure Firewall:
Ensure your firewall is configured to allow connections to MySQL/MariaDB. For example, to allow connections on the default port 3306:<code>sudo firewall-cmd --permanent --add-port=3306/tcp sudo firewall-cmd --reload</code>
Copy after login -
Use Strong Passwords:
Ensure all user accounts have strong, unique passwords. Avoid using default passwords. -
Limit User Privileges:
Only grant the necessary privileges to users. Use the principle of least privilege. -
Enable SSL/TLS:
Configure MySQL/MariaDB to use SSL/TLS for encrypted connections:- Edit the configuration file (
/etc/my.cnf
or/etc/mysql/my.cnf
) to include SSL settings. - Generate SSL certificates and keys.
- Restart the MySQL/MariaDB service.
- Edit the configuration file (
-
Regular Updates:
Keep MySQL/MariaDB and your CentOS system updated with the latest security patches. -
Audit and Monitor:
Regularly audit your database for any suspicious activity and monitor logs to detect and respond to potential security issues.
What are the common troubleshooting steps for MySQL/MariaDB on CentOS?
Common troubleshooting steps for MySQL/MariaDB on CentOS include:
-
Check Service Status:
Verify if the MySQL/MariaDB service is running:<code>sudo systemctl status mysqld # For MySQL sudo systemctl status mariadb # For MariaDB</code>
Copy after login -
Examine Log Files:
Review the log files for error messages. The log files are typically located at:<code>/var/log/mysqld.log # For MySQL /var/log/mariadb/mariadb.log # For MariaDB</code>
Copy after login -
Check for Disk Space Issues:
Ensure there is sufficient disk space. Run:<code>df -h</code>
Copy after loginto check available disk space.
-
Verify Configuration:
Review the configuration file (/etc/my.cnf
or/etc/mysql/my.cnf
) for any incorrect settings. -
Test Network Connectivity:
If you are accessing MySQL/MariaDB remotely, ensure that network connectivity is working and that the firewall is configured correctly. -
Check for Corrupt Tables:
Use MySQL/MariaDB tools to check and repair corrupt tables:<code>mysqlcheck -u root -p --auto-repair --check --optimize --all-databases</code>
Copy after login -
Restart the Service:
Sometimes, simply restarting the service can resolve issues:<code>sudo systemctl restart mysqld # For MySQL sudo systemctl restart mariadb # For MariaDB</code>
Copy after login -
Consult Documentation:
Refer to the official MySQL or MariaDB documentation for specific error codes and troubleshooting guides.
By following these steps, you should be able to address most common issues encountered with MySQL/MariaDB on CentOS.
The above is the detailed content of How do I install and configure MySQL/MariaDB on CentOS?. For more information, please follow other related articles on the PHP Chinese website!

Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

AI Hentai Generator
Generate AI Hentai for free.

Hot Article

Hot Tools

Notepad++7.3.1
Easy-to-use and free code editor

SublimeText3 Chinese version
Chinese version, very easy to use

Zend Studio 13.0.1
Powerful PHP integrated development environment

Dreamweaver CS6
Visual web development tools

SublimeText3 Mac version
God-level code editing software (SublimeText3)

Hot Topics



Using Docker to containerize, deploy and manage applications on CentOS can be achieved through the following steps: 1. Install Docker, use the yum command to install and start the Docker service. 2. Manage Docker images and containers, obtain images through DockerHub and customize images using Dockerfile. 3. Use DockerCompose to manage multi-container applications and define services through YAML files. 4. Deploy the application, use the dockerpull and dockerrun commands to pull and run the container from DockerHub. 5. Carry out advanced management and deploy complex applications using Docker networks and volumes. Through these steps, you can make full use of D

The steps for backup and recovery in CentOS include: 1. Use the tar command to perform basic backup and recovery, such as tar-czvf/backup/home_backup.tar.gz/home backup/home directory; 2. Use rsync for incremental backup and recovery, such as rsync-avz/home//backup/home_backup/ for the first backup. These methods ensure data integrity and availability and are suitable for the needs of different scenarios.

Frequently asked questions and answers to CentOS interview include: 1. Use the yum or dnf command to install software packages, such as sudoyumininstallnginx. 2. Manage users and groups through useradd and groupadd commands, such as sudouseradd-m-s/bin/bashnewuser. 3. Use firewalld to configure the firewall, such as sudofirewall-cmd--permanent-add-service=http. 4. Set automatic updates to use yum-cron, such as sudoyumininstallyum-cron and configure apply_updates=yes.

In CentOS, how to manage user accounts, permissions and services? 1. Use the useradd command to create a user, 2. Use the usermod and groupmod commands to manage user permissions, 3. Use the systemd to manage services, such as the systemctlstart/stop/status command. Through these steps, CentOS servers can be managed efficiently to ensure their safe and efficient operation.

Improve HDFS performance on CentOS: A comprehensive optimization guide to optimize HDFS (Hadoop distributed file system) on CentOS requires comprehensive consideration of hardware, system configuration and network settings. This article provides a series of optimization strategies to help you improve HDFS performance. 1. Hardware upgrade and selection resource expansion: Increase the CPU, memory and storage capacity of the server as much as possible. High-performance hardware: adopts high-performance network cards and switches to improve network throughput. 2. System configuration fine-tuning kernel parameter adjustment: Modify /etc/sysctl.conf file to optimize kernel parameters such as TCP connection number, file handle number and memory management. For example, adjust TCP connection status and buffer size

The CentOS shutdown command is shutdown, and the syntax is shutdown [Options] Time [Information]. Options include: -h Stop the system immediately; -P Turn off the power after shutdown; -r restart; -t Waiting time. Times can be specified as immediate (now), minutes ( minutes), or a specific time (hh:mm). Added information can be displayed in system messages.

CentOS has stopped maintaining and has moved to CentOSStream and no longer provides a production-friendly version. Impacts include system migration and enterprise reevaluation of Linux policies. Alternatives are: 1. Migrate to RHEL, 2. Turn to Ubuntu or Debian, 3. Consider CentOSStream as a test platform, 4. Use AlmaLinux or RockyLinux. It is recommended to develop a migration plan as early as possible to evaluate existing system and team needs.

CentOS server security reinforcement can be achieved through the following steps: 1. Keep the system software updated and use the "sudoyumupdate-y" command; 2. Disable unnecessary services, such as "sudosystemctldisablecups&&sudosystemctlstopcups"; 3. Configure SELinux as mandatory mode, use the "sudosetenforce1&&sudosed-i's/SELINUX=permissive/SELINUX=enforcing/g'/etc/selinux/config" command; 4. Regularly
