首页 > 数据库 >MySQL主从中复制账号密码可以加密吗?

MySQL主从中复制账号密码可以加密吗?

时间:2024-11-26 11:36:48浏览次数:3  
标签:info MySQL Ssl master mysql 主从 账号密码

搭建MySQL主从复制后,你会发现复制账号的密码是明文存储在mysq.mysql.slave_master_info这张系统表的User_password字段当中,早期MySQL版本中,账号密码存储在master.info文件中。如下案例所示:

mysql> select * from mysql.slave_master_info\G
*************************** 1. row ***************************
Number_of_lines: 33
Master_log_name: mysql_binlog.000001
Master_log_pos: 1165
Host: 192.168.9.154
User_name: repl
User_password: ReL@wpL#123456
Port: 3306
Connect_retry: 60
Enabled_ssl: 0
Ssl_ca:
Ssl_capath:
Ssl_cert:
Ssl_cipher:
Ssl_key:
Ssl_verify_server_cert: 0
Heartbeat: 30
Bind:
Ignored_server_ids: 0
Uuid: da5deebc-9b54-11ef-b5d0-0050569739e5
Retry_count: 86400
Ssl_crl:
Ssl_crlpath:
Enabled_auto_position: 0
Channel_name:
Tls_version:
Public_key_path:
Get_public_key: 1
Network_namespace:
Master_compression_algorithm: uncompressed
Master_zstd_compression_level: 3
Tls_ciphersuites: NULL
Source_connection_auto_failover: 0
Gtid_only: 0
1 row in set (0.00 sec)

mysql>

那么在搭建主从复制的时候,有没有方法将这个账号密码加密呢?检索了一些资料,在当前这个时间点,所有的MySQL版本都没有提供方法将其加密。也就是说,当前阶段,没有任何方法加密这个账号密码。确切的说是官方没有提供任何方法。完全忽略了这个安全隐患。

官方文档[How To Encypt Replication Credentials In mysql.slave_master_info (Doc ID 2623399.1)]中也给出了简单答复。 至于如何规避密码明文存储的一些风险问题,官方给出的建议如下:

Ensure that the master info repository can be accessed only by the database administrator.

[...]

Use a restricted access mode to protect database backups that include log tables or log files containing passwords."

个人强烈建议在创建复制账号时,一定要严格限制这个账号的IP地址,以及账号的权限。不要授予过大的权限。

--在MySQL主/从库中:创建数据同步的账号(从库也创建相同账号,方便切换)
create user repl@'192.168.xxx.xx%' identified by "xxxxxxx";
flush privileges;


grant replication slave on . to 'repl'@'192.168.xxx.xx%';
flush privileges;

标签:info,MySQL,Ssl,master,mysql,主从,账号密码
From: https://www.cnblogs.com/kerrycode/p/18569792

相关文章

  • MySQL MVCC之Read View 的运行原理演示
    背景在MySQL的InnoDB存储引擎中,REPEATABLEREAD是默认的事务隔离级别。在这个隔离级别下,每个事务在开始时会创建一个ReadView,这个ReadView记录了事务开始时所有活跃事务的ID。事务在执行过程中会一直使用这个ReadView,即使其他事务提交了更改。示例假设我们......
  • WINDOWS环境下的MYSQL安装
    一、下载安装包1、进入官网,下载mysql社区版安装包https://dev.mysql.com/downloads/installer/MySQL::下载MySQL安装程序 二、安装1、安装包下载完成后,双击安装包,进入安装指引2、安装指引中,选择自定义安装Custom,并点击【下一步】 3、选择mysql服务 4、添加服务......
  • MySQL索引
      2.1索引概述2.1.1介绍索引(index)是帮助MySQL高效获取数据的数据结构(有序)。在数据之外,数据库系统还维护着满足特定查找算法的数据结构,这些数据结构以某种方式引用(指向)数据,这样就可以在这些数据结构上实现高级查找算法,这种数据结构就是索引。在无索引情况下,就需要从......
  • 【MySQL】备份与恢复
    文章目录一、前置准备二、备份三、恢复一、前置准备先创建库createdatabasetest;使用test数据库usetest;创建表createtabletest(idint,namevarchar(20));插入数据insertintotestvalues(1,"张三");insertintotestvalues(2,"李四");in......
  • MySQL的补充知识点
    SQL注入?定义:MySQL的sql注入是一种攻击技术,攻击者通过再应用程序中插入恶意的sql代码,从而控制应用程序和服务器之间的交互,当应用程序未对用户输入进行适当验证或转义时,这种攻击就可能发生。发生的情况:未对用户输入进行验证:当Web应用程序直接将用户输入拼接到SQL查询语句中,而......
  • MySQL 查询做了这些优化后,纵享丝滑…… 转载
    一、前言 在程序上线运行一段时间后,一旦数据量上去了,或多或少会感觉到系统出现延迟、卡顿等现象,出现这种问题,就需要程序员或架构师进行系统调优工作了。 其中,大量的实践经验表明,调优的手段尽管有很多,但涉及到SQL调优的内容仍然是非常重要的一环,本文将结合实例,总结一些工作中......
  • MySQL面试攻略:从基础到高级,全面解析
    ......
  • MySQL原理简介—7.redo日志的底层原理
    大纲1.redo日志对事务提交后数据不丢失的意义2.redo日志文件的构成3.redo日志会写入到RedoLogBlcok中4.redo日志如何写入到RedoLogBlcok中5.RedoLogBuffer解析6.RedoLogBuffer的刷盘时机7.undolog回滚日志原理 1.redo日志对事务提交后数据不丢失的意义(1)redo......
  • MySQL原理简介—8.MySQL并发事务处理
    大纲1.简单总结增删改SQL语句的实现原理2.多个事务同时执行的场景遇到的问题3.多个事务并发更新或查询时可能出现的问题4.SQL标准中对事务的4个隔离级别5.MySQL是如何支持4种事务隔离级别的6.Spring事务注解了如何设置隔离级别7.uodolog多版本链介绍8.基于undolog多版本......
  • 基于Java+SpringBoot+Mysql在线简单拍卖竞价拍卖竞拍系统功能设计与实现七
    一、前言介绍:免费学习:猿来入此1.1项目摘要主要源于互联网技术的快速发展和电子商务的普及。随着网络技术的不断进步,人们越来越依赖于互联网进行购物、交易和沟通。电子商务的兴起为在线拍卖提供了广阔的市场和便利的条件。在线拍卖系统通过搭建一个虚拟的拍卖平台,将传统......