1,检查系统是否已经安装了mysql,如果已经安装mysql,需要先卸载。
1)检查命令:
rpm -qa | grep mysql
2)卸载命令:
yum remove -y mysql-community-server.x86_64
3)删除mysql的文件
- find / -name mysql ------------------------(查找文件的目录)
- rm -rf xxxxx ------------------------(删除mysql文件)
2,配置mysql源
1)创建文件
vim /etc/yum.repos.d/mysql.repo
2)编辑文件
#Enable to use MySQL 8.0
[mysql80-community]
name=MySQL 8.0 Community Server
baseurl=http://repo.mysql.com/yum/mysql-8.0-community/el/8/x86_64/
enabled=1
gpgcheck=0
gpgkey=file:///etc/pki/rpm-gpg/RPM-GPG-KEY-mysql
enabled=1
#这个选项表示这个repo中定义的源是启用的,0为禁用
gpgcheck=1
#这个选项表示这个repo中下载的rpm将进行gpg的校验,已确定rpm包的来源是有效和安全的,0为关闭
3,禁用默认的MySQL模块(仅限EL8系统)
1)查看内核版本命令:uname -r
2)基于RHEL8和Oracle Linux 8的基于EL8的系统包括默认情况下启用的MySQL模块。除非禁用此模块,否则它将屏蔽MySQL存储库提供的软件包。要禁用包含的模块并使MySQL存储库软件包可见,请使用以下命令
yum module disable mysql
4,安装MySQL
通过以下命令安装MySQL
yum install mysql-community-server
这将安装MySQL服务器的软件包(mysql-community-server
)以及运行服务器所需组件的软件包,
包括客户端的软件包(mysql-community-client
),客户端和服务器的常见错误消息和字符集(mysql-community-common
)以及共享的客户端库(mysql-community-libs
)
5,修改路径
1) 新建文件夹
mkdir /home/data/mysql
2)将目录授权给mysql用户组
chown mysql:mysql /home/data/mysql
3)原来目录有数据的拷贝数据到新文件夹,第一次安装不需要执行
cp -a -R /var/lib/mysql/* /mnt/mystorage/mysql/
4)更改目录权限(也可以不加权限,防止其他用户无法访问,比如root用户设置750权限,普通用户访问mysql.sock文件可能存在权限不够)
chmod 750 /mnt/mystorage/mysql
5)配置文件my.cnf
6)重新初始化配置内容
mysqld --defaults-file=/etc/my.cnf --initialize --user=mysql
7)建立连接
ln -s /home/data/mysql/mysql.sock /var/lib/mysql/mysql.sock
8)关闭selinux
vi / etc / selinux / config
9)重启系统
reboot
6,启动MySQL服务器
使用以下命令启动MySQL服务器:
systemctl start mysqld
7,查看mysql状态
使用以下命令检查MySQL服务器的状态:
systemctl status mysqld
8,获取随机密码
grep 'temporary password' /var/log/mysqld.log
9,登录mysql
mysql -uroot -p
10,查看文件路径
show global variables like '%datadir%';
show global variables like '%basedir%';
11,修改密码
ALTER USER 'root'@'localhost' IDENTIFIED BY '新密码';
注意: 默认密码策略validate_password
要求密码至少包含一个大写字母,一个小写字母,一位数字和一个特殊字符,并且密码总长度至少为8个字符。
12,设置远程登录
方式一:
- CREATE USER 'root'@'%' IDENTIFIED WITH mysql_native_password BY '密码';
- GRANT ALL ON *.* TO 'root'@'%';
方式二:
- alter user'root'@'%' IDENTIFIED BY '密码'; ----------%就是设置所有IP可以访问
- flush privileges;
13,开放防火墙端口
这时候如果你是第一次安装,没有开放防火墙端口,则通过IP是无法进行连接的,阿里云配置安全组即可!!
- firewall-cmd --permanent --add-port=3306/tcp --------------------(开放3306端口)
- firewall-cmd --reload ----------------------------------------------------- (重启防火墙)
14,将mysql设置为开机自启
systemctl enable mysqld.service
图例
安装mysql
启动MySQL
查看密码,修改密码
开机启动