内容简介:Shell 下免密码快速登陆 MySQL 数据库
背景
当我们在 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 就可以看到你输入过的命令。
参考链接
利用.my.cnf,安全实现Shell下MySQL免输入密码登录
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持 码农网
本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
程序员2010精华本
程序员杂志社 / 电子工业 / 2011-1 / 49.00元
《程序员(2010精华本)》主要内容:《程序员》创刊10年来,每年末编辑部精心打造的“合订本”已经形成一个品牌,得到广大读者的认可和喜爱。今年,《程序员》杂志内容再次进行了优化整合,除了每期推出的一个大型专题策划,各版块也纷纷以专题、策划的形式,将每月的重点进行了整合,让内容非常具有凝聚力,如专题篇、人物篇、实践篇等。另外杂志的版式、色彩方面也有了很大的飞跃,给读者带来耳目一新的阅读体验。一起来看看 《程序员2010精华本》 这本书的介绍吧!