MySQL安全輸入密碼的一些操作介紹
當(dāng)我們運(yùn)行mysql客戶(hù)端連接mysql服務(wù)器的時(shí)候,以一種暴露的可被其他用戶(hù)發(fā)現(xiàn)的方式指定我們的密碼是不妥的。我們輸入密碼的方式有四種,其中每一種都有一定風(fēng)險(xiǎn)。下面就分別說(shuō)下這四種方式:
MySQL密碼輸入的安全操作(翻譯)
第一種:直接在命令行后使用 -pyour_pass 或者r --password=your_pass 這兩種選項(xiàng)。
舉例:
shell> mysql -u ksharpdabu -pksharppassword db_name
這種方式很方便,但是不安全,因?yàn)樵谀承┫到y(tǒng)里,通過(guò)這種方式輸入的密碼對(duì)于一些系統(tǒng)狀態(tài)程序,比如ps命令變得可見(jiàn),可以讓其他用戶(hù)調(diào)用來(lái)顯示你的命令。一般mysql客戶(hù)端通常會(huì)在初始化序列期間用零覆蓋命令行參數(shù),但是仍然有一個(gè)短暫間隔時(shí)間內(nèi)參數(shù)值可見(jiàn)的。
比如,你使用shell> mysql -u ksharpdabu -pksharppassword db_name &
將命令掛起,用shell >ps –f 命令產(chǎn)看,就會(huì)發(fā)現(xiàn)結(jié)果如下:
[root@EVA ~]# ps -f UID PID PPID C STIME TTY TIME CMD root 11594 11591 0 19:54 pts/0 00:00:00 -bash root 11614 11594 0 19:54 pts/0 00:00:00 mysql –uksharpdabu -px xxxxx root 11616 11594 0 19:54 pts/0 00:00:00 ps -f
密碼參數(shù)值變成了星號(hào),不可見(jiàn),但是,如果你kill的時(shí)候,還是能看到你的密碼參數(shù)值。
第二種:使用一個(gè) -p 或者 --password 選項(xiàng)(后面不指定密碼),在這種情況下,客戶(hù)端程序請(qǐng)求來(lái)自終端的密碼:
shell>mysql -u ksharp -p da_name
Enter password:*********
因?yàn)樗鼘?duì)其他用戶(hù)不可見(jiàn),與在命令行指定相比,這樣登陸mysql服務(wù)器會(huì)更加安全。但是,這個(gè)只能用于交互式運(yùn)行程序,我們大部分情況下都是非交互的運(yùn)行一個(gè)腳本調(diào)用客戶(hù)端,就不能使用這種方法了。在某些系統(tǒng)中,甚至?xí)l(fā)現(xiàn)腳本的第一行被錯(cuò)誤地讀并解釋為我們的mysql登陸密碼。
第三種:在一個(gè)配置文件中存儲(chǔ)你的密碼,例如,在Unix中,可以在主目錄的“.my.cnf”文件中[client]節(jié)列出你的密碼。
舉例:
[client] password=your_pass
當(dāng)然,如果你在“.my.cnf”里存儲(chǔ)了密碼,就一定要保管好這個(gè)文件,除了自己本人,絕不能讓其他人能訪(fǎng)問(wèn)該文件。保證文件的訪(fǎng)問(wèn)模式是:400或600。
使用如下命令:
shell>chmod 600 .my.cnf
附上在Unix中,MySQL程序讀取啟動(dòng)選項(xiàng)的文件列表:
MYSQL_HOME是一個(gè)環(huán)境變量,包含服務(wù)器相關(guān)的my.cnf文件駐留的目錄路徑。
如果未設(shè)置MYSQL_HOME,并且DATADIR中有一個(gè)my.cnf文件,BASEDIR中沒(méi)有my.cnf文件,mysqld_safe將MYSQL_HOME設(shè)置為DATADIR。否則,如果未設(shè)置MYSQL_HOME并且在DATADIR中沒(méi)有my.cnf,則mysqld_safe將MYSQL_HOME設(shè)置為BASEDIR。
典型情況二進(jìn)制安裝的目錄為/usr/local/mysql/data或源代碼安裝的目錄為/usr/local/var。請(qǐng)注意這是配置時(shí)指定的數(shù)據(jù)目錄的位置,而不是 mysqld啟動(dòng)時(shí)用--datadir指定的。運(yùn)行時(shí)使用--datadir對(duì)尋找選項(xiàng)文件的服務(wù)器沒(méi)有效果,因?yàn)榉?wù)器在處理命令行參量之前尋找這些選項(xiàng)。
MySQL按照上述順序?qū)ふ疫x項(xiàng)文件,并讀存在的選項(xiàng)文件。如果你想要使用的某個(gè)選項(xiàng)文件不存在,則用明文文本編輯器創(chuàng)建。如果存在多個(gè)選項(xiàng)文件,文件中指定的后讀取的選項(xiàng)要優(yōu)先文件中指定的先讀取的選項(xiàng)。
注釋?zhuān)涸赨nix平臺(tái)上,MySQL忽略人人可寫(xiě)的配置文件。這是故意的,是一個(gè)安全措施。
任何可以在運(yùn)行MySQL程序時(shí)在命令行給出的長(zhǎng)選項(xiàng)也可以在選項(xiàng)文件中給出。要想列出程序的適用選項(xiàng),用--help選項(xiàng)運(yùn)行程序。
其他系統(tǒng)下的配置文件列表如下,
在Windows中,MySQL程序從以下文件讀取啟動(dòng)選項(xiàng):
第四種:在MYSQL_PWD環(huán)境變量中存儲(chǔ)密碼
但是這種指定MySQL密碼的方法是極不安全的,不應(yīng)該使用。ps的某些版本包括顯示運(yùn)行進(jìn)程的環(huán)境的選
項(xiàng);如果你設(shè)定MYSQL_PWD,你的密碼將被運(yùn)行ps的所有人看見(jiàn),甚至在沒(méi)有這樣一個(gè)版本的ps的系統(tǒng)上,也可能被觀(guān)察到。
在Unix上,mysql的客戶(hù)端會(huì)將執(zhí)行的命令保存在歷史記錄文件里。在默認(rèn)情況下,這個(gè)文件被命名為 .mysql_history ,創(chuàng)建在你的home目錄下。密碼作為純文本記錄在如 CREATE USER, GRANT, 和 SET PASSWORD 這些語(yǔ)句里面。所以如果使用了這些語(yǔ)句,他們就被記錄在這個(gè)歷史文件里。為了保證安全,應(yīng)該嚴(yán)格顯示這個(gè)文件的訪(fǎng)問(wèn)模式,就和對(duì)剛才說(shuō)的 .my.cnf 文件一樣。
如果你的命令解釋器配置為保持歷史,這些歷史記錄文件,其中將包含在命令行中輸入MySQL的密碼。例如,bash中使用?/.bash_history的。任何這樣的文件應(yīng)該有一個(gè)嚴(yán)格的訪(fǎng)問(wèn)模式。
相關(guān)文章
用于A(yíng)pp服務(wù)端的MySQL連接池(支持高并發(fā))
這篇文章主要介紹了用于A(yíng)pp服務(wù)端的MySQL連接池,并支持高并發(fā),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2015-12-12mysql 8.0.18 壓縮包安裝及忘記密碼重置所遇到的坑
這篇文章主要介紹了mysql 8.0.18 壓縮包安裝及忘記密碼重置所遇到的坑,本文給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2019-12-12mysql 如何使用JSON_EXTRACT() 取json值
這篇文章主要介紹了mysql如何使用JSON_EXTRACT() 取json值的操作方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-07-07Window 下安裝Mysql5.7.17 及設(shè)置編碼為utf8的方法
這篇文章主要介紹了Window 下安裝Mysql5.7.17 及設(shè)置編碼為utf8的方法,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友可以參考下2017-03-03MySQL數(shù)據(jù)庫(kù)誤操作后快速回滾的方法
這篇文章主要介紹了MySQL數(shù)據(jù)庫(kù)誤操作后快速回滾的方法的相關(guān)資料,需要的朋友可以參考下2016-12-12微信昵稱(chēng)帶符號(hào)導(dǎo)致插入MySQL數(shù)據(jù)庫(kù)時(shí)出錯(cuò)的解決方案
Mysql的utf8編碼最多3個(gè)字節(jié),而Emoji表情或者某些特殊字符是4個(gè)字節(jié),所以會(huì)導(dǎo)致帶有表情的昵稱(chēng)插入數(shù)據(jù)庫(kù)時(shí)出錯(cuò),下面給大家分享下解決方案,需要的朋友參考下吧2016-12-12mysql 常用數(shù)據(jù)庫(kù)語(yǔ)句 小練習(xí)
一個(gè)mysql小練習(xí) 建表 查詢(xún) 修改表 增加字段 刪除字段2009-07-07MariaDB(Mysql分支)my.cnf配置文件中文注釋版
這篇文章主要介紹了MariaDB my.cnf配置文件中文注釋版,MariaDB是Mysql的一個(gè)分支,完全兼容Mysql,需要的朋友可以參考下2014-06-06