Linux Centos7配置mysql8.0数据库

本文转至:672530440

在此感谢博主,撒花!!!

本文主要从以下几个方面对自己在centos7 下安装mysql8过程做如下总结:

  • CentOS7 安装mysql8 步骤;
  • window下的Navicat 连接MySql8;
  • 涉及到的Linux命令

https://blog.csdn.net/managementandjava/article/details/80039650

------------------------------------------------------------------------------------------------------------------

第一部分 CentOS7安装mysql

1.1 安装前清理工作;

1.1.1 清理原有的mysql数据库;

使用以下命令查找出安装的mysql软件包和依赖包:

rpm -pa | grep mysql

显示结果如下:

  1. mysql80-community-release-el7-1.noarch

  2.  

    mysql-community-server-8.0.11-1.el7.x86_64

  3.  

    mysql-community-common-8.0.11-1.el7.x86_64

  4.  

    mysql-community-libs-8.0.11-1.el7.x86_64

  5.  

    mysql-community-client-8.0.11-1.el7.x86_64

使用以下命令依次删除上面的程序

yum remove mysql-xxx-xxx-

删除mysql的配置文件,卸载不会自动删除配置文件,首先使用如下命令查找出所用的配置文件;

find / -name mysql

可能的显示结果如下:

  1. /etc/logrotate.d/mysql

  2.  

    /etc/selinux/targeted/active/modules/100/mysql

  3.  

    /etc/selinux/targeted/tmp/modules/100/mysql

  4.  

    /var/lib/mysql

  5.  

    /var/lib/mysql/mysql

  6.  

    /usr/bin/mysql

  7.  

    /usr/lib64/mysql

  8.  

    /usr/local/mysql

根据需求使用以下命令 依次 对配置文件进行删除

rm -rf /var/lib/mysql

1.1.2 删除MariaDB的文件,

由于MySQL在CentOS7中收费了,所以已经不支持MySQL了,取而代之在CentOS7内部集成了mariadb,而安装MySQL的话会和MariaDB的文件冲突,所以需要先卸载掉MariaDB.

使用rpm 命令查找出要删除的mariadb文件;

rpm -pa | grep mariadb

可能的显示结果如下:

mariadb-libs-5.5.56-2.el7.x86_64

删除上面的程序

rpm -e mariadb-libs-5.5.56-2.el7.x86_64

可能出现错误提示如下:

  1. 依赖检测失败:

  2.  

  3.  

    libmysqlclient.so.18()(64bit) 被 (已安裝) postfix-2:2.10.1-6.el7.x86_64 需要

  4.  

  5.  

    libmysqlclient.so.18(libmysqlclient_18)(64bit) 被 (已安裝) postfix-2:2.10.1-6.el7.x86_64 需要

  6.  

  7.  

    libmysqlclient.so.18(libmysqlclient_18)(64bit) 被 (已安裝) postfix-2:2.10.1-6.el7.x86_64 需要

使用强制删除:

rpm -e --nodeps mariadb-libs-5.5.56-2.el7.x86_64

至此就将原来有的mysql 和mariadb数据库删除了;

1.2 安装mysql

1.2.1 下面mysql官网提供的mysql repo源

centos的yum 源中默认是没有mysql的,所以我们需要先去官网下载mysql的repo源并安装;

mysql官网下载链接:mysql repo下载地址 如下:

1.2.2 使用putty的pscp将文件上传到CentOS

使用putty将F:盘下刚下好的mysql repo文件上传到Centos/usr/local/mysql文件夹下;

D:\Putty>pscp F:\mysql80-community-release-el7-1.noarch.rpm [email protected]:/usr/local/mysql/

1.2.3 安装 yum repo文件并更新 yum 缓存;

rpm -ivh mysql57-community-release-el7-11.noarch.rpm

执行结果:

会在/etc/yum.repos.d/目录下生成两个repo文件mysql-community.repo mysql-community-source.repo

更新 yum 命令

  1. yum clean all

  2.  

    yum makecache

1.2.4 使用 yum安装mysql

当我们在使用yum安装mysql时,yum默认会从yum仓库中安装mysql最新的GA版本;如何选择自己的版本;

第一步: 查看mysql yum仓库中mysql版本,使用如下命令

yum repolist all | grep mysql

可以看到 MySQL 5.5 5.6 5.7为禁用状态 而MySQL 8.0为启用状态;

第二步 使用 yum-config-manager 命令修改相应的版本为启用状态最新版本为禁用状态

  1. yum-config-manager --disable mysql80-community

  2.  

    yum-config-manager --enable mysql57-community

或者可以编辑 mysql repo文件,

cat /etc/yum.repos.d/mysql-community.repo 

将相应版本下的enabled改成 1 即可;

1.2.5 安装mysql 命令如下:

yum install mysql-community-server

1.2.6 开启mysql 服务

systemctl start mysqld.service

1.2.7 获取初始密码登录mysql

mysql在安装后会创建一个[email protected]账户,并且把初始的密码放到了/var/log/mysqld.log文件中;

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

使用初始密码登录mysql

mysql -u root -p 

修改初始密码:所以刚开始设置的密码必须符合长度,且必须含有数字,小写或大写字母,特殊字符。

ALTER USER ‘root‘@‘localhost‘ IDENTIFIED BY ‘MyNewPass4!‘;

1.2.8 在防火墙中开启3306端口

CentOS7默认使用的是firewall作为防火墙,我这里改为习惯常用的iptables防火墙

第一步: 关闭firewall防火墙

  1. systemctl stop firewalld.service

  2.  

    systemctl disable firewalld.service

  3.  

    systemctl mask firewalld.service

第二步: 安装iptables防火墙

yum install iptables-services -y

第三步: 启动iptable防火墙

  1. systemctl enable iptables

  2.  

    systemctl start iptables

第四步: 编辑防火墙增加端口 防火墙文件位置为: /etc/sysconfig/iptables

vim /etc/sysconfig/iptables

在倒数第三行上增加

-A INPUT -p tcp -m state --state NEW -m tcp --dport 3306 -j ACCEPT

第五步: 重启防火墙

  1. systemctl enable iptables.service

  2.  

    systemctl start iptables.service

1.2.9 将mysql 服务加入开机启动项,并启动mysql进程

  1. systemctl enable mysqld.service

  2.  

    systemctl start mysqld.service

常用mysql服务命令:

  1. 登录mysql

  2.  

    mysql -u username -p

  3.  

  4.  

    退出mysql

  5.  

    quit

  6.  

  7.  

    启动mysql

  8.  

    systemctl start mysqld.service

  9.  

  10.  

    结束

  11.  

    systemctl stop mysqld.service

  12.  

  13.  

    重启

  14.  

    systemctl restart mysqld.service

  15.  

  16.  

    开机自启

  17.  

    systemctl enable mysqld.service

  18.  

  19.  

    查看mysql版本

  20.  

    select version();

本节参考文档:

参考文献1: centos安装mysql

参考文献2: A Quick Guide to Using the MySQL Yum Repository

------------------------------------------------------------------------------------------------------------------

第二部分 Navicat 连接 Mysql8

2.1 开启mysql远程服务:

2.1.1 修改mysql数据库下的user表中host的值

可能是你的帐号不允许从远程登陆,只能在localhost。这个时候只要在localhost的那台电脑,登入mysql后,更改 "mysql" 数据库里的 "user" 表里的 "host" 项,从"localhost"改称"%"登录mysql数据库 执行如下命令:

  1. mysql -u root -p

  2.  

    use mysql;

  3.  

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

2.1.2 使用授权的方式

赋予任何主机访问数据的权限

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

如果想myuser用户使用mypassword密码从任何主机连接到mysql服务器的话。

GRANT ALL PRIVILEGES ON *.* TO ‘myuser‘@‘%‘IDENTIFIED BY ‘mypassword‘ WITH GRANT OPTION;

如果你想允许用户myuser从ip为192.168.1.6的主机连接到mysql服务器,并使用mypassword作为密码

GRANT ALL PRIVILEGES ON *.* TO ‘myuser‘@‘192.168.1.3‘IDENTIFIED BY ‘mypassword‘ WITH GRANT OPTION;

2.2 在使用 Navicat for Mysql连接mysql 8.0时会报如下错误:

Authentication plugin ‘caching_sha2_password‘ cannot be loaded: 

mysql8.0 引入了新特性 caching_sha2_password;这种密码加密方式客户端不支持;客户端支持的是mysql_native_password 这种加密方式;

我们可可以查看mysql 数据库中user表的 plugin字段;

可以使用命令将他修改成mysql_native_password加密模式:

update user set plugin=‘mysql_native_password‘ where user=‘root‘;

再用Navicat链接 就可以链接成功;

 也可以新建用户远程连接

#CREATE USER ‘用户名‘@‘主机‘ IDENTIFIED BY ‘密码‘;

CREATE USER ‘lylong‘@‘%‘ IDENTIFIED BY ‘901109‘;

这一步提示密码过于简单,先执行一下两条命令,再次运行创建用户的命令就行 .

set global validate_password.policy=0;

set global validate_password.length=1;

mysql8.0默认的加密方式是“caching_sha2_password”,而navicat只支持以前的"mysql_native_password",所以接下来修改密码加密方式

ALTER USER ‘lylong‘@‘%‘ IDENTIFIED WITH mysql_native_password BY ‘901109‘;

修改后可以执行select host,user,plugin from user;语句,查看新增用户的plugin是否是"mysql_native_password"

6 设置该账户可以远程登陆

GRANT ALL PRIVILEGES ON *.* TO ‘lylong‘@‘%‘;

7 刷新权限

flush privileges;

本节参考文献:

参考文献1: mysql开启远程的两种方式

参考文献2:初次安装mysql遇到的问题

------------------------------------------------------------------------------------------------------------------

第三部分:安装过程中涉及到的Linux命令学习;

3.1 rpm

3.2 putty 上传文件 pscp命令;

在window机上CD进入pttty安装目录:

    cd :\program files (x86)\Putty

将本地文件拷贝到Linux上:pscp 文件 用户名@LinuxIP:目录

    pscp hello.txt [email protected]:/tmp/userfile/

将本地文件夹 拷贝到Linux上:pscp  -r 目录 用户名@LinuxIP:目录

   pscp -r c:\file [email protected]:/root/testFolder  

将Linux上的文件\root\test.txt拷贝到本地C盘src文件夹,如下:

   pscp [email protected]_pc:/root/test.txt  C:\src  

3.3 修改防火墙文件/etc/sysconfig/iptables

3.4 systemctl命令

原文地址:https://www.cnblogs.com/qffxj/p/11569220.html

时间: 2024-10-04 01:21:38

Linux Centos7配置mysql8.0数据库的相关文章

Centos7下Mysql8.0安装手册 以及 一些坑点总结

MySQL 8 正式版 8.0.11 已发布,官方表示 MySQL 8 要比 MySQL 5.7 快 2 倍,还带来了大量的改进和更快的性能! 一.  Mysql8.0版本相比之前版本的一些特性 1) 默认编码utf8默认编码使用utf8mb4, utf8mb4编码是utf8编码的超集,兼容utf8,并且能存储4字节的表情字符历史,MySQL数据库的 "utf8"并不是真正概念里的 UTF-8.MySQL中的"utf8"编码只支持最大3字节每字符.真正的大家正在使用

Linux下配置OpenCV1.0环境

自己一直嚷嚷着打算学学图像识别,识别个简单的,车牌号,验证码之类的,之前查过资料,OpenCV可以实现.昨天花了一个下午终于配置好环境了,今天写下总结. OpenCV这一名称包含了Open和Computer Vision两者的意思.实际上,Open指Open Source(开源,即开放源代码),Computer Vision则指计算机视觉.更详细介绍,请参考:http://zh.wikipedia.org/wiki/OpenCV 配置环境系统信息:Linux [email protected]:

Linux 安装配置maven3.0 以及搭建nexus私服

一.软件准备 1.apache-maven-3.0-bin.tar.gz 下载地址:http://www.apache.org/dyn/closer.cgi/maven/binaries/apache-maven-3.0-bin.tar.gz 2.nexus-oss-webapp-1.8.0-bundle.tar.gz 下载地址:http://nexus.sonatype.org/downloads/ 二.maven安装配置 1.创建需要操作maven的用户组以及用户(如果用root用户安装不用

linux centos7安装mysql8

一.RPM版安装 查看是否有其他版本的数据库,若有,删除干净 非root用户必须要有sudo权限 1.下载mysql相关安装包 https://mirrors.tuna.tsinghua.edu.cn/mysql/yum/mysql80-community-el7/mysql-community-server-8.0.18-1.el7.x86_64.rpm https://mirrors.tuna.tsinghua.edu.cn/mysql/yum/mysql80-community-el7/m

【记录】Linux环境安装mysql8.0

话说mysql8.0版本比5.7版本要快2倍以上,这么看宣传怎么能不装8.0呢,但是新版本和旧版本有不少不同导致若使用以前的一些安装方法会导致安到一半就由于各种找不到文件卡住. 尝试了不少次,只有使用yum源安装的方法成功了,其中还有以boot版本的编译安装方法,结果编译到73%卡住怎么也过不去233 基本按照下面这个博客的教程即可以安装成功,在此感谢正确且完善的良心教程: https://blog.csdn.net/qq_35098526/article/details/80077683 以下

centos7安装mysql8.0

MySQL 8 正式版 8.0.11 已发布,官方表示 MySQL 8 要比 MySQL 5.7 快 2 倍,还带来了大量的改进和更快的性能! mysql8.0安装步骤: 1.添加yum安装库 安装库的下载地址:https://repo.mysql.com//mysql80-community-release-el7-2.noarch.rpm wget https://repo.mysql.com//mysql80-community-release-el7-2.noarch.rpm rpm -

Windows 10配置mysql8.0.11 步骤

每次配mysql都要查一遍,记又记不住,所以写个记录. https://dev.mysql.com/downloads/mysql/  下载地址 下载免安装包,解压 配置环境变量: PATH:    解压路径\bin 编写配置文件my.ini [mysqld] # 设置3306端口 port=3306 # 设置mysql的安装目录 basedir=F:\\mysql-8.0.15-winx64 # 切记此处一定要用双斜杠\\,单斜杠我这里会出错,不过看别人的教程,有的是单斜杠.自己尝试吧 # 设

Win10配置MySQL8.0.15免安装版教程

官网下载免安装版的,然后解压到指定文件夹. 首先配置环境变量: 将 mysql 文件夹下的 bin 文件夹路径添加到系统环境变量即(添加到 path 里) 在mysql-8.0.15-winx64文件夹中创建一个data文件夹 在mysql-8.0.15-winx64文件夹中新建 my.ini 文件,文件内容为: [client] port=3306 [mysql] [mysqld] port=3306 #此处改为你自己的安装路径 basedir= D:\\ruanjian\mysql-8.0.

CentOs7中Mysql8.0设置远程连接

1 登陆Mysql mysql -uroot -p 输入密码 2 选择 mysql 数据库 use mysql; 在mysql数据库中存储了用户信息的user表 3 在 mysql 数据库的 user 表中查看当前 root 用户的相关信息 select host, user, authentication_string, plugin from user; 可以看到root用户的host默认为localhost,只允许本地访问,不允许远程连接.. 为了安全(网上有人是这么说的,作为菜鸡,我也不