preface
How to install MySQL database step by step on a Linux host? You must be right to read this article!
1, Linux server installation
Options for installing Linux server: Centos, Redhat, Oracle Linux.
Linux installation package download:
https://mp.weixin.qq.com/s/PFKkftgaTWpJKCnhI3uxZw
Referring to the documents on the official website, the actual combat environment is configured as follows:
- Redhat 7.9 x86_64
- Memory 2G
- Hard disk 50G
data:image/s3,"s3://crabby-images/71e87/71e8740243225a1fbf70b630b11f410edc465c16" alt=""
data:image/s3,"s3://crabby-images/38f2d/38f2dcf07c617d7516b8c616ecbcfa57a914a1e4" alt=""
⭐ Linux host installation tutorial can refer to: Practical part: installing Linux system on VMware Workstation virtual machine
2, MySQL installation media Download
MySQL installation package official website download address: MySQL Product Archives !
Select version:
- Classic version 5.7.20
- Linux-Generic
- glibc-2.12 && x86-64
data:image/s3,"s3://crabby-images/0396c/0396cc67be0e87a9eed22a35b06f99e0fd33d43e" alt=""
After downloading, the installation package is as follows: mysql-5.7.20-linux-glibc2.12-x86_64.tar.gz, which is uploaded to the Linux server folder through ftp tool.
3, MySQL installation
Refer to the official document for installation steps: Installing MySQL on Unix/Linux Using Generic Binaries
1. Check installation media
Upload the installation media to the / soft Directory:
data:image/s3,"s3://crabby-images/4dbda/4dbda0be6e054f22200e533b140d9961c4288f55" alt=""
2. Unzip the installation media
Unzip the installation media and change the unzipped folder name to mysql:
cd /soft tar -xvf mysql-5.7.20-linux-glibc2.12-x86_64.tar.gz mv mysql-5.7.20-linux-glibc2.12-x86_64 mysql
data:image/s3,"s3://crabby-images/be6b5/be6b5dc12bb4f5e276dce2dc89db57bc619a988f" alt=""
data:image/s3,"s3://crabby-images/4a0c7/4a0c77035cc1230671ef7d4ed80ebac0bf6b618e" alt=""
3. Turn off firewall
systemctl stop firewalld systemctl disable firewalld systemctl status firewalld
4. Establish users and groups
To install mysql, you need to create a MySQL user:
groupadd mysql useradd -r -g mysql -s /bin/false mysql
data:image/s3,"s3://crabby-images/6199e/6199e336cce80ebe69db8567e85f5af106ccc8ef" alt=""
5. Create related directories
mkdir -p /data/mysql chown -R mysql:mysql /data chown -R mysql:mysql /soft chmod 750 /data
data:image/s3,"s3://crabby-images/e4d27/e4d2773c06e89b4a3642bac79d9c1f4b6f093641" alt=""
6. Configure environment variables
Configure the root user environment variable:
cat <<EOF>> /root/.bash_profile export PATH=\$PATH:/soft/mysql/bin EOF ##Effective environment variable source /root/.bash_profile
data:image/s3,"s3://crabby-images/cd590/cd59074ac55a0e19c4e05ea1bae7cae8f001128a" alt=""
7. Install dependent packages
Configure the yum source and install the libaio package:
##Mount mirror source mount /dev/cdrom /mnt ##Configure yum source cat <<EOF>>/etc/yum.repos.d/local.repo [local] name=local baseurl=file:///mnt gpgcheck=0 enabled=1 EOF ##Install dependent packages yum install -y libaio
data:image/s3,"s3://crabby-images/5be7a/5be7ab9240d7ec90b908fdb8e1fbc639c6430f5d" alt=""
8. Uninstall the built-in mariadb and mysql
- Check whether mysql is installed in the system: rpm -qa | grep mysql is not installed because I minimize the installation.
- If yes, force uninstall: rpm -e --nodeps $(rpm -qa | grep mysql)
data:image/s3,"s3://crabby-images/74a90/74a907b4532398210c1469b775ca61b50d32debd" alt=""
- Check whether mariadb is installed on the system: rpm -qa | grep mariadb
- If yes, force uninstall: rpm -e --nodeps $(rpm -qa | grep mariadb). The uninstall is successful here.
data:image/s3,"s3://crabby-images/d6c0e/d6c0e7b5800e72cd4fab389a8448c3495443e208" alt=""
4, MySQL initialization
1. Initialize MySQL database
Initialize and create MySQL database with the following command:
mysqld --initialize --user=mysql --basedir=/soft/mysql --datadir=/data/mysql/
Parameters: - basedir is the mysql decompression directory, - datadir is the mysql data storage directory.
data:image/s3,"s3://crabby-images/92c1a/92c1adcfa15866dd3c16c389a788357471df9290" alt=""
📢 Note: the initial password of the root user is displayed here: yhfvt_rP,24M !
2. Configure my.cnf
Configuration my.cnf file:
cat <<EOF>/etc/my.cnf [mysqld] user=mysql basedir=/soft/mysql datadir=/data/mysql server_id=6 port=3306 socket=/tmp/mysql.sock ##client [mysql] socket=/tmp/mysql.sock prompt=lucifer [\\\\d]> EOF
data:image/s3,"s3://crabby-images/ff9ef/ff9ef9ba7d490cb1b720e5226b7afd05de578f0b" alt=""
Start MySQL service:
/soft/mysql/support-files/mysql.server start
data:image/s3,"s3://crabby-images/070e2/070e247beaf560edd6dc6d0d04907e566546d66b" alt=""
Of course, MySQL service can also be configured to start automatically!
3. Configure MySQL startup and self startup
Linux 6&7 general configuration mode:
cp /soft/mysql/support-files/mysql.server /etc/init.d/mysqld chkconfig mysqld on
data:image/s3,"s3://crabby-images/99aab/99aabdb044dbf619f33175072122f346bb8399d5" alt=""
After configuration, you can start the MySQL service with service mysqld start!
Linux 7 configuration mode:
##Configure mysqld.service file: cat <<EOF>>/usr/lib/systemd/system/mysqld.service [Unit] Description=MySQL Server Documentation=man:mysqld(8) Documentation=http://dev.mysql.com/doc/refman/en/using-systemd.html After=network.target After=syslog.target [Install] WantedBy=multi-user.target [Service] User=mysql Group=mysql ExecStart=/soft/mysql/bin/mysqld --defaults-file=/etc/my.cnf LimitNOFILE = 5000 EOF systemctl enable mysqld
data:image/s3,"s3://crabby-images/bf825/bf82554eb72147d0788759b3b08315a598874146" alt=""
After configuration, you can start the mysql service with systemctl start mysqld!
data:image/s3,"s3://crabby-images/756b5/756b5bb6d85c8c30cab63ea6f6cd4f167be8f457" alt=""
4. Modify MySQL ROOT password
Try to connect to mysql database:
mysql -uroot -pyhfvt_rP,24M
data:image/s3,"s3://crabby-images/f8431/f8431292fe686522d0b2e97af4569a74f9865a6e" alt=""
Because the initial password is hard to remember, you need to modify the initial password of the database root user!
Reset root password:
mysqladmin -uroot -pyhfvt_rP,24M password mysql
data:image/s3,"s3://crabby-images/bc25e/bc25ec507ab69041f3789a0cd322e1ab06936889" alt=""
Connect to MySQL database with new password:
mysql -uroot -pmysql
data:image/s3,"s3://crabby-images/fbbcc/fbbcc68a3f1338decf1dec40f5bdade135638691" alt=""
5. Query test
To view the currently created database:
data:image/s3,"s3://crabby-images/03033/030336b24680fd14e1fe5b363de9ed967101e3a5" alt=""
To view the user information of MySQL database:
data:image/s3,"s3://crabby-images/9093f/9093fc35d662074758d9d78d5a2354585b58972b" alt=""
data:image/s3,"s3://crabby-images/fd022/fd022d8fa922e4dbe8957fe4adbaebcd8ef4a25a" alt=""
So far, MySQL database has been installed and can be connected for test operation!