【MySQL Tips】除了指定密码外 MySQL客户端更好的选择——登录路径

news2025/1/13 15:41:30

在实际项目中,我们在生产(环境)发布新版本或运维时,使用 mysql 、mysqladmin、mysqlimport、mysqldump、mysqlpump 等 MySQL 客户端程序时,每次都需要输入密码,一般都会采用更安全的互动输入密码模式,而不会采用暴露密码却更便捷的在命令行中直接输入密码的方式。一旦连接的服务器多了,这样便会令人感到厌烦。因而,有其他更好的方式吗?答案是肯定的,比如今天要讲的 mysql_config_editor ,它的优点是可以以一定的加密手段将登录路径选项组以非明文的形式存储在登录路径文件中,在后续使用时可以更方便快捷的使用--login-path=已定义的登录路径名称选项来连接 MySQL 数据库;缺点是安全防护能力有限,不如使用 SSL 协议、TLS 协议的安全认证安全。

文章目录

  • mysql_config_editor 简介
  • 演示
    • 创建登陆选项
    • 打印查看已创建的登录路径
    • 额外功能:复用包含多数相同登录选项的登录路径实现快速客户端连接
    • 为 test 实例创建登录路径并测试
    • 使用本地登录路径连接远程服务器
  • 改进建议
  • 更多信息

mysql_config_editor 简介

mysql_config_editor 实用程序使您能够将身份验证凭据存储在名为.mylogin.cnf的模糊(加密)登录路径文件中。文件位置在 Windows 上为%APPDATA%\MySQL目录,在非 Windows 系统上为当前用户的主目录。MySQL 客户端程序可以稍后读取该文件,以获取连接到 MySQL 服务器的身份验证凭据。

mylogin.cnf登录路径文件的未加密格式由选项组组成,与其他选项文件类似。mylogin.cnf中的每个选项组都称为**“登录路径( Login Path )”**,这是一个仅允许某些选项的组:hostuserpasswordportsocket。将登录路径选项组视为一组选项,这些选项指定要连接到哪个 MySQL 服务器以及要使用哪个帐户进行身份验证。下面是一个未加密的示例:

[client]
user = mydefaultname
password = mydefaultpass
host = 127.0.0.1
[mypath]
user = myothername
password = myotherpass
host = localhost

当您调用客户端程序连接到服务器时,客户端会将.mylogin.cnf与其他选项文件一起使用。它的优先级高于其他选项文件,但低于客户端命令行上明确指定的选项。

如果指定--login-path=mypath,则 mysql_config_editor 会创建一个名为 mypath 的登录路径。之后,可以使用任意支持该选项的 MySQL 客户端程序,如 mysql 客户端,从其他选项文件中读取[client][mysql],从登录路径文件中读取[client][mysql][mypath]

mysql_config_editor 采用模糊化明文文本的方式加密,因而,虽然可以避免在配置文件或命令行中键入密码产生的暴露密码或每次都要输入的繁琐问题,提供了一定的安全性,但却无法防止坚定的攻击者在获得系统管理权限后花一些功夫来破解它。

演示

在主机名为 natnet-source 的虚拟机上,我启动了两个 MySQL 服务器实例,一个名为source,一个名为test 。由下图可知,两个实例运行正常。
在这里插入图片描述

创建登陆选项

此处创建一个名为root_src_3306的登录路径,使用 TCP/IP 端口 3306,主机名natnet-sourceroot账户连接 ;第二个登录路径名称为root_sock,使用 Unix 套接字,root账户连接。

mysql_config_editor set -u root -P 3306 -h natnet-source -p --login-path=root_src_3306
mysql_config_editor set -u root -S /var/lib/mysql/data/source/mysql.sock -p --login-path=root_sock

在这里插入图片描述

打印查看已创建的登录路径

执行下面的命令,查看我已定义的登录路径:

mysql_config_editor print --all

在这里插入图片描述
可见,我仅为 MySQL source服务器实例建立了两个登录路径,并没有为test实例创建登录路径。

额外功能:复用包含多数相同登录选项的登录路径实现快速客户端连接

将两个实例的root@localhost的密码设置得相同,所以可以在命令行中指定--port=3307socket=/var/lib/mysql-test/mysql.sock来复用本来为source实例创建的登陆选项。

mysql --login-path=root_src_3306 -P 3307
mysql> select @@hostname,@@port,@@socket;

在这里插入图片描述

mysql --login-path=root_sock -S /var/lib/mysql-test/mysql.sock -e "select @@hostname,@@port,@@socket;"

在这里插入图片描述

可见成功了!所以,这里点出了登录路径的一个额外功能:当不同 MySQL 实例存在很多相同的选项时,可以利用**“登录路径+命令行选项”**的方式快速实现客户端连接。

为 test 实例创建登录路径并测试

mysql_config_editor set -u root -P 3307 -h natnet-source -p --login-path=root_test_3307
mysql_config_editor set -u root -S /var/lib/mysql-test/mysql.sock -p --login-path=root_test_sock

在这里插入图片描述

测试其可用性。

[root@natnet-source ~]# mysql --login-path=root_test_3307 -e "select @@hostname,@@port,@@socket;"
+---------------+--------+--------------------------------+
| @@hostname    | @@port | @@socket                       |
+---------------+--------+--------------------------------+
| natnet-source |   3307 | /var/lib/mysql-test/mysql.sock |
+---------------+--------+--------------------------------+
[root@natnet-source ~]# mysql --login-path=root_test_sock -e "select @@hostname,@@port,@@socket;"
+---------------+--------+--------------------------------+
| @@hostname    | @@port | @@socket                       |
+---------------+--------+--------------------------------+
| natnet-source |   3307 | /var/lib/mysql-test/mysql.sock |
+---------------+--------+--------------------------------+

使用本地登录路径连接远程服务器

使用root_src_3306登录路径和-h natnet-replica1连接到 natnet-replica1 主机。

[root@natnet-source lib]# mysql --login-path=root_src_3306 -h natnet-replica1 -e "select @@hostname,@@port,@@socket;"
+-----------------+--------+-----------------------------------------+
| @@hostname      | @@port | @@socket                                |
+-----------------+--------+-----------------------------------------+
| natnet-replica1 |   3306 | /var/lib/mysql/data/replica1/mysql.sock |
+-----------------+--------+---

同样,我们也可以使用内网 IP (Host-Only 网络)访问 natnet-replica1 主机,此时使用-h hostonly-replica1

[root@natnet-source lib]# mysql --login-path=root_src_3306 -h hostonly-replica1 -e "select @@hostname,@@port,@@socket;"
+-----------------+--------+-----------------------------------------+
| @@hostname      | @@port | @@socket                                |
+-----------------+--------+-----------------------------------------+
| natnet-replica1 |   3306 | /var/lib/mysql/data/replica1/mysql.sock |
+-----------------+--------+-----------------------------------------+
[root@natnet-source lib]# cat /etc/hosts
127.0.0.1   localhost localhost.localdomain localhost4 localhost4.localdomain4
::1         localhost localhost.localdomain localhost6 localhost6.localdomain6

10.0.2.1                natnet-win                      win.nat-net
10.0.2.2                natnet-source           source.nat-net
10.0.2.3                natnet-replica1         replica1.nat-net
10.0.2.4                natnet-replica2         replica2.nat-net

192.168.56.2    hostonly-win            win.host-only
192.168.56.2    hostonly-source         source.host-only
192.168.56.3    hostonly-replica1       replica1.host-only
192.168.56.4    hostonly-replica2       replica2.host-only

改进建议

在实际项目中,我们以前大多在项目中将连接数据库的用户名和密码存储在配置文件中,有些以变量定义形式存在,有些以 URI 连接(字符)串形式存在。这种方法虽然常用,但使用多了,也表现出一些缺陷成为业务痛点,比如在配置文件中明文存储的安全性;数据库因密码安全策略要求需定期修改,导致后端配置文件也需要相应的修改。如果 MySQL 能做到可以让 MySQL Connector 可以识别 login-path 选项就好了,这样我们就无需在连接串中输入用户名,密码,主机名,端口号,通讯协议等信息了,而只需要指定登录路径就可以了。这样无论 DBA、操作系统运维人员如何修改密码,只要他们把.mylogin.cnf文件同步更新了,我们在客户端服务器复制一份就可以了。

更多信息

更多信息,请参考 4.6.7 mysql_config_editor —— MySQL 配置实用程序 。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/149180.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

UOS 22.0家庭版使用体验

1月4日这天我收到了UOS的22.0版本的推送,更新后新增了未成年人账户和学习中心,由于是虚拟机中所以无法新增未成年人账户,于是我制作了Linux to go(LTG)但是由于我的U盘不是固态U盘所以我用普通的更新就卡在了更新界面。…

Linux下第一个程序:进度条

一、前言 进度条程序曾经是百度的一道面试题。 这一期博客我们来介绍代码和原理究竟是怎样的。 二、知识点 1.回车和换行 通常意义上我们以为回车就是就是键盘的那个回车键。 其实不然。回车其实是不换行,回到本行开头。我们通常用符号表示为 \r 。 换行就是新…

Docker Compose安装

目录 前言 1. 二进制包在线安装 2. 二进制包离线安装 2.1 下载安装包。 2.2 上传到linux服务器 2.3 解压到/usr/local/bin/docker-compose目录。 2.4 将可执行权限应用于二进制文件 2.5 创接建软链(可选) 2.6 测试是否安装成功 3. 国内镜像二进…

Linux应用编程---3.wait()函数

Linux应用编程—3.wait()函数 ​ 首先引入三个函数,我们通过在Linux终端下查阅它的作用与使用方法。 ​ Linux终端命令下输入:man exit,敲击回车键即可打开exit函数详情页。 图1 exit编程手册​ exit函数的作用是终止一般进程,没…

12、Java基础之泛型的使用

一、泛型的理解1、泛型的概念所谓泛型,就是允许在定义类、接口时通过一个标识表示类中某个属性的类型或者是某个方法的返回值及参数类型。这个类型参数将在使用时(例如, 继承或实现这个接口,用这个类型声明变量、创建对象时&#…

[游戏测试]基于人工智能博弈树,极大极小(Minimax)搜索算法并使用Alpha-Beta剪枝算法优化实现的可人机博弈的AI智能五子棋游戏。

⬜⬜⬜ 🐰🟧🟨🟩🟦🟪 (*^▽^*)欢迎光临 🟧🟨🟩🟦🟪🐰⬜⬜⬜ ✏️write in front✏️ 📝个人主页:陈丹宇jmu &a…

关于idea中查看源码时的注释以及.class与.java文件的问题

文章目录问题描述解决方法问题描述 在使用idea编辑器学习java的时候发现有的人的idea将鼠标方法java自带的类方法上会出现解释注释,但是我的idea不可以,经过查询发现是idea中jdk选择的问题。 下图为能查看注释时的截图 按住ctrl点击方法名进入&#x…

分治和递归

目录 分治的概念: 递归的概念: 分治策略的特征: 分治法步骤: 例:阶乘! 迭代 递归 关于递归使用栈 斐波拉切数列 迭代 递归 分治的概念: 将一个难以直接解决的大问题(规模大…

【年终总结】我的前端之行,回顾2022,展望2023

🐱个人主页:不叫猫先生 🙋‍♂️作者简介:前端领域新星创作者、华为云享专家、阿里云专家博主,专注于前端各领域技术,共同学习共同进步,一起加油呀! 💫系列专栏&#xff…

Vivado综合属性之MAX_FANOUT

本文介绍了综合属性MAX_FANOUT对Schematic的影响,通过本文可以理解通过寄存器复制的方式可以降低扇出。 高扇出信号可能会因为布线拥塞而出现时序问题。常用的规避方法是通过寄存器复制的方式降低扇出,可通过MAX_FANOUT实现寄存器复制。 MAX_FANOUT既可…

为金融业保驾护航,浪潮存储容灾方案获得权威媒体认可

近日,在2022中国金融科技年会上,经权威IT专家多项严格评审,浪潮金融行业数据存储与容灾解决方案,凭借安全、可靠、经济、高效四大优势,能够满足金融业务服务永远在线、数据永不丢失、性能永远满足、容量永远充足的核心…

【Linux】Linux编译器 gcc 的使用 | 动静态库的初步认识

👑作者主页:进击的安度因 🏠学习社区:进击的安度因(个人社区) 📖专栏链接:Linux 文章目录一、前言二、gcc 演示翻译环境1、预处理2、编译3、汇编4、链接5、总结三、动静态链接库1、库…

代码随想录算法训练营第6天 1.两数之和、242. 有效的字母异位词、349.两个数组的交集

代码随想录算法训练营第6天 1.两数之和、242. 有效的字母异位词、349.两个数组的交集 两数之和 力扣题目链接(opens new window) 给定一个整数数组 nums 和一个目标值 target,请你在该数组中找出和为目标值的那 两个 整数,并返回他们的数组下标。 首…

JS数字日期转中文日期(封装函数,dayjs转换时间格式)

JS数字日期转中文日期往期相关文章场景复现封装函数(数字日期转中文日期)实际应用往期相关文章 文章内容文章链接JS数组对象——根据日期进行排序,按照时间进行升序或降序排序https://blog.csdn.net/XSL_HR/article/details/128579840?spm1…

Markdown使用说明

Markdown使用说明欢迎使用Markdown编辑器新的改变功能快捷键合理的创建标题,有助于目录的生成如何改变文本的样式插入链接与图片如何插入一段漂亮的代码片生成一个适合你的列表创建一个表格设定内容居中、居左、居右SmartyPants创建一个自定义列表如何创建一个注脚注…

[网鼎杯 2020 朱雀组]phpweb

目录 信息收集 方法一:in_array()函数绕过 方法二:反序列化漏洞利用 信息收集 抓个包,发现POST传入以下内容 funcdate&pY-m-dh%3Ai%3Asa func和p的值分别为一个待执行的函数和函数的参数 构造payload 尝试funcphpinfo&p 回显 H…

【学习笔记之Linux】权限

权限概念 一件事是否允许被谁“做”,这就是权限。权限 用户 文件属性。   在Linux上,用户分为普通用户和root。root是超级管理员 ≈ 天王老子,只能够有一个。root的命令提示符是#;普通用户通过root创建,可以有多个…

【案例教程】地下水环评(一级)实践技术及Modflow地下水数值模拟

【前沿】地下水数值模拟技术应用与地下水环评报告编制方法实践线上直播课程,主要围绕的环评导则,结合不同行业类别,实例讲解地下水环境影响评价的原则、内容、工作程序、方法。包括数据处理分析、数值模型构建以及环评报告编写等。涉及地下水…

【自学C++】C++ int

C int C int教程 C 中的 int 用来表示一个 整数,也可以叫做整型,int 的取值范围是介于 short 和 long 之间的。 C int定义详解 语法 int varname value;参数 参数描述int定义 int 类型变量使用的类型。varname变量名。value可选,变量的…

Linux应用编程---9.消息队列

Linux应用编程—9.消息队列 ​ 消息队列用于进程之间的通讯,可以在如父子进程、兄弟进程这样的具有亲缘关系的进程之间传递数据,也可以用于具有非亲缘关系的进程之间通讯。消息队列可以传递结构体,所以可以发送任意数据类型。与消息队列有关…