linux下安装mysql

 本文示例的安装过程是在阿里云esc实例的centos7.5下安装mysql8.0.25,使用的工具是xshell


 检查依赖

rpm -qa | grep libaio
rpm -qa | grep net-tools

#如果不存在需要到centos安装盘里进行rpm安装,如果安装的是图形化界面的,这些都是自带好的

#安装libaio(如果上面rpm -qa | grep libaio有,就不要进行此步)

yum install -y libaio


准备mysql安装文件到/opt/software

MySQL :: Download MySQL Community Server (Archived Versions)

选择RPM Bundle全量包,包括了下面的全部组件.

再选择使用rz  sz (lrzsz)来传输文件

rz  sz指令可以实现linux和windows之间的文件传输,但要求在windows客户端要安装Xshell或SecureCRT远程连接工具。

        rz指令和sz指令是一对上传与下载的指令。它们的软件包名为lrzsz。

  rz  sz指令使用很简单,执行rz 指令,远程连接工具会弹出windows文件选择窗口,只要选择要上传的文件即可

#安装lrzsz

  $ yum install lrzsz -y

待全量包安装好后直接拖进xshell就传输了

#解压全量包

tar -xvf mysql-8.0.25-1.el7.x86_64.rpm-bundle.tar

#我们需要使用的组件有


安装

在mysql的安装文件目录下执行(必须按照顺序执行)

rpm 是redhat package manage缩写,通过rpm的管理,用户可以把源代码包装成以rpm为扩展名的文件形式,易于安装

-i        install 安装软件包

-v        verbose提供更多的详细信息输出

-h        hash软件包安装的时候列出哈希标记(和-v一起使用效果更好),展示进度条

#倒数两个安装较缓慢,耐心等待

rpm -ivh mysql-community-common-8.0.25-1.el7.x86_64.rpm
rpm -ivh mysql-community-client-plugins-8.0.25-1.el7.x86_64.rpm
rpm -ivh mysql-community-libs-8.0.25-1.el7.x86_64.rpm
rpm -ivh mysql-community-client-8.0.25-1.el7.x86_64.rpm
rpm -ivh mysql-community-server-8.0.25-1.el7.x86_64.rpm 

#如果安装libs时出现mariadb-libs被mysql-community-libs-8.0.25-1.el7.x86_64取代报错,清除之前安装过的依赖即可

yum remove mysql-libs

检查

#查看mysql版本,执行成功会类似java -version打出版本信息

mysql --version

 

#检查一下我们需要的组件是否都安装好了

rpm -qa | grep -i mysql


服务的初始化

为了 保证数据库目录与文件的所有者为mysql登录用户,如果你是以root身份运行mysq服务,需要执行下面的命令初始化

--initialize选项默认以安全模式来初始化,会为root用户生成一个密码并将改密码标记为过期,登录后需要设置一个新的密码,生成的临时密码会往日志中记录一份

mysqld --initialize --user=mysql

#查看密码并记录

cat /var/log/mysqld.log


 mysql启停等常用指令

#启动

systemctl start mysqld.service

#关闭

systemctl stop mysqld.service

#重启

systemctl restart mysqld.service

#查看状态

systemctl status mysqld.service

#查看进程

ps -ef | grep -i mysql

#查看mysql服务是否自启动

systemctl list-unit-files | grep mysqld.service

 默认是enabled(自启动)

#如果不是,设置为自启动

systemctl enable mysqld.service

#如果不想设置为自启动

systemctl disable mysqld.service

 登录

#localhost:mysql对应服务器的地址(可以省略)

#3306为mysql的默认端口(可以省略)

#root登录用户

#password密码(我们刚才记录的密码)

#自行按照自己的情况输入

mysql -hlocalhost -p3306 -uroot -ppassword

修改密码,5.7版本后加入了全新的密码安全机制,太简单会报错

alter user 'root'@'localhost' identified by 'hello_world123';

远程连接(使用navicat/sqlyog等软件访问数据库)

use mysql;
select host,user from user;

可以看到root用户的当前主机配置信息为localhost

host列指定了允许用户登录所使用的ip,user = root,host = 192.168.1.1则意味着root用户只能通过192.168.1.1的客户端去访问(大学里的文献论文查看等都要求用学校的内网,这就是限制的原理),配置成%,表示所有ip都有连接权限

update user set host = '%' where user = 'root';

解决报错

解决not allowed to connect this mysql

#关闭防火墙

systemctl stop firewalld.service

#设置开机禁用防火墙

systemctl disable firewalld.service

#查看防火墙状态

systemctl status firewalld.service

 

解决plugn 'caching_sha2_password'

这条报错是因为mysql8的密码加密方式变了

ALTER USER 'root'@'%' IDENTIFIED WITH mysql_native_password BY 'abc123';

 ALTER USER 'root'@'%' IDENTIFIED WITH mysql_native_password BY 'abc123';


 ALTER USER 'root'@'%' IDENTIFIED WITH mysql_native_password BY 'abc123';
 ALTER USER 'root'@'%' IDENTIFIED BY 'abc123';
--有什么区别?
--第一条命令使用了MySQL的native password身份验证机制,而第二条命令使用了MySQL的old style身份验证机制。

--Native password身份验证机制是MySQL 8.0及更高版本中使用的身份验证机制,它使用加密的密码来验证用户的身份。在这种机制下,您可以使用IDENTIFIED BY选项来指定用户的密码。

--Old style身份验证机制是MySQL 5.7及更早版本中使用的身份验证机制,它使用明文密码来验证用户的身份。在这种机制下,您可以使用IDENTIFIED BY PASSWORD选项来指定用户的密码。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值