1、查看端口被哪個(gè)應(yīng)用程序占用
[root@localhost conf]# netstat –ntlp
netstat命令:顯示網(wǎng)絡(luò)狀態(tài)
參數(shù):
n 直接使用IP地址,而不通過(guò)域名服務(wù)器
t 顯示TCP傳輸協(xié)議的連線狀況
l 顯示監(jiān)控中的服務(wù)器的Socket
p 顯示正在使用Socket的程序識(shí)別碼和程序名稱
2、查看Apache是否安裝以及安裝路徑和版本
命令:Apachectl –v
[root@localhost apache]# apachectl -v
Server version: Apache/2.2.15 (Unix)
Server built: Jul 7 2011 11:27:40
通過(guò)這個(gè)命令可以獲得當(dāng)前部署的Apache的版本和發(fā)行時(shí)間。
如果用rpm安裝,可用rpm –d httpd命令查看是否已經(jīng)安裝過(guò)。
3、查找安裝的指定程序
1)如果是rpm套件,可用:
[root@localhost apache]# rpm -qa | grep xxx
其中:
q 使用詢問(wèn)模式,當(dāng)遇到任何問(wèn)題時(shí),rpm指令會(huì)先詢問(wèn)用戶
a 查詢所有套件
2)如果是源碼安裝的,可以用:
whereis xxx
4、RPM套件基本操作
1)安裝 rpm 套件
命令:rpm -ihv
例子:rpm -ihv bind-8.2.1-7.i386.rpm
2)更新rpm套件
命令:rpm -Uhv
例子:rpm -Uhv bind-8.2.1-7.i386.rpm
3)查詢已安裝的rpm 套件
命令:rpm -qa | grep xxx
例子:rpm -qa | grep bind rpm -e
4)刪除 rpm 套件
命令:rpm –e
例子:rpm -e bind-8.2.1-7.i386.rpm
注意: 刪除服務(wù)前應(yīng)先停止
5)強(qiáng)制刪除rpm套件
命令: rpm -e –nodeps xxxxxx.rpm
rpm參數(shù)說(shuō)明:
e 刪除指定的套件
i 顯示套件的相關(guān)信息
h 套件安裝時(shí)列出標(biāo)記
v 顯示指令執(zhí)行過(guò)程
U 升級(jí)指定的套件檔
nodeps 不考慮包間的依賴關(guān)系
5、查找程序進(jìn)程
1)ps -ef | grep xxx
ps命令:報(bào)告程序狀況
參數(shù):
-e 顯示所有終端機(jī)下執(zhí)行的程序
-f 顯示UID,PPIP,C與STIME欄位
例子:ps -ef | grep httpd
2)netstat –ntlp
說(shuō)明請(qǐng)參考前面的介紹。
6、殺死Linux進(jìn)程
1)kill pid
注釋:標(biāo)準(zhǔn)的kill命令通常都能達(dá)到目的。終止有問(wèn)題的進(jìn)程,并把進(jìn)程的資源釋放給系統(tǒng)。然而,如果進(jìn)程啟動(dòng)了子進(jìn)程,只殺死父進(jìn)程,子進(jìn)程仍在運(yùn)行,因此仍消耗資源。為了防止這些所謂的“僵尸進(jìn)程”,應(yīng)確保在殺死父進(jìn)程之前,先殺死其所有的子進(jìn)程。
2)kill -l pid
注釋:當(dāng)使用該選項(xiàng)時(shí),kill命令也試圖殺死所留下的子進(jìn)程。但這個(gè)命令也不是總能成功,或許仍然需要先手工殺死子進(jìn)程,然后再殺死父進(jìn)程。
3)kill -temp ppid
注釋:給父進(jìn)程發(fā)送一個(gè)TERM信號(hào),試圖殺死它和它的子進(jìn)程。
4)killall httpd
注釋:killall命令殺死同一進(jìn)程組內(nèi)的所有進(jìn)程。其允許指定要終止的進(jìn)程的名稱,而非PID。
5)kill -HUP PID
注釋:該命令讓Linux和緩的執(zhí)行進(jìn)程關(guān)閉,然后立即重啟。在配置應(yīng)用程序的時(shí)候,這個(gè)命令很方便,在對(duì)配置文件修改后需要重啟進(jìn)程時(shí)就可以執(zhí)行此命令。
5)kill -9 PID
注釋:終極大招。這個(gè)強(qiáng)大和危險(xiǎn)的命令迫使進(jìn)程在運(yùn)行時(shí)突然終止,進(jìn)程在結(jié)束后不能自我清理。危害是導(dǎo)致系統(tǒng)資源無(wú)法正常釋放,一般不推薦使用,除非其他辦法都無(wú)效。由于只能
通過(guò)終止父進(jìn)程來(lái)消除僵尸進(jìn)程,因此當(dāng)使用此命令時(shí),一定要通過(guò)ps -ef確認(rèn)沒(méi)有剩下任何僵尸進(jìn)程。如果僵尸進(jìn)程被init收養(yǎng),問(wèn)題就比較嚴(yán)重了。殺死init進(jìn)程意味著關(guān)閉系統(tǒng)。
如果系統(tǒng)中有僵尸進(jìn)程,并且其父進(jìn)程是init,而且僵尸進(jìn)程占用了大量的系統(tǒng)資源,那么就需要在某個(gè)時(shí)候重啟機(jī)器以清除進(jìn)程表了。
7、常用的防火墻操作(iptables)
[root@localhost httpd-2.2.22]# /sbin/iptables -I INPUT -p tcp --dport 80 -j ACCEPT
[root@localhost httpd-2.2.22]# /sbin/iptables -I INPUT -p tcp --dport 443 -j ACCEPT
[root@localhost httpd-2.2.22]# /etc/init.d/iptables save
這樣重啟計(jì)算機(jī)后,防火墻默認(rèn)便開(kāi)放了80和443端口。
也可以通過(guò)以下方式不重啟計(jì)算機(jī),完成規(guī)則的添加:
#/etc/init.d/iptables restart
查看防火墻信息:
#/etc/init.d/iptables status
關(guān)閉防火墻服務(wù):
#/etc/init.d/iptables stop
永久關(guān)閉防火墻:
#chkconfig –level 35 iptables off
參考文章:
1、CentOS Linux防火墻配置及關(guān)閉