设为首页 加入收藏

TOP

Linux系统下 MySQL 5.7和8.0 版本安装指南
2018-12-27 14:14:11 】 浏览:49
Tags:Linux 系统 MySQL 5.7 8.0 版本 安装 指南

查看系统中是否已安装 mariadb 服务:


rpm -qa | grep mariadb



yum list installed | grep mariadb


如果已安装则删除 mariadb及其依赖的包:


yum -y remove mariadb-libs-5.5.44-2.el7.centos.x86_64


关闭防火墙:


firewall-cmd --state #查看防火墙状态


systemctl stop firewalld.service #关闭防火墙


systemctl is-enabled firewalld.service;echo $? #查看防火墙是否开机自启


systemctl disable firewalld.service #禁止防火墙开机启动


MySQL依赖于libaio 库,安装libaio


yum search libaio


yum install libaio


2.下载安装包


mkdir /data


cd /data/


yum -y install wget


wget https://cdn.mysql.com//Downloads/MySQL-5.7/mysql-5.7.20-linux-glibc2.12-x86_64.tar.gz


3. 解压、重命名


tar -zxvf mysql-5.7.20-linux-glibc2.12-x86_64.tar.gz -C /data


mv /data/mysql-5.7.20-linux-glibc2.12-x86_64/ /data/mysql57


mkdir mysql #数据目录与安装目录分离,便于以后MySQL升级


groupadd mysql


useradd mysql -g mysql


/etc/my.cnf


主要参数及取值如下:


(相关取值,请根据实际环境做调整,如内存配置参数等)


说明:


请一定记得上面 配置模板文件中的server-id 参数一定要修改。


否则在配置 主从复制,或者MHA时会报错。


例如错误信息 :


2018-10-09T16:13:53.205115+08:00 11 [ERROR] [MY-013117] [Repl] Slave I/O for channel '': Fatal error: The slave I/O thread stops because master and slave have equal MySQL server ids; these ids must be different for replication to work (or the --replicate-same-server-id option must be used on slave but this does not always make sense; please check the manual before using it). Error_code: MY-013117


cd /data/mysql


mkdir mysql_log


chown -R mysql.mysql mysql_log/


mkdir tmp


chown -R mysql.mysql tmp/


 说明:


有时候,可能我们只是将MYSQL的二进制文件从其它的服务器Copy至本地。


例如我们在安装MYSQL8.0 时,安装文件从其它的服务,Copy到本地,文件命名为mysql80。如下图:



此时还需要执行以下权限,所以 我手动增加了一下权限,执行代码如下:


chmod -R 755 /data/mysql80/bin/


说明:


主参数--defaults-file=/etc/my.cnf必须紧接在mysqld后面,如果做第二个以后的参数加入时,则会出现报错:


[ERROR] unknown variable 'defaults-file=/etc/my.cnf'!


注意密码:5.7初始化后会生成一个临时密码,存在mysql.err


[Note] A temporary password is generated for root@localhost: XXXXXXXX


也就是root@localhost:后的字符串。


设置开机启动和检查是否成功


说明:


如果还是使用的Copy文件的方式,例如我们前面 Copy的mysql80 二进制文件, 此处就会报错:



此时 还要执行以下赋权命令 :


chmod -R 755 ./mysql.server  (这个文件是 /data/mysql80/support-files)


和  


chmod -R 755 /etc/init.d/mysqld


说明 :


MySQL 8.0 是报错的:


ERROR 1064 (42000): You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near 'password('XXXXX')' at line 1


在登录MySQL,修改root密码时,使用就方法 SET PASSWORD=PASSWORD(‘[新密码]’) 报错。



查看网上的相关解释为:


以前版本的MySQL的密码认证插件是“mysql_native_password”,而现在使用的是“caching_sha2_password”。


解决方案:


ALTER USER 'root'@'localhost' IDENTIFIED WITH mysql_native_password BY '新密码';


FLUSH PRIVILEGES;



编程开发网
】【打印繁体】【投稿】【收藏】 【推荐】【举报】【评论】 【关闭】 【返回顶部
上一篇MySQL 5.7 分区表性能下降的案例.. 下一篇MySQL字段自增长AUTO_INCREMENT用..

评论

帐  号: 密码: (新用户注册)
验 证 码:
表  情:
内  容:

array(4) { ["type"]=> int(8) ["message"]=> string(24) "Undefined variable: jobs" ["file"]=> string(32) "/mnt/wp/cppentry/do/bencandy.php" ["line"]=> int(214) }