Mysql8 CentOS7 Compressed TAR Archive安装

目录​​​​​​​ 

一、二进制全量包安装Mysql8

二、Mysql Root用户修改密码、设置权限、设置可远程访问


当前服务器为Centos7,如果是CentOS6则自行下载对应的包。进入Mysql官方下载地址:MySQL :: MySQL Community Downloads

 点击Mysql Community Server,选择下载tag.gz或者tar的安装包,只是压缩方式不同,这里使用tar.gz 包进行安装如下:

 可以从已上传的百度网盘下载

Mysql8.0.27

链接: https://pan.baidu.com/s/1Q5D1--Z4_RcoO1Cmf9RP0Q

提取码: boqs

Mysql8.0.18

链接: https://pan.baidu.com/s/1QjVkuENu38gA0R0pRws_IA

提取码: 2jfw

说明:下面都会基于mysql 8.0.18进行安装

一、二进制全量包安装Mysql8

安装依赖:yum install -y libaio

先将下载的 tar.gz包上传至服务器(比如当前上传到了 /home/mysql目录)

解压、移动到 /usr/local目录、修改文件名,两种方法(这里写的第二种):

1、直接解压到指定目录、修改名称

解压安装包到指定目录: tar -zxvf /root/mysql-8.0.16-el7-x86_64.tar.gz -C /usr/local/

修改文件夹名称做为安装目录: mv /usr/local/mysql-8.0.16-el7-x86_64 /usr/local/mysql

2、解压到当前文件夹、修改名称、cp或者mv到 /usr/local

解压 tar -zxvf mysql-8.0.18-el7-x86_64.tar.gz

重命名:mv mysql-8.0.18-el7-x86_64 mysql

移动到/usr/local目录下:mv mysql /usr/local/

创建mysql数据存放目录(下面在 my.cnf中配置): mkdir /usr/local/mysql/mysqldb

设置权限(这里也是直接暴力社区为777):

chmod 777 /usr/local/mysql

chmod 777 /usr/local/mysql/mysqldb

跳转到mysql目录: cd /usr/local/mysql/

创建linux用户组 mysql:groupadd mysql

建立MySQL用户,但该用户不能登陆: useradd -r -g mysql -s /bin/false mysql

把mysql用户加入到mysql组下: chown -R mysql:mysql ./

[root@iZ2ze4zhiwnwqxsc7wehwlZ etc]# cd /usr/local/mysql/
[root@iZ2ze4zhiwnwqxsc7wehwlZ etc]# groupadd mysql
[root@iZ2ze4zhiwnwqxsc7wehwlZ etc]# useradd -r -g mysql -s /bin/false mysql
[root@iZ2ze4zhiwnwqxsc7wehwlZ mysql]# chown -R mysql:mysql ./

修改mysql的启动配置文件 /etc/my.cnf,如果不存在自行创建,内容为:

[mysqld]
# 设置3306端口
port=3306
# 设置mysql的安装目录
basedir=/usr/local/mysql
# 设置mysql数据库的数据的存放目录
datadir=/usr/local/mysql/mysqldb
# 容许最大链接数
max_connections=10000
# 容许链接失败的次数。这是为了防止有人从该主机试图攻击数据库系统
max_connect_errors=10
# 服务端使用的字符集默认为UTF8
character-set-server=utf8
# 建立新表时将使用的默认存储引擎
default-storage-engine=INNODB
# 默认使用“mysql_native_password”插件认证
default_authentication_plugin=mysql_native_password
[mysql]
# 设置mysql客户端默认字符集
default-character-set=utf8
[client]
# 设置mysql客户端链接服务端时默认使用的端口
port=3306
default-character-set=utf8

安装mysql:

cd /usr/local/mysql/bin

./mysqld --initialize --console

重新设置权限:

chmod -R 777 /usr/local/mysql

跳转到安装包的support-files目录,启动mysql服务

./mysql.server start

【可选项】,将mysql加入系统进程中,并重启试一下命令是否可用

cp mysql.server /etc/init.d/mysqld

service mysqld restart

 【可选项】,设置环境变量和软连接,让mysql相关命令在任何地方都可以执行:

vi /etc/profile 添加:export PATH=$PATH:/usr/local/mysql/bin

ln -s /usr/local/mysql/bin/mysql /usr/bin

【可选项】,设置开机启动:

vi /etc/rc.local 添加: service mysqld start

同样记住开放防火墙端口,或者关闭防火墙;如果阿里云、华为云等云服务器记得在安全规则中开放端口。

关闭防火墙命令: systemctl stop firewalld.service

查看防火墙状态 :systemctl status firewalld.service

查看已经开放的端口 firewall-cmd --list-portsfirewall-cmd --query-port=3306/tcp

开启端口 firewall-cmd --zone=public --add-port=3306/tcp --permanent

二、Mysql Root用户修改密码、设置权限、设置可远程访问

上面安装执行 mysql --initlizalize --console命令时可以查看Mysql root用户的密码,也可以在 /etc/my.cnf 中设置mysql日志的文件,再使用命令查看文件中的查看当前root的密码:

cat /在my.cnf设置的路径/mysqld.log | grep password

如果mysql之后默认不允许远程访问数据库,如果遇到登陆遇到该问题

可以先在 /etc/my.cnf 中添加 skip-grant-tables 配置,然后重启mysql,执行命令

systemctl restart mysqld

然后再执行root 修改密码、修改远程访问以及修改权限等操作(否则请忽略)

 如果在改模式下执行修改密码操作,包错 The MySQL server is running with the --skip-grant-tables option so it cannot execute this statement 则先执行一次 flush privileges; 

 最后还是要再执行一遍 flush privileges;,改完后记得恢复 /etc/my.cnf 中的skip-grant-tables项

mysql -u root -p登陆成功后【修改密码,修改远程能访问,设置权限】

mysql> ALTER USER 'root'@'%' IDENTIFIED BY '!Mosty123'; -- 修改root密码

mysql> alter user root identified with mysql_native_password by '!Mosty123';

             -- 防止在远程不能登陆

mysql> use mysql;

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

mysql> GRANT ALL PRIVILEGES ON *.* TO 'root'@'%' WITH GRANT OPTION;

mysql> Grant all privileges on *.* to 'root'@'%';

mysql> FLUSH PRIVILEGES;

mysql> exit;

如果还是远程不能访问,报错 1045

1、查看防火墙

2、查看上面的命令是否都输入了

3、查看数据库是否允许访问的ip

 4、最后还不行,请检查密码是否输入对了!!!

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值