關(guān)于Shell下如何實(shí)現(xiàn)免密碼快速登陸MySQL數(shù)據(jù)庫(kù)的方法分享

這篇文章主要給大家介紹了在shell下實(shí)現(xiàn)免密碼快速登陸mysql數(shù)據(jù)庫(kù)的方法,文中通過示例代碼一步步介紹的非常詳細(xì),對(duì)大家具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面跟著小編來一起看看吧。

背景

當(dāng)我們?cè)?Shell 下想要通過 mysql-client 登陸到 MySQL 數(shù)據(jù)庫(kù)的時(shí)候,我們總是需要非常麻煩的輸入一次又一次的密碼。

而且,如果你的 root 密碼是高度隨機(jī)的話(LastPass大法好),那么你登陸一次 MySQL 數(shù)據(jù)庫(kù)的成本就會(huì)非常大了。

通常我們登陸數(shù)據(jù)庫(kù)的時(shí)候都是這樣登陸的,如下

root@imlonghao:~#?mysql?-uroot?-p  Enter?password:

那么,有沒有一個(gè)辦法能夠既mysql數(shù)據(jù)庫(kù),又能簡(jiǎn)單方便地登陸到數(shù)據(jù)庫(kù)去呢?

方法

答案當(dāng)然是有的,而且,MySQL 也已經(jīng)幫我們想過這個(gè)問題了!

參考鏈接:End-User Guidelines for Password Security

使用 .my.cnf 快速登陸

在 ~/ 目錄新建一個(gè) .my.cnf 文件。當(dāng)然,如果你已經(jīng)有這個(gè)文件了,直接修改這個(gè)文件即可!

我個(gè)人喜歡用 vim 大法,于是我們就可以這樣

vim?~/.my.cnf

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

[client]  password=your_pass  user=your_user

注意:修改 your_pass 和 your_user 為你想要登陸用戶的密碼和用戶名

下面是一個(gè)例子:

[client]  password=mysqlrootpassword123321  user=root

如果你已經(jīng)有 .my.cnf 這個(gè)文件了,就在 [client] 欄位寫入信息即可!

注意:由于 .my.cnf 文件中明文寫了你的密碼,因此要注意設(shè)置這個(gè)文件的文件權(quán)限

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

保存后,我們就可以直接使用 mysql 命令登陸 MySQL 數(shù)據(jù)庫(kù)了!

注:如果你需要指定一個(gè)設(shè)置文件而不使用默認(rèn)的 ~/.my.cnf 的話,就需要使用 –defaults-file=file_name 參數(shù)了。例:

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

使用環(huán)境mysql數(shù)據(jù)庫(kù) MYSQL_PWD 快速登陸

MySQL優(yōu)先會(huì)使用環(huán)境變量中的參數(shù)作為運(yùn)行參數(shù)

root@imlonghao:~#?export?MYSQL_PWD=your_pass

設(shè)置后,再次登陸 mysql 就不需要再次輸入密碼了。

不過需要注意的是,如果你mysql數(shù)據(jù)庫(kù)了當(dāng)前的 Shell 的話,這個(gè)環(huán)境變量就會(huì)消失。

更需要注意的是,你在 Shell 輸入的命令,會(huì)被自動(dòng)保存, history 就可以看到你輸入過的命令。

總結(jié)

? 版權(quán)聲明
THE END
喜歡就支持一下吧
點(diǎn)贊5 分享
站長(zhǎng)的頭像-小浪學(xué)習(xí)網(wǎng)月度會(huì)員