MySql常見問題之php無法連接至數(shù)據(jù)庫

前言

在linux上放置php代碼骡尽,發(fā)現(xiàn)啟動(dòng)httpd后訪問php頁面報(bào)錯(cuò):

Warning: mysql_connect(): Can't connect to MySQL server on 'xxx'

即php無法連接至指定的數(shù)據(jù)庫,在谷歌拙毫、百度查找許久后妈拌,終于在谷歌一篇文章中尋找到了類似的疑問與解答。

如果您正在尋找解決方案而我的解決方案對(duì)您不起作用狭园,我將列出最常見的解決方案:
1–確保正確配置了MySQL用戶權(quán)限读处。
2–確保MySQL在服務(wù)器上和正確的端口上運(yùn)行
3–確保selinux不會(huì)阻止MySQL端口或mysqld進(jìn)程

前兩點(diǎn)相信大家都能明白是怎么回事,也不會(huì)在這點(diǎn)上犯錯(cuò)唱矛,但是第三點(diǎn)罚舱,selinux,這是什么绎谦?


SELinux

SELinux是一個(gè) Linux 內(nèi)核模塊管闷,也是 Linux 的一個(gè)安全子系統(tǒng)。它的作用簡而言之就是最大限度地減小系統(tǒng)中服務(wù)進(jìn)程可訪問的資源窃肠。在這里包个,很顯然就是SELinux限制了httpd對(duì)mysql的訪問。

默認(rèn)情況下冤留,大部分系統(tǒng)的 SELinux 設(shè)置為 Enforcing碧囊。你要如何知道你的系統(tǒng)當(dāng)前是什么模式?你可以使用一條簡單的命令來查看纤怒,這條命令就是 getenforce糯而。如下圖:


getenforce.png

可以很明顯地看到,SELinux的狀態(tài)為Enforcing肪跋。
SELinux的狀態(tài):
1)enforcing:強(qiáng)制狀態(tài)歧蒋,每個(gè)受限的進(jìn)程都必然受限
2)permissive:啟用狀態(tài)土砂,每個(gè)受限的進(jìn)程違規(guī)操作不會(huì)被禁止
3)disabled:關(guān)閉狀態(tài)

設(shè)置 SELinux 的模式實(shí)際上很簡單——取決于你想設(shè)置什么模式。記酌涨ⅰ:永遠(yuǎn)不推薦關(guān)閉 SELinux萝映。最佳模式是 Enforcing 或者 Permissive。

enforcing 和 permissive 模式可以通過 setenforce 1|0 命令快速切換阐虚。

[root@localhost ~]# setenforce 0
[root@localhost ~]# setenforce 1
setenforce.png

解決方法

首先切換SELinux的模式:

[root@localhost ~]# setenforce 0;

然后使用setsebool命令序臂,它是用來修改SElinux策略內(nèi)各項(xiàng)規(guī)則的布爾值。即:

[root@localhost ~]# setsebool -P httpd_can_network_connect_db 1

至此实束,重新啟動(dòng)httpd奥秆,再次訪問php頁面即可。

附部分setsebool命令與用途:

setsebool -P allow_ftpd_anon_write=1          #允許ftpd匿名用戶可寫
setsebool -P ftp_home_dir 1                   #允許用戶訪問自己的根目錄
setsebool -P ftpd_is_daemon 1                 #允許daemon運(yùn)行ftpd
setsebool -P ftpd_disable_trans 1             #關(guān)閉SELINUX對(duì)ftpd的保護(hù)
setsebool -P allow_httpd_anon_write=1         #允許httpd匿名用戶可寫
setsebool -P allow_httpd_sys__anon_write=1    #同上
setsebool -P httpd_enable_cgi 1               #httpd被設(shè)置允許cgi被執(zhí)行
setsebool -P httpd_enable_homedirs 1          #允許訪問用戶的根目錄
setsebool -P httpd_tty_comm 1                 #允許httpd控制終端
setsebool -P httpd_unified 0                  #httpd之間相互獨(dú)立
setsebool -P httpd_builtin_ing 0              #同httpd環(huán)境一樣運(yùn)行
setsebool -P httpd_can_network_connect_db 1   #httpd可以連接到數(shù)據(jù)庫(如連接mysql就必須設(shè)置)
setsebool -P httpd_can_network_connect 1      #httpd可以連接到網(wǎng)絡(luò)(如連接redis就必須設(shè)置)
setsebool -P httpd_read_user_content 1        #開啟用戶文件的訪問權(quán)限(如日志文件就必須設(shè)置)
setsebool -P httpd_suexec_disable_trans 1     #禁用suexec過度
setsebool -P httpd_disable_trans 1            #允許daemon用戶啟動(dòng)httpd
setsebool -P httpd_can_sendmail 1             #允許httpd發(fā)送email
setsebool -P named_write_master_zones 1       #允許修改dns的主zone文件
setsebool -P named_disable_trans 1            #允許daemon啟動(dòng)named
setsebool -P nfs_export_all_ro 1              #nfs只讀
setsebool -P nfs_export_all_rw 1              #nfs可讀寫
setsebool -P use_nfs_home_dirs 1              #允許本機(jī)訪問遠(yuǎn)程nfs的根目錄
setsebool -P allow_smbd_anon_write=1          #samba允許匿名用戶可寫
setsebool -P samba_enable_home_dirs 1         #允許根目錄訪問
setsebool -P use_samba_home_dirs 1            #允許本機(jī)訪問遠(yuǎn)程samba根目錄
setsebool -P smbd_disable_trans 1             #允許daemon啟動(dòng)samba
setsebool -P allow_rsync_anon_write=1         #允許匿名用戶可寫
setsebool -P rsync_disable_trans 1            #允許daemon啟動(dòng)rsync

歡迎訪問我的個(gè)人博客:Lemon - 萬事順?biāo)?/a>

  • 序言:七十年代末咸灿,一起剝皮案震驚了整個(gè)濱河市构订,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌避矢,老刑警劉巖悼瘾,帶你破解...
    沈念sama閱讀 222,183評(píng)論 6 516
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異审胸,居然都是意外死亡亥宿,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 94,850評(píng)論 3 399
  • 文/潘曉璐 我一進(jìn)店門砂沛,熙熙樓的掌柜王于貴愁眉苦臉地迎上來烫扼,“玉大人,你說我怎么就攤上這事碍庵∮称螅” “怎么了?”我有些...
    開封第一講書人閱讀 168,766評(píng)論 0 361
  • 文/不壞的土叔 我叫張陵怎抛,是天一觀的道長卑吭。 經(jīng)常有香客問我,道長马绝,這世上最難降的妖魔是什么豆赏? 我笑而不...
    開封第一講書人閱讀 59,854評(píng)論 1 299
  • 正文 為了忘掉前任,我火速辦了婚禮富稻,結(jié)果婚禮上掷邦,老公的妹妹穿的比我還像新娘。我一直安慰自己椭赋,他們只是感情好抚岗,可當(dāng)我...
    茶點(diǎn)故事閱讀 68,871評(píng)論 6 398
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著哪怔,像睡著了一般宣蔚。 火紅的嫁衣襯著肌膚如雪向抢。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 52,457評(píng)論 1 311
  • 那天胚委,我揣著相機(jī)與錄音挟鸠,去河邊找鬼。 笑死亩冬,一個(gè)胖子當(dāng)著我的面吹牛艘希,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播硅急,決...
    沈念sama閱讀 40,999評(píng)論 3 422
  • 文/蒼蘭香墨 我猛地睜開眼覆享,長吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來了营袜?” 一聲冷哼從身側(cè)響起撒顿,我...
    開封第一講書人閱讀 39,914評(píng)論 0 277
  • 序言:老撾萬榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎荚板,沒想到半個(gè)月后核蘸,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 46,465評(píng)論 1 319
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡啸驯,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 38,543評(píng)論 3 342
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了祟峦。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片罚斗。...
    茶點(diǎn)故事閱讀 40,675評(píng)論 1 353
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖宅楞,靈堂內(nèi)的尸體忽然破棺而出针姿,到底是詐尸還是另有隱情,我是刑警寧澤厌衙,帶...
    沈念sama閱讀 36,354評(píng)論 5 351
  • 正文 年R本政府宣布距淫,位于F島的核電站,受9級(jí)特大地震影響婶希,放射性物質(zhì)發(fā)生泄漏榕暇。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 42,029評(píng)論 3 335
  • 文/蒙蒙 一喻杈、第九天 我趴在偏房一處隱蔽的房頂上張望彤枢。 院中可真熱鬧,春花似錦筒饰、人聲如沸缴啡。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,514評(píng)論 0 25
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽业栅。三九已至秒咐,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間碘裕,已是汗流浹背携取。 一陣腳步聲響...
    開封第一講書人閱讀 33,616評(píng)論 1 274
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留娘汞,地道東北人歹茶。 一個(gè)月前我還...
    沈念sama閱讀 49,091評(píng)論 3 378
  • 正文 我出身青樓,卻偏偏與公主長得像你弦,于是被迫代替她去往敵國和親惊豺。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,685評(píng)論 2 360

推薦閱讀更多精彩內(nèi)容

  • 1禽作、第八章 Samba服務(wù)器2尸昧、第八章 NFS服務(wù)器3、第十章 Linux下DNS服務(wù)器配站點(diǎn)旷偿,域名解析概念命令:...
    哈熝少主閱讀 3,742評(píng)論 0 10
  • linux的訪問控制 Discretionary Access Control(DAC) 自主(自由)訪問控制:這...
    dreamscd閱讀 4,299評(píng)論 0 7
  • 一烹俗、LAMP環(huán)境的介紹 1.LAMP環(huán)境的重要性 思索許久,最終還是決定寫一篇詳細(xì)的LAMP的源碼編譯安裝的實(shí)驗(yàn)文...
    endmoon閱讀 2,626評(píng)論 4 26
  • 在使用CentOS時(shí)多多少少會(huì)涉及SELinux萍程,尤其是針對(duì)Web服務(wù)幢妄,大部分的做法是關(guān)閉SELinux,正確的做...
    開口海螺閱讀 6,834評(píng)論 0 8
  • 青年三嘆 夢(mèng)事浮沉花開落茫负, 無名野地草綠黃蕉鸳。 長行路上滄桑過, 看是佳人不是孀忍法。 朔冬 輾轉(zhuǎn)母難眠潮尝, 俄感刺...
    月影下的雪鷹閱讀 286評(píng)論 0 2