1.修改root用戶口令,刪除空口令php
缺省安裝的MySQL的root用戶是空密碼的,爲了安全起見,必須修改成強密碼,所謂的強密碼,至少8位,由字母、數字和符號組成的不規律密碼。使用MySQL自帶的命令mysaladmin修改root密碼,同時也能夠登錄數據庫,修改數據庫mysql下的user表的字段內容,修改方法以下所示:html
注意:安裝的mapn默認的mysql密碼是rootmysql
a.登陸mysqllinux
/usr/local/mysql/bin/mysql -u root -p 123456ios
b.進入到mysql控制檯後你會看到四個數據庫information_schema,test,mysql,ftp(這些是針對mapn而言的)sql
修改數據庫mysql中的user表:shell
update user set password=password("abcdef") where user="root";數據庫
c.#mysql> flush privileges; //強制刷新內存受權表,不然用的仍是在內存緩衝的口令安全
2.刪除默認數據庫和數據庫用戶bash
通常狀況下,MySQL數據庫安裝在本地,而且也只須要本地的php腳本對mysql進行讀取,因此不少用戶不須要,尤爲是默認安裝的用戶。MySQL初始化後會自動生成空用戶和test庫,進行安裝的測試,這會對數據庫的安全構成威脅,有必要所有刪除,最後的狀態只保留單個root便可,固然之後根據須要增長用戶和數據庫。
#mysql> show databases;
#mysql> drop database test; //刪除數據庫test
#use mysql;
#delete from db; //刪除存放數據庫的表信息,由於尚未數據庫信息。
#mysql> delete from user where not (user=’root’) ; // 刪除初始非
root的用戶
#mysql> delete from user where user=’root’ and password=」; //刪除空密碼的root,儘可能重複操做
Query OK, 2 rows affected (0.00 sec)
#mysql> flush privileges; //強制刷新內存受權表。
3.改變默認mysql管理員賬號
4.關於密碼的管理
密碼是數據庫安全管理的一個很重要因素,不要將純文本密碼保存到數據庫中。若是你的計算機有安全危險,入侵者能夠得到全部的密碼並使用它們。相反,應使用 MD5()、SHA1()或單向哈希函數。也不要從詞典中選擇密碼,有專門的程序能夠破解它們,請選用至少八位,由字母、數字和符號組成的強密碼。在存取密碼時,使用mysql的內置函數password()的sql語句,對密碼進行加密後存儲。例如如下方式在users表中加入新用戶。
#mysql> insert into users values (1,password(1234),’test’);
5.使用獨立用戶運行msyql
絕對不要做爲使用root用戶運行MySQL服務器。這樣作很是危險,由於任何具備FILE權限的用戶可以用root建立文件(例如,~root/.bashrc)。mysqld拒絕使用root運行,除非使用–user=root選項明顯指定。應該用普通非特權用戶運行 mysqld。正如前面的安裝過程同樣,爲數據庫創建獨立的linux中的mysql帳戶,該帳戶用來只用於管理和運行MySQL。
要想用其它Unix用戶啓動mysqld,,增長user選項指定/etc/my.cnf選項文件或服務器數據目錄的my.cnf選項文件中的[mysqld]組的用戶名。
#vi /etc/my.cnf
[mysqld]
user=mysql
該命令使服務器用指定的用戶來啓動,不管你手動啓動或經過mysqld_safe或mysql.server啓動,都能確保使用mysql的身份。也能夠在啓動數據庫是,加上user參數。
# /usr/local/mysql/bin/mysqld_safe –user=mysql &
做爲其它linux用戶而不用root運行mysqld,你不須要更改user表中的root用戶名,由於MySQL帳戶的用戶名與linux帳戶的用戶名無關。確保mysqld運行時,只使用對數據庫目錄具備讀或寫權限的linux用戶來運行。
6.禁止遠程鏈接數據庫
在命令行netstat -ant下看到,默認的3306端口是打開的,此時打開了mysqld的網絡監聽,容許用戶遠程經過賬號密碼鏈接數本地據庫,默認狀況是容許遠程鏈接數據的。爲了禁止該功能,啓動skip-networking,不監聽sql的任何TCP/IP的鏈接,切斷遠程訪問的權利,保證安全性。假如須要遠程管理數據庫,可經過安裝PhpMyadmin來實現。假如確實須要遠程鏈接數據庫,至少修改默認的監聽端口,同時添加防火牆規則,只容許可信任的網絡的 mysql監聽端口的數據經過。
# vi /etc/my.cf
將#skip-networking註釋去掉。
# /usr/local/mysql/bin/mysqladmin -u root -p shutdown //中止數據庫
#/usr/local/mysql/bin/mysqld_safe –user=mysql & //後臺用mysql用戶啓動mysql
7.限制鏈接用戶的數量
數據庫的某用戶屢次遠程鏈接,會致使性能的降低和影響其餘用戶的操做,有必要對其進行限制。能夠經過限制單個帳戶容許的鏈接數量來實現,設置my.cnf 文件的mysqld中的max_user_connections變量來完成。GRANT語句也能夠支持資源控制選項來限制服務器對一個帳戶容許的使用範圍。
#vi /etc/my.cnf
[mysqld]
max_user_connections 2
8.用戶目錄權限限制
默認的mysql是安裝在/usr/local/mysql,而對應的數據庫文件在/usr/local/mysql/var目錄下,所以,必須保證該目錄不能讓未經受權的用戶訪問後把數據庫打包拷貝走了,因此要限制對該目錄的訪問。確保mysqld運行時,只使用對數據庫目錄具備讀或寫權限的linux 用戶來運行。
# chown -R root /usr/local/mysql/ //mysql主目錄給root
# chown -R rotot /usr/local/mysql/var //確保數據庫目錄權限所屬mysql用戶
9.命令歷史記錄保護
數據庫相關的shell操做命令都會分別記錄在.bash_history,若是這些文件不慎被讀取,會致使數據庫密碼和數據庫結構等信息泄露,而登錄數據庫後的操做將記錄在.mysql_history文件中,若是使用update表信息來修改數據庫用戶密碼的話,也會被讀取密碼,所以須要刪除這兩個文件,同時在進行登錄或備份數據庫等與密碼相關操做時,應該使用-p參數加入提示輸入密碼後,隱式輸入密碼,建議將以上文件置空。
# rm .bash_history .mysql_history //刪除歷史記錄
# ln -s /dev/null .bash_history //將shell記錄文件置空
# ln -s /dev/null .mysql_history //將mysql記錄文件置空
10.禁止MySQL對本地文件存取
在mysql中,提供對本地文件的讀取,使用的是load data local infile命令,默認在5.0版本中,該選項是默認打開的,該操做令會利用MySQL把本地文件讀到數據庫中,而後用戶就能夠非法獲取敏感信息了,假如你不須要讀取本地文件,請務必關閉。應該禁止MySQL中用「LOAD DATA LOCAL INFILE」命令。網絡上流傳的一些攻擊方法中就有用它LOAD DATA LOCAL INFILE的,同時它也是不少新發現的SQL Injection攻擊利用的手段!黑客還能經過使用LOAD DATALOCAL INFILE裝載「/etc/passwd」進一個數據庫表,而後能用SELECT顯示它,這個操做對服務器的安全來講,是致命的。能夠在my.cnf中添加local-infile=0,或者加參數local-infile=0啓動mysql。
#/usr/local/mysql/bin/mysqld_safe –user=mysql –local-infile=0 &
#mysql> load data local infile ’sqlfile.txt’ into table users fields terminated by ‘,’;
#ERROR 1148 (42000): The used command is not allowed with this MySQL version
–local-infile=0選項啓動mysqld從服務器端禁用全部LOAD DATA LOCAL命令,假如須要獲取本地文件,須要打開,可是建議關閉。
11.MySQL服務器權限控制
MySQL權限系統的主要功能是證明鏈接到一臺給定主機的用戶,而且賦予該用戶在數據庫上的SELECT、INSERT、UPDATE和DELETE等權限(詳見user超級用戶表)。它的附加的功能包括有匿名的用戶並對於MySQL特定的功能例如LOAD DATA INFILE進行受權及管理操做的能力。
管理員能夠對user,db,host等表進行配置,來控制用戶的訪問權限,而user表權限是超級用戶權限。只把user表的權限授予超級用戶如服務器或數據庫主管是明智的。對其餘用戶,你應該把在user表中的權限設成’N'而且僅在特定數據庫的基礎上受權。你能夠爲特定的數據庫、表或列受權,FILE權限給予你用LOAD DATA INFILE和SELECT … INTO OUTFILE語句讀和寫服務器上的文件,任何被授予FILE權限的用戶都能讀或寫MySQL服務器能讀或寫的任何文件。(說明用戶能夠讀任何數據庫目錄下的文件,由於服務器能夠訪問這些文件)。 FILE權限容許用戶在MySQL服務器具備寫權限的目錄下建立新文件,但不能覆蓋已有文件在user表的File_priv設置Y或N。,因此當你不須要對服務器文件讀取時,請關閉該權限。
#mysql> load data infile ’sqlfile.txt’ into table loadfile.users fields terminated by ‘,’;
Query OK, 4 rows affected (0.00 sec) //讀取本地信息sqlfile.txt’
Records: 4 Deleted: 0 Skipped: 0 Warnings: 0
#mysql> update user set File_priv=’N’ where user=’root’; //禁止讀取權限
Query OK, 1 row affected (0.00 sec)
Rows matched: 1 Changed: 1 Warnings: 0
mysql> flush privileges; //刷新受權表
Query OK, 0 rows affected (0.00 sec)
#mysql> load data infile ’sqlfile.txt’ into table users fields terminated by ‘,’; //重登錄讀取文件
#ERROR 1045 (28000): Access denied for user ‘root’@'localhost’ (using password: YES) //失敗
# mysql> select * from loadfile.users into outfile ‘test.txt’ fields terminated by ‘,’;
ERROR 1045 (28000): Access denied for user ‘root’@'localhost’ (using password: YES)
爲了安全起見,隨時使用SHOW GRANTS語句檢查查看誰已經訪問了什麼。而後使用REVOKE語句刪除再也不須要的權限。
12.使用chroot方式來控制MySQL的運行目錄
Chroot是linux中的一種系統高級保護手段,它的創建會將其與主系統幾乎徹底隔離,也就是說,一旦遭到什麼問題,也不會危及到正在運行的主系統。這是一個很是有效的辦法,特別是在配置網絡服務程序的時候。
過crontab定時備份數據:
#!/bin/sh
time=`date +」(「%F」)」%R`
$/usr/local/mysql/bin/mysqldump -u nagios -pnagios nagios | gzip >/home/sszheng/nfs58/nagiosbackup/nagios_backup.$time.gz
# crontab -l
# m h dom mon dow command
00 00 * * * /home/sszheng/shnagios/backup.sh
恢復數據使用命令:
gzip -d nagios_backup.\(2008-01-24\)00\:00.gz
nagios_backup.(2008-01-24)00:00
#mysql –u root -p nagios < /home/sszheng/nfs58/nagiosbackup/nagios_backup.\(2008-01-24\)12\:00
15. Mysqld安全相關啓動選項
–local-infile[={0|1}]
若是用–local-infile=0啓動服務器,則客戶端不能使用LOCAL in LOAD DATA語句。
–old-passwords
強制服務器爲新密碼生成短(pre-4.1)密碼哈希。當服務器必須支持舊版本客戶端程序時,爲了保證兼容性這頗有用。
(OBSOLETE) –safe-show-database
在之前版本的MySQL中,該選項使SHOW DATABASES語句只顯示用戶具備部分權限的數據庫名。在MySQL 5.1中,該選項再也不做爲如今的 默認行爲使用,有一個SHOW DATABASES權限能夠用來控制每一個帳戶對數據庫名的訪問。
–safe-user-create
若是啓用,用戶不能用GRANT語句建立新用戶,除非用戶有mysql.user表的INSERT權限。若是你想讓用戶具備受權權限來建立新用戶,你應給用戶授予下面的權限:
mysql> GRANT INSERT(user) ON mysql.user TO ‘user_name’@'host_name’;
這樣確保用戶不能直接更改權限列,必須使用GRANT語句給其它用戶授予該權限。
–secure-auth
不容許鑑定有舊(pre-4.1)密碼的帳戶。
16.information_schema 安全
在用戶角度來看,INFORMATION_SCHEMA只是一個以插件方式存在的存儲引擎,編譯安裝的時候
–disable-information-schema 就好了
added TRIGGER_ACL check for I_S.TRIGGERS
經過文章,咱們把LAMP安全的內容都學了一遍,不會的能夠翻看前面的文章,但願大家的LAMP運行愈來愈好!