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),可以讓其他用戶調(diào)用來(lái)顯示你的命令。一般mysql客戶端通常會(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)(后面不指定密碼),在這種情況下,客戶端程序請(qǐng)求來(lái)自終端的密碼:
shell>mysql -u ksharp -p da_name
Enter password:*********
因?yàn)樗鼘?duì)其他用戶不可見(jiàn),與在命令行指定相比,這樣登陸mysql服務(wù)器會(huì)更加安全。但是,這個(gè)只能用于交互式運(yùn)行程序,我們大部分情況下都是非交互的運(yùn)行一個(gè)腳本調(diào)用客戶端,就不能使用這種方法了。在某些系統(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è)文件,除了自己本人,絕不能讓其他人能訪問(wèn)該文件。保證文件的訪問(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)。
注釋:在Unix平臺(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)上,也可能被觀察到。
在Unix上,mysql的客戶端會(huì)將執(zhí)行的命令保存在歷史記錄文件里。在默認(rèn)情況下,這個(gè)文件被命名為 .mysql_history ,創(chuàng)建在你的home目錄下。密碼作為純文本記錄在如 CREATE USER, GRANT, 和 SET PASSWORD 這些語(yǔ)句里面。所以如果使用了這些語(yǔ)句,他們就被記錄在這個(gè)歷史文件里。為了保證安全,應(yīng)該嚴(yán)格顯示這個(gè)文件的訪問(wèn)模式,就和對(duì)剛才說(shuō)的 .my.cnf 文件一樣。
如果你的命令解釋器配置為保持歷史,這些歷史記錄文件,其中將包含在命令行中輸入MySQL的密碼。例如,bash中使用?/.bash_history的。任何這樣的文件應(yīng)該有一個(gè)嚴(yán)格的訪問(wèn)模式。
聲明:本網(wǎng)頁(yè)內(nèi)容旨在傳播知識(shí),若有侵權(quán)等問(wèn)題請(qǐng)及時(shí)與本網(wǎng)聯(lián)系,我們將在第一時(shí)間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com