Apache"No spache left on device"錯(cuò)誤與解決方法
1、錯(cuò)誤現(xiàn)象
這是一個(gè)使用
創(chuàng)新互聯(lián)服務(wù)器的客戶(hù)案例,客戶(hù)反映在執(zhí)行“apache start”啟動(dòng)Apache時(shí)無(wú)報(bào)錯(cuò)信息,但是網(wǎng)頁(yè)還是不能訪(fǎng)問(wèn)??蛻?hù)的網(wǎng)站是基于A(yíng)pache+PHP+Mysql的在線(xiàn)交易平臺(tái),聽(tīng)到客戶(hù)描述的現(xiàn)象后,反應(yīng)應(yīng)是防火墻屏蔽了HTTP端口或SELinux的問(wèn)題,于是登錄服務(wù)器查看相關(guān)信息,如下圖。
從輸出可知,防火墻所有策略都處于開(kāi)放狀態(tài),并未所任何限制,而SELinux也處于關(guān)閉狀態(tài),應(yīng)該不是防火墻問(wèn)題導(dǎo)致的。
既然不是防火墻攔截的問(wèn)題,那么看看httpd進(jìn)程是否存在及httpd端口是否正常啟動(dòng),操作過(guò)程如下圖。
這個(gè)操作首先查看了服務(wù)器上的httpd進(jìn)程,發(fā)現(xiàn)并沒(méi)有httpd進(jìn)程運(yùn)行,同時(shí)httpd對(duì)應(yīng)的端口80也并無(wú)啟動(dòng),于是重新啟動(dòng)Apahce,在啟動(dòng)Apache的過(guò)程中并沒(méi)有報(bào)錯(cuò),啟動(dòng)完成后發(fā)現(xiàn)仍然沒(méi)有httpd進(jìn)程運(yùn)行,由此看來(lái),應(yīng)該是Apache內(nèi)容出現(xiàn)了問(wèn)題。
2、解決思路
在判斷是Apache的問(wèn)題后,首先要看的是Apache的啟動(dòng)日志,在查看Apache的error日志后,發(fā)現(xiàn)了一個(gè)可疑輸出,內(nèi)容為:
No space left device:mod_rewrite:could not create rewrite_log_lock Configuration Failed
看到這個(gè)錯(cuò)誤提示,感覺(jué)應(yīng)該是磁盤(pán)空間耗盡導(dǎo)致的,于是趕緊查看系統(tǒng)所有磁盤(pán)分區(qū),結(jié)果發(fā)現(xiàn)所有磁盤(pán)分區(qū)都還有很多可用空間,這有些奇怪了。
Linux下對(duì)磁盤(pán)空間的占用分為三個(gè)部分:物理磁盤(pán)、inode節(jié)點(diǎn)磁盤(pán)空間和信號(hào)磁盤(pán)空間。通過(guò)檢查服務(wù)器的物理磁盤(pán)空間,發(fā)現(xiàn)仍有很多剩余,因此被排除了物理磁盤(pán)空間的問(wèn)題。接著通過(guò)“df -i”命令查看系統(tǒng)可用的inode節(jié)點(diǎn),發(fā)現(xiàn)每個(gè)分區(qū)可用的inode還有很多,這樣inode節(jié)點(diǎn)問(wèn)題也被排除了,那么應(yīng)該是信號(hào)量磁盤(pán)空間耗盡導(dǎo)致的。
這里簡(jiǎn)單介紹了Linux信號(hào)量相關(guān)的知識(shí),信號(hào)量是一種鎖機(jī)制用于協(xié)調(diào)進(jìn)程之間互斥的訪(fǎng)問(wèn)臨界資源,以確保某種共享資源不被多個(gè)進(jìn)程同時(shí)訪(fǎng)問(wèn)。Linux系統(tǒng)的信號(hào)量是用于進(jìn)程間通信的。它有兩種標(biāo)準(zhǔn)實(shí)現(xiàn),分別是POSIX及System v,現(xiàn)在大多數(shù)Linux系統(tǒng)都實(shí)現(xiàn)了這兩種標(biāo)準(zhǔn)。這兩種標(biāo)準(zhǔn)都可用于進(jìn)行線(xiàn)程間的通信,只是系統(tǒng)調(diào)用方式略有不同。
Syetem v信號(hào)量通過(guò)系統(tǒng)調(diào)用semget來(lái)創(chuàng)建,通過(guò)linux命令ipcs即可顯示進(jìn)程間通信用的System v類(lèi)型信號(hào)量及共享內(nèi)存。
POSIX信號(hào)量可用于線(xiàn)程和線(xiàn)程間通信,并可分為有名和無(wú)名兩種。也可簡(jiǎn)單理解為是否保存在磁盤(pán)上。有名的信號(hào)量會(huì)以文件形式保存在/dev/shm下,因此可用于不相關(guān)的進(jìn)程間通信,而無(wú)名信號(hào)量只能用于線(xiàn)程間和父子進(jìn)程間通過(guò)。
在對(duì)信號(hào)量有了簡(jiǎn)單了解后,可以發(fā)現(xiàn)Apaceh使用的進(jìn)程間通信方式應(yīng)該是Syqtem v,因此可以通過(guò)ipcs命令查看和解決這個(gè)問(wèn)題了。
3、解決問(wèn)題
在解決這個(gè)問(wèn)題之前,首先查看下Linux系統(tǒng)默認(rèn)信號(hào)量的設(shè)置值是多少,執(zhí)行如下命令:
[root@localhost ~]#cat /proc/sys/kemel/sem
250 32000 32 128
這四個(gè)輸出值的含義如下:
SEMMSL,此參數(shù)用于控制每個(gè)信號(hào)集的信號(hào)數(shù)。
SEMMNS,此參數(shù)用于控制整個(gè)Linux系統(tǒng)中信號(hào)的數(shù)量。
SEMOM,此參數(shù)用于控制每個(gè)semop系統(tǒng)調(diào)用可以執(zhí)行的信號(hào)操作數(shù)。
SEMMNI,此內(nèi)核參數(shù)用于控制整個(gè)Linux系統(tǒng)中信號(hào)集的數(shù)量。
接著通過(guò)ipcs命令查看httpd進(jìn)程占用了多少信號(hào)量,執(zhí)行如下命令:
[root@localhost ~]#ipcs -s|grep daemon
其中“daemon”是啟動(dòng)Apahce進(jìn)程的用戶(hù),默認(rèn)是daemon,也可能是nobody用戶(hù),根據(jù)實(shí)際環(huán)境而定。執(zhí)行完此命令后,發(fā)現(xiàn)很多基于daemon的信號(hào)量輸出,問(wèn)題終于找到了。解決信息量耗盡的方法很簡(jiǎn)單,通過(guò)ipcrm命令消除即可,最簡(jiǎn)單方法是執(zhí)行如下命令組合:
[root@localhost ~]#ipcs -s | grep nobody|perl -e 'while(<STDIN>)'{@=split(^s+/)};print
'ipcrm sem $a[1]'
執(zhí)行完上面這個(gè)命令后,再次啟動(dòng)Apache,然后查看是否有httpd進(jìn)程啟動(dòng),可以看到,此時(shí)httpd進(jìn)程啟動(dòng)了,那么Apache也工作正常了。
當(dāng)前題目:Apache"No spache left on device"錯(cuò)誤與解決方法
標(biāo)題來(lái)源:http://aaarwkj.com/news17/105167.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供關(guān)鍵詞優(yōu)化、定制開(kāi)發(fā)、App設(shè)計(jì)、標(biāo)簽優(yōu)化、網(wǎng)站制作、電子商務(wù)
廣告
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶(hù)投稿、用戶(hù)轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀(guān)點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話(huà):028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源:
創(chuàng)新互聯(lián)