Shell下实现免密码快速登陆MySQL数据库的方法
数据库  /  管理员 发布于 7年前   159
背景
当我们在 Shell 下想要通过 mysql-client 登陆到 MySQL 数据库的时候,我们总是需要非常麻烦的输入一次又一次的密码。
而且,如果你的 root 密码是高度随机的话(LastPass大法好),那么你登陆一次 MySQL 数据库的成本就会非常大了。
通常我们登陆数据库的时候都是这样登陆的,如下
root@imlonghao:~# mysql -uroot -pEnter password:
那么,有没有一个办法能够既安全,又能简单方便地登陆到数据库去呢?
方法
答案当然是有的,而且,MySQL 也已经帮我们想过这个问题了!
参考链接:End-User Guidelines for Password Security
使用 .my.cnf 快速登陆
在 ~/ 目录新建一个 .my.cnf 文件。当然,如果你已经有这个文件了,直接修改这个文件即可!
我个人喜欢用 vim 大法,于是我们就可以这样
vim ~/.my.cnf
然后在文件中写入下面的信息
[client]password=your_passuser=your_user
注意:修改 your_pass 和 your_user 为你想要登陆用户的密码和用户名
下面是一个例子:
[client]password=mysqlrootpassword123321user=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 就可以看到你输入过的命令。
总结
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作能带来一定的帮助,如果有疑问大家可以留言交流,谢谢大家对的支持。
122 在
学历:一种延缓就业设计,生活需求下的权衡之选中评论 工作几年后,报名考研了,到现在还没认真学习备考,迷茫中。作为一名北漂互联网打工人..123 在
Clash for Windows作者删库跑路了,github已404中评论 按理说只要你在国内,所有的流量进出都在监控范围内,不管你怎么隐藏也没用,想搞你分..原梓番博客 在
在Laravel框架中使用模型Model分表最简单的方法中评论 好久好久都没看友情链接申请了,今天刚看,已经添加。..博主 在
佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 @1111老铁这个不行了,可以看看近期评论的其他文章..1111 在
佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 网站不能打开,博主百忙中能否发个APP下载链接,佛跳墙或极光..
Copyright·© 2019 侯体宗版权所有·
粤ICP备20027696号