• centos安装mysql8


    1.下载并安装 yum repostory

    下载:

    wget -i -c  https://repo.mysql.com//mysql80-community-release-el7-1.noarch.rpm
    
    • 1

    安装myql:

    yum -y install mysql80-community-release-el7-1.noarch.rpm
    
    • 1

    安装mysql服务:

    yum -y install mysql-community-server
    
    • 1

    2.配置数据库:

    2.1如果有需要可以设置u不区分大小写(编辑 /etc/my.cnf文件):

    文件中添加如下配置:

    lower_case_table_names=1   // 1:不敏感,0:敏感)
    
    • 1

    2.2启动mysql8

    systemctl start  mysqld.service
    
    • 1

    2.3查看mysql8运行状态

    systemctl status mysqld.service
    
    • 1

    2.4设置密码

    设置密码首先我们要知道root账户的初始密码使用以下命令查看:

    grep "password" /var/log/mysqld.log
    
    • 1

    上图箭头中指示的就是初始密码,复制该密码,使用以下命令登录数据库:

    mysql -uroot -p
    
    • 1

    注意:这时候用初始密码登录是无法做任何事的,需要先修改初始密码,修改初始密码如果密码不符合规则过于简单是会报错的,如果想设置个简单的密码,那第一次你还是先设置个比较复杂的,设置完以后再修改密码策略,这时候再次修改为简单的密码即可,具体操作如下:

    2.4.1修改一个复杂的密码:

    ALTER USER 'root'@'localhost' IDENTIFIED BY '你的复杂密码';
    
    • 1

    2.4.2查看密码策略:

    SHOW VARIABLES LIKE 'validate_password%';
    
    • 1

    注意这里mysql8的密码策略是

    validate_password.policy

    而mysql5的时候密码策略是

    validate_password_policy

    2.4.3修改策略为低级:

    set global validate_password.policy=LOW;
    
    • 1

    然后再按照2.4.1命令修改一个简单的密码即可

    3.设置远程访问:

    3.1开放防火墙3306端口

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

    如果防火墙关闭状态,可以先打开

    1> 查看防火墙状态:systemctl status firewalld

    2>开启防火墙:systemctl start firewalld

    开启防火墙以后再执行开放端口命令即可。

    3.2刷新防火墙

    firewall-cmd --reload
    
    • 1

    安装到此结束。

    **最后:**如果你用navicat客户端登录可能会报错,因为密码认证方式不支持,默认是 caching_sha2_password,可以修改 /etc/my.cnf文件改变密码认证方式为mysql_native_password

    在my.cnf文件的[mysqld]下面加上如下配置:

    default_authentication_plugin=mysql_native_password
    
    • 1

    登录mysql

    mysql -u root -p
    
    • 1

    查询用户信息:

    select host, user, authentication_string, plugin from user;
    
    • 1

    上图中我们能看到相关信息,默认localhost,不支持所有ip访问,我们修改所有ip都允许,则把localhost改为%

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

    修改加密规则:

    ALTER USER 'root'@'%' IDENTIFIED BY '登录密码' PASSWORD EXPIRE NEVER;
    
    • 1

    更新密码:

    ALTER USER 'root'@'%' IDENTIFIED WITH mysql_native_password BY '登录密码';
    
    • 1

    刷新权限:

    flush privileges;
    
    • 1

    到此ok!

  • 相关阅读:
    Excel·VBA工作表导出为图片
    RK3568技术笔记十 Ubuntu常用命令简介
    常见的文件系统格式
    终于,手把手教会 HR 实现 Python + Excel 「邮件自动化」发工资条了
    数据分析与处理 实验二 numpy的基本使用
    都说测试行业饱和了,为什么我们公司给初级测试开到了12K?
    js逆向-5-字体反爬
    评估大型语言模型生成文章的能力
    Springboot毕设项目个人健康管理系统tfg73(java+VUE+Mybatis+Maven+Mysql)
    【极简python】第六章 for循环与while循环
  • 原文地址:https://blog.csdn.net/m0_67402013/article/details/126031403