文章目录

  • CentOS7默认数据库是mariadb,配置等用着不习惯,因此决定改成mysql,但是CentOS7的yum源中默认好像是没有mysql的。为了解决这个问题,我们要先下载mysql的repo源 (可以先不卸载MariaDB,安装mysql后会自动覆盖删除MariaDB,文末提供卸载MariaDB步骤)
  • 第一步下载mysql的repo源
  • 第二步安装mysql-community-release-el7-5.noarch.rpm包(**安装需要root权权限,加sudo,或者切换到root用户,执行rpm -ivh mysql-community-release-el7-5.noarch.rpm 也可以**)
  • 第三步安装mysql服务
  • 安装后设置root密码
  • 卸载centos7自带的MariaDB(最好使用root用户操作,或者用具有root权限的普通)



如果不是centos7minimal版本,可以直接按如下步骤依次执行安装命令即可

CentOS7默认数据库是mariadb,配置等用着不习惯,因此决定改成mysql,但是CentOS7的yum源中默认好像是没有mysql的。为了解决这个问题,我们要先下载mysql的repo源 (可以先不卸载MariaDB,安装mysql后会自动覆盖删除MariaDB,文末提供卸载MariaDB步骤)

第一步下载mysql的repo源
wget http://repo.mysql.com/mysql57-community-release-el7-10.noarch.rpm

:minimal版本如果报下面错误

mac M3 安装centOS9_root用户


解决办法:安装wget

yum install wget

安装后重新执行第一步的命令后如下

mac M3 安装centOS9_mac M3 安装centOS9_02

第二步安装mysql-community-release-el7-5.noarch.rpm包(安装需要root权权限,加sudo,或者切换到root用户,执行rpm -ivh mysql-community-release-el7-5.noarch.rpm 也可以)
sudo rpm -ivh mysql57-community-release-el7-10.noarch.rpm

mac M3 安装centOS9_mysql_03

第三步安装mysql服务
sudo yum -y install mysql-community-server

mac M3 安装centOS9_root用户_04

  • 开启mysql服务(需要root权限,可以先切换成root用户,再执行命令,普通也可以直接执行命令,需要输入密码,使用普通用户执行前提是该用户配置过权限)
systemctl start mysqld.service
  • 查看mysql状态
systemctl status mysqld.service

mac M3 安装centOS9_mysql_05

安装后设置root密码

1、查看初始密码(使用root用户操作)

# grep "password" /var/log/mysqld.log

mac M3 安装centOS9_root用户_06


2、使用初始密码登录

# mysql -uroot -p

mac M3 安装centOS9_修改密码_07


3、修改密码,mysql强制用户必须修改密码,不然只能登陆,却不能操作数据库(注意:在修改密码时密码复杂度不能太简单,如:123456,但是我们自己开发时又不想设置的太复杂,所以在修改密码之前先修改密码复杂度,如若不想修改密码复杂度,请直接执行ALTER语句)

mysql> set global validate_password_policy=0;
Query OK, 0 rows affected (0.00 sec)
 
mysql> set global validate_password_length=1;
Query OK, 0 rows affected (0.00 sec)

mysql> ALTER USER 'root'@'localhost' IDENTIFIED BY '123456';
Query OK, 0 rows affected (0.00 sec)

4、修改默认字符集,mysql默认的database和server字符集为latin1,我们需要把它修改为utf8

mysql> show variables like 'character%';
+--------------------------+----------------------------+
| Variable_name            | Value                      |
+--------------------------+----------------------------+
| character_set_client     | utf8                       |
| character_set_connection | utf8                       |
| character_set_database   | latin1                     |
| character_set_filesystem | binary                     |
| character_set_results    | utf8                       |
| character_set_server     | latin1                     |
| character_set_system     | utf8                       |
| character_sets_dir       | /usr/share/mysql/charsets/ |
+--------------------------+----------------------------+
8 rows in set (0.01 sec)
 
mysql> set character_set_database=utf8;
Query OK, 0 rows affected, 1 warning (0.00 sec)
 
mysql> set character_set_server=utf8;
Query OK, 0 rows affected (0.00 sec)
 
mysql>

5、授权root用户可以从任意主机登录(注意将123456换成自己的密码)

mysql> grant all privileges on *.* to root@"%" identified by "123456" with grant option;
Query OK, 0 rows affected, 1 warning (0.00 sec)
 
mysql>

:"%"表示匹配全部,可以换做主机名(ip也行),换做主机名的话,就是指定主机访问本机的mysql

grant:授权
		all:所有权限
		*.*:数据库名称.表名称
		root:操作mysql的用户
		@'':主机名
		密码:123456

6、刷新或者退出并重启mysql

mysql> flush privileges;
Query OK, 0 rows affected (0.00 sec)

如果使用退出并重启mysql如下(exit和quit都可以退出

mysql> quit
Bye
[root@hadoop1 conf]# systemctl restart mysqld.service
[root@hadoop1 conf]#

7、开放3306(mysql默认的端口)

[root@hadoop1 conf]# firewall-cmd --zone=public --add-port=3306/tcp --permanent
success
[root@hadoop1 conf]# firewall-cmd --reload
success
[root@hadoop1 conf]#

执行完以上步骤还是不能远程连接mysql的话,尝试开放防火墙的3306端口或者关闭防火墙
8、可以删除mysql57-community-release-el7-10.noarch.rpm,也可以不删除,(如果找不到了,可以使用find等查找命令)


卸载centos7自带的MariaDB(最好使用root用户操作,或者用具有root权限的普通)

1、列出所有被安装的rpm package

# rpm -qa | grep mariadb
mariadb-libs-5.5.50-1.el7_2.x86_64
mariadb-5.5.50-1.el7_2.x86_64
mariadb-server-5.5.50-1.el7_2.x86_64

2、强制卸载所有

# rpm -e --nodeps mariadb-libs-5.5.50-1.el7_2.x86_64
# rpm -e --nodeps mariadb-5.5.50-1.el7_2.x86_64
# rpm -e --nodeps mariadb-server-5.5.50-1.el7_2.x86_64