千家信息网

mysql_config_editor

发表于:2025-01-20 作者:千家信息网编辑
千家信息网最后更新 2025年01月20日,简介mysql_config_editor是一种存储mysql登录信息的工具。通过mysql_config_editor设置了登录信息后,在用mysql命令登录数据库时就可以只用一个--login-p
千家信息网最后更新 2025年01月20日mysql_config_editor

简介

mysql_config_editor是一种存储mysql登录信息的工具。
通过mysql_config_editor设置了登录信息后,在用mysql命令登录数据库时就可以只用一个--login-path=name 的参数指定在mysql_config_editor中设置的名称,而不用再输入host,user,password等信息
例如:
mysql --login-path=5637

通过mysql_config_editor设置的登录信息存储在名为.mylogin.cnf的配置文件中。在Windows系统中,这个文件在%APPDATA%\MySQL目录下,在linux系统中,这个文件在用户的home目录下

.mylogin.cnf的格式

在.mylogin.cnf中,可以存放多个数据库的登录信息,每个信息是一个login path选项组,每个组由由一个方括号括起来的名称作为开头,然后由host,user,password,port,socket中的一个或多个组成。
例如:
[client]
user = mydefaultname
password = mydefaultpass
host = 127.0.0.1
[mypath]
user = myothername
password = myotherpass
host = localhost

在通过mysql命令连接数据库时,如果没有指定--login-path选项或者没有指定--login-path=name将会默认读取.mylogin.cnf中client的配置内容。(就算指定了--login-path=name,也会读取client的内容。而且在.mylogin.cnf中,后面的内容会覆盖掉前面的内容,也就是说,如过clinet在name之后,那么在name中和client中同时设置了user,host之类的值,会以client中的为准。)
在.mylogin.cnf中的设置优先级高于其他配置文件中的,但是低于在命令行中输入的参数。

通过mysql_config_editor设置login path

添加login path

通过set命令可以添加login path
例如:mysql_config_editor set --login-path=name --host=hostname --user=user_name

set命令具有以下参数:

  • --help 显示帮助
  • --login-path=name,-G name
  • --host=host_name,-h host_name 主机名
  • --password,-p 密码,注意这个地方不能使用"="直接写入密码
  • --port=port_num,-P port_num 端口号
  • --socket=file_names,-S file_name 文件名
  • --user=user_name,-u user_name 用户名
  • --warn,-w 默认开启,提示警告信息,如果要忽略警告,使用--skip-warn 参数
    示例:
    删除login path

    通过remove命令可以删除login path或者login path中的指定选项。如果不指定--login-path,将删除clinet中的相关内容。
    remove具有以下参数

  • --host,-h 主机名
  • --login-path=name,-G name login path的名称,如果不指定,默认为clinet
  • --password,-p 密码
  • --port,-P 端口号
  • --socket,-S socket文件
  • --user,-u 用户名
  • --warn,-w 开启,提示警告信息,如果要忽略警告,使用--skip-warn 参数
清空login path

通过reset命令可以清空所有的配置信息
mysql_config_editor reset

显示login path

通过print命令可以显示已经设置过的配置文件信息
mysql_config_editor print
print命令具有以下参数:

  • --all 显示所有login-path的信息
  • --login-path=name,-G name 显示指定名称的login path的信息
    如果不指定参数,默认显示名称为client的login path的信息
    如果同时指定了--all和--login-path=name,那么显示所有login path的信息
    通过print命令显示的信息,其中的密码会以******替代
    示例:
    这里由于没有名称为client的login path,所有不加参数的print不会显示任何内容。

使用示例

在本地服务器上存在5637和5719两个版本的数据,他们具有不同的socket文件以及root密码。信息如下:
ps-ef |grep mysqld

为了方便连接,通过mysql_config_editor设置login path
mysql_config_editor set --login-path=5637 --socket=/tmp/mysql5637.sock --user=root --password
mysql_config_editor set --login-path=5719 --socket=/tmp/mysql5719.sock --user=root --password

检查login path是否设置成功
mysql_config_editor print --all

通过login path连接数据库
mysql --login-path=5719
mysql --login-path=5637

0