当前位置:首页 > 数据库 > 正文内容

MySQL主从中仿制账号密码能够加密吗?

邻居的猫1个月前 (12-09)数据库2065

建立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;

扫描二维码推送至手机访问。

版权声明:本文由51Blog发布,如需转载请注明出处。

本文链接:https://www.51blog.vip/?id=543

分享给朋友:

“MySQL主从中仿制账号密码能够加密吗?” 的相关文章

Redis的ZSet底层数据结构,ZSet类型全面解析

Redis的ZSet底层数据结构,ZSet类型全面解析

文章目录 一、ZSet有序调集类型 1.1 简介 1.2 运用场景 1.3 底层结构 1.4 ZSet常用指令 二、ZSet底层结构详解 2.1 数据结构 2.2 紧缩列表ZipList 2.3 跳表详解 2.3.1 跳表是什么(what) 2.3.2 跳表怎样做的(how) 2.3.3...

oracle删除所有表,Oracle数据库中删除所有表的全面指南

Oracle数据库中删除所有表的全面指南在Oracle数据库管理中,有时可能需要删除所有的表,这可能是因为数据库重构、迁移到新版本或者清理不再需要的测试数据。本文将详细介绍如何在Oracle数据库中删除所有表,并提供一些重要的注意事项。准备工作在执行删除所有表的操作之前,以下准备工作是必不可少的:...

个人征信大数据查询,了解信用状况,守护个人金融安全

您可以通过以下几种途径查询个人征信大数据:1. 中国人民银行征信中心: 提供个人信用报告查询服务及异议申请线上办理,确保信息安全。2. 个人信用信息服务平台: 该平台提供个人信用报告查询服务,需通过银行卡或数字证书验证身份,查询结果一般在24小时内反馈。3. 信用中国:...

oracle查看当前用户,Oracle数据库中查看当前用户的方法详解

oracle查看当前用户,Oracle数据库中查看当前用户的方法详解

在Oracle数据库中,你可以使用`USER`或`SYS_CONTEXT`来查看当前用户。下面是两个查询的示例:1. 使用`USER`:```sqlSELECT USER FROM DUAL;```2. 使用`SYS_CONTEXT`:```sqlSELECT SYS_CONTEXT FROM DU...

spark大数据分析,大数据时代的利器

spark大数据分析,大数据时代的利器

Apache Spark 是一个开源的大数据处理框架,它提供了一个快速、通用和易于使用的大数据处理平台。Spark 支持多种数据源,包括 Hadoop、Hive、Cassandra、HBase、Tachyon 等,并且提供了多种语言 API,包括 Scala、Java、Python 和 R。以下是...

mysql替换,MySQL 替换函数简介

mysql替换,MySQL 替换函数简介

MySQL替换操作通常是指在一个字符串中替换指定的子字符串。在MySQL中,可以使用`REPLACE`函数来实现这个功能。`REPLACE`函数的语法如下:```sqlREPLACE``` `str`:要替换的原始字符串。 `search_str`:要被替换的子字符串。 `replace_str`:...