欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

Shell下实现免密码快速登陆MySQL数据库的方法

程序员文章站 2022-09-07 21:58:55
背景 当我们在 shell 下想要通过 mysql-client 登陆到 mysql 数据库的时候,我们总是需要非常麻烦的输入一次又一次的密码。 而且,如果你的 roo...

背景

当我们在 shell 下想要通过 mysql-client 登陆到 mysql 数据库的时候,我们总是需要非常麻烦的输入一次又一次的密码。

而且,如果你的 root 密码是高度随机的话(lastpass大法好),那么你登陆一次 mysql 数据库的成本就会非常大了。

通常我们登陆数据库的时候都是这样登陆的,如下

root@imlonghao:~# mysql -uroot -p
enter password: 

那么,有没有一个办法能够既安全,又能简单方便地登陆到数据库去呢?

方法

答案当然是有的,而且,mysql 也已经帮我们想过这个问题了!

参考链接:end-user guidelines for password security

使用 .my.cnf 快速登陆

在 ~/ 目录新建一个 .my.cnf 文件。当然,如果你已经有这个文件了,直接修改这个文件即可!

我个人喜欢用 vim 大法,于是我们就可以这样

vim ~/.my.cnf

然后在文件中写入下面的信息

[client]
password=your_pass
user=your_user

注意:修改 your_pass 和 your_user 为你想要登陆用户的密码和用户名

下面是一个例子:

[client]
password=mysqlrootpassword123321
user=root

如果你已经有 .my.cnf 这个文件了,就在 [client] 栏位写入信息即可!

注意:由于 .my.cnf 文件中明文写了你的密码,因此要注意设置这个文件的文件权限

root@imlonghao:~# chmod 400 ~/.my.cnf

保存后,我们就可以直接使用 mysql 命令登陆 mysql 数据库了!

注:如果你需要指定一个设置文件而不使用默认的 ~/.my.cnf 的话,就需要使用 --defaults-file=file_name 参数了。例:

root@imlonghao:~# mysql --defaults-file=/home/imlonghao/mysql-opts

使用环境变量 mysql_pwd 快速登陆

mysql优先会使用环境变量中的参数作为运行参数

root@imlonghao:~# export mysql_pwd=your_pass

设置后,再次登陆 mysql 就不需要再次输入密码了。

不过需要注意的是,如果你退出了当前的 shell 的话,这个环境变量就会消失。

更需要注意的是,你在 shell 输入的命令,会被自动保存, history 就可以看到你输入过的命令。

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作能带来一定的帮助,如果有疑问大家可以留言交流,谢谢大家对的支持。