系统:Redhat Linux 7.7

MySQL版本:5.7

1. MySQL下载

o 登录网站:https://dev.mysql.com/downloads/mysql/

o 选择合适版本与系统

  • Select version:5.7.31
  • Select operating system:Red Hat Enterprise Linux
  • Select OS Version:Red Hat Enterprise Linux 7
  • Download Packages:mysql-5.7.31-1.el7.x86_64.rpm-bundle.tar
  • 点击Download



mysql数据库直连 mysql5.7连接数据库_mysql tar包安装


2. MySQL安装

(1) 卸载系统自带Mariadb,mariadb是Mysql的一个分支,具有和mysql相同的API和命令行。

  • 查看mariadb数据库:rpm -qa | grep mariadb
  • 卸载mariadb:rpm -e --nodeps mariadb文件名

(2) 为了避免mysql有之前安装的碎片,卸载mysql

  • 查看与mysql数据库:rpm -qa | grep mysql
  • 下载mysql数据库:rpm -e --nodeps mysql数据库

(3) 删除etc目录下的my.cnf文件:

rm /etc/my.cnf

(4) 解压 RPM 包

  • 解压mysql-5.7.21-1.el7.x86_64.rpm-bundle.tar包,

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

(5) 安装 RPM 包

  • 安装如下几个rpm包,需要按照如下顺序安装,因为有些包需要依赖,故需要按照一定的额顺序安装:(注意命令虽然之间的空小,里面都会隔一个空格)

rpm -ivh mysql-community-common-5.7.31-1.el7.x86_64.rpm

rpm -ivh mysql-community-libs-5.7.31-1.el7.x86_64.rpm

rpm -ivh mysql-community-client-5.7.31-1.el7.x86_64.rpm

rpm -ivh mysql-community-server-5.7.31-1.el7.x86_64.rpm

rpm -ivh mysql-community-devel-5.7.31-1.el7.x86_64.rpm

(6) 安装成功后,开启mysql服务:

systemctl start mysqld.service

  • 可能遇到的问题:在这里启动mysql服务时可能会遇到如下错误:

错误:Job for mysqld.service failed because the control process exited with error code.

--- 解决办法:目前还没有想到,查看了日志也没有看出来,最终通过卸载之前的装的mysql,重装解决了,出现这个问题的原因可能是之前的mysql或者mariadb没有卸载干净。

--- 卸载mysql的命令同一中的方法。

(7) 查看 3306 端口是否成功开启

netstat -ln | grep 3306

3. MySQL启动与初始化配置

(1) 启动并查看mysql进程


mysql数据库直连 mysql5.7连接数据库_mysql_02


(2) 使用root账户登录,重置密码时一般会遇到报

mysql -u root

ERROR 1045 (28000): Access denied for user 'root'@'localhost' (using password: NO)

(3) 修改 my.cnf 信息

vi /etc/my.cnf

添加如下信息:

skip-grant-tables

character_set_server=utf8

init_connect='SET NAMES utf8'

collation-server=utf8_general_ci

(4) 重启mysql服务:

systemctl restart mysqld.service

(5) 修改初始密码:

cat /var/log/mysqld.log | grep password

将初始密码复制下来,输入如下命令登陆mysql :

mysql –u root –p

将复制的密码粘贴到命令行中,进入了mysql,使用如下命令修改密码:

set password=password('新密码');

flush privileges;

# 修改 root 初始密码

set password=password(‘123’)

# 可能弹出错误

ERROR 1819 (HY000): Your password does not satisfy the current policy requirements

# 解决方案

set global validate_password_policy=0;

set global validate_password_length=1;

# 更改密码

set password=password(‘1234’)

# 查看密码策略方式

show variables like 'validate_password%';


mysql数据库直连 mysql5.7连接数据库_mysql数据库直连_03


# 退出 mysql

exit

# 暂停 mysql 服务

systemctl stop mysqld.service

# 修改 my.cnf

cat /etc/my.cnf

# 编辑my.cnf配置文件将:skip-grant-tables这一行注释掉

# 重启mysql服务

systemctl start mysqld.service

再次登录mysql

mysql -uroot -p1234

4. MySQL远程连接

(1) 关闭防火墙或开放端口,以下可以 二选一:

o 方法一:关闭防火墙

# 停止firewall

systemctl stop firewalld.service

# 禁止firewall开机启动

systemctl disable firewalld.service

o 方法二:开放端口:

firewall-cmd --zone=public --add-port=3306/tcp --permanent

firewall-cmd --reload

(2) 添加远程访问权限:

GRANT ALL PRIVILEGES ON *.* TO 'root'@'%' IDENTIFIED BY 'root' WITH GRANT OPTION;

# 第一个 root 为 用户名,第二个root 为 密码

# % -- 表示所有的电脑都可以连接,也可以设置某个ip地址运行连接

flush privileges;

(3) 重启服务

systemctl restart mysqld.service;

5. Windows下连接MySQL

(1) 在windows下安装 Navicat for mysql

(2) 打开 cmd,看是否能连接上服务器

ping 192.168.2.153

ssh -v -p 3306 root@192.168.2.153


mysql数据库直连 mysql5.7连接数据库_mysql数据库直连_04


mysql数据库直连 mysql5.7连接数据库_mysql_05


(3)Navicat for mysql 连接

o 设置用户与密码


mysql数据库直连 mysql5.7连接数据库_MySQL_06


o 点击链接测试看到如下内容表示成功


mysql数据库直连 mysql5.7连接数据库_centos6安装mysql并远程连接_07