明明白白你的Linux服務(wù)器——網(wǎng)絡(luò)篇
原創(chuàng)【51CTO獨(dú)家特稿】前言:這篇文章是明明白白你的Linux服務(wù)器-硬件篇的續(xù)篇,《明明白白你的Linux服務(wù)器》系列的第二篇。希望大家看完此文后,能很清楚明白你的服務(wù)器的網(wǎng)絡(luò)情況,能很輕松的配置其網(wǎng)絡(luò)環(huán)境。Linux服務(wù)器在裝完系統(tǒng),配置其網(wǎng)絡(luò)環(huán)境是每一個system administrator的職能。
一、服務(wù)器的網(wǎng)絡(luò)配置
在服務(wù)器的網(wǎng)絡(luò)配置時,喜歡圖形的朋友可用setup或system-config-network來配置。
網(wǎng)卡配置文件為/etc/sysconfig/network-scripts/ifcfg-eth0,設(shè)置完畢后直接用service network restart生效
- [root@linpcl root]#cat /etc/sysconfig/networking/devices/ifcfg-rth0
- DEVICE=eth0
- ONBOOT=yes
- BOOTPROTO=static
- IPADDR=192.168.0.2
- NETMASK=255.255.255.0
- GATEWAY=192.168.0.1
GATEWAY選項(xiàng)可以設(shè)置網(wǎng)關(guān)參數(shù),這里注意下ONBOOT選項(xiàng),它表示網(wǎng)卡是否隨系統(tǒng)啟動而啟動,此項(xiàng)一定要設(shè)置成on
這里介紹二個不是太常用的參數(shù)
USERCTL=no,即不允許普通用戶修改網(wǎng)卡 PEERDNS=yes,它表示允許從DHCP獲得的DNS覆蓋本地的DNS
查看本機(jī)所有的網(wǎng)卡情況 ifconfig –a,更高級的網(wǎng)卡路由命令用ip addr,特別是你的服務(wù)器由keepalived綁定了虛擬VIP后用其查看很方便查看本機(jī)路由 netstat –rn或route
增加一條本機(jī)網(wǎng)絡(luò)路由用命令route add -net 172.16.6.0 netmask 255.255.255.0 gw 172.16.2.25,即增加一條網(wǎng)絡(luò)172.16.6.0/24 經(jīng)過172.16.2.254 ,這個地址也可以理解為你的下一跳的地址
刪除路由用命令route del –net 172.16.86.0/24
如果要永久的生效可用文件編輯的辦法
vim /etc/sysconfig/network-scripts/route-eth0 172.16.6.0/24 via 172.16.2.25
查看本機(jī)的DNS服務(wù)器 cat /etc/resolv.conf 查看主機(jī)名hostname 查看主機(jī)名對應(yīng)的IP地址 /etc/hosts
它的執(zhí)行順序是優(yōu)于DNS的,現(xiàn)在多用于集群環(huán)境,比如Heartbeat;還有一個妙用,在沒用DNS的環(huán)境中做測試時,直接改服務(wù)器的此文件,達(dá)到優(yōu)先解析的目的查看與本機(jī)直連的網(wǎng)絡(luò)設(shè)備用命令arp
這里跟大家介紹一個很有用的工具,mii-tool,判斷哪塊網(wǎng)卡連接了網(wǎng)線,同事們靠抽插網(wǎng)線來判斷哪個網(wǎng)卡連接了網(wǎng)線的辦法比較沒有效率
- [root@mail~]#mii-tool
- eth0: negotiated 100baseTx-FD flow-control, link ok
- SIOCGMIIPHY on 'eth1' failed: Resource temporarily unavailable
大家看這段文字可能沒什么感覺,但到了機(jī)房就非常有用了,特別是那些網(wǎng)卡多的服務(wù)器,我見得最多的某臺Linux服務(wù)器上綁定了六塊網(wǎng)卡。
二、查看你的服務(wù)器網(wǎng)絡(luò)連接狀態(tài)
- netstat -n | awk '/^tcp/ {++S[$NF]} END {for(a in S) print a, S[a]}'
- LAST_ACK 14
- SYN_RECV 348
- ESTABLISHED 70
- FIN_WAIT1 229
- FIN_WAIT2 30
- CLOSING 33
- TIME_WAIT 18122
狀態(tài):描述
◆CLOSED:無連接是活動的或正在進(jìn)行
◆LISTEN:服務(wù)器在等待進(jìn)入呼叫
◆SYN_RECV:一個連接請求已經(jīng)到達(dá),等待確認(rèn)
◆SYN_SENT:應(yīng)用已經(jīng)開始,打開一個連接
◆ESTABLISHED:正常數(shù)據(jù)傳輸狀態(tài)
◆FIN_WAIT1:應(yīng)用說它已經(jīng)完成
◆FIN_WAIT2:另一邊已同意釋放
◆ITMED_WAIT:等待所有分組死掉
◆CLOSING:兩邊同時嘗試關(guān)閉
◆TIME_WAIT:另一邊已初始化一個釋放
◆LAST_ACK:等待所有分組死掉
ESTABLISHED的值其實(shí)也是當(dāng)前的并發(fā)數(shù),這個可重點(diǎn)關(guān)注下;另外,可關(guān)注下TIME——WAIT這項(xiàng)的數(shù)值。Linux下高并發(fā)的Squid服務(wù)器,TCP TIME_WAIT套接字?jǐn)?shù)量經(jīng)常達(dá)到兩、三萬,服務(wù)器很容易被拖死。通過修改Linux內(nèi)核參數(shù),可以減少Squid服務(wù)器的TIME_WAIT套接字?jǐn)?shù)量,具體可參見我的另一篇文章:優(yōu)化Linux生產(chǎn)服務(wù)器的經(jīng)驗(yàn)之談。
#p#
三、 尋找惡意IP并用iptables禁止掉
找出惡意連接你的服務(wù)器80端口的IP,直接用iptables來drop掉它;這里建議寫腳本來運(yùn)行,有興趣的請參考我在51cto.com里發(fā)表的自動分析黑名單及白名單的iptables腳本一文
netstat -an| grep :80 | grep -v 127.0.0.1 |awk '{ print $5 }' | sort|awk -F: '{print $1,$4}' | uniq -c | awk '$1 >50 {print $1,$2}'
iptables腳本執(zhí)行完畢后,用iptables –nv –L 可查看其規(guī)則,下面的iptables語法比較詳細(xì),推薦記憶
iptables [-t表名] <-A| I |D |R > 鏈名[規(guī)則編號] [-i | o 網(wǎng)卡名稱] [-p 協(xié)議類型] [-s 源IP地址 | 源子網(wǎng)][--sport 源端口號] [-d 目標(biāo)IP地址 | 目標(biāo)子網(wǎng)][--dport 目標(biāo)端口號] <-j 動作>
四、SMTP會話處理方式
捕獲一個SMTP會話,以下命令很管用,推薦下 ;不喜歡用命令的同學(xué)我推薦用wireshark
- tcpdump -vv –x –X –s 1500 `port 25`
五、打印自動運(yùn)行服務(wù)
打印出自動運(yùn)行的服務(wù),3、5級別的即可;當(dāng)然喜歡圖形的同學(xué)可用ntsysv工具。
- [root@ltos test]# chkconfig -list | grep 3:on | awk '{print $1,$5}'
- [root@ltos test]# chkconfig –list | grep 5:on | awk '{print $1,$7}'
六、使用Netstat查看協(xié)議數(shù)據(jù)
Netstat用于顯示與IP、TCP、UDP和ICMP協(xié)議相關(guān)的統(tǒng)計(jì)數(shù)據(jù),一般用于檢驗(yàn)本機(jī)各端口的網(wǎng)絡(luò)連接情況。
- NETSTAT [-a] [-b] [-e] [-n] [-o] [-p proto] [-r] [-s] [-v] [interval]
- -a 顯示所有連接和監(jiān)聽端口。
- -b 顯示包含于創(chuàng)建每個連接或監(jiān)聽端口的可執(zhí)行組件。
- -e 顯示以太網(wǎng)統(tǒng)計(jì)信息。此選項(xiàng)可以與-s選項(xiàng)組合使用。
- -n 以數(shù)字形式顯示地址和端口號。
- -o 顯示與每個連接相關(guān)的所屬進(jìn)程 ID。
- -p proto 顯示 proto 指定的協(xié)議的連接。
- -r 顯示路由表。
- -s 顯示按協(xié)議統(tǒng)計(jì)信息。
一般用得比較多的就是netstat -an與netstat –rn #p#
七、使用lsof查看文件信息
在unix里面,一切皆文件;而Linux秉承了這一特性,將unix下的工具lsof移植過來得很成功。lsof可以列出被進(jìn)程所打開的文件的信息。
被打開的文件可以是
1.普通的文件
2.目錄
3.網(wǎng)絡(luò)文件系統(tǒng)的文件
4.字符設(shè)備文件
5.(函數(shù))共享庫
6.管道,命名管道
7.符號鏈接
8.底層的socket字流。網(wǎng)絡(luò)socket,unix域名socket,用得比較多的用法是lsof -i:端口號,列出誰在使用某個端口,例如:lsof -i :3306,我喜歡用此用法來判斷服務(wù)到底有沒有正常啟用。
八、使用fuser查看和殺死相關(guān)進(jìn)程
與lsof –i的用法相法,如果我想查找占用3306端口的程序,則用fuser –n tcp -v 8080,另外,fuser的其它功能也是很強(qiáng)大的,我常用的它的兩個功能:查看我需要的進(jìn)程和我要?dú)⑺牢也榈降倪M(jìn)程(撫琴煮酒是一般用來解決device is busy的問題)
比如當(dāng)你想umount光驅(qū)的時候,結(jié)果系統(tǒng)提示你設(shè)備正在使用或者正忙,可是你又找不到到底誰使用了他。這個時候fuser可派上用場了。
- [root@lancy sbin]# eject
- umount: /media/cdrom: device is busy
- umount: /media/cdrom: device is busy
- eject: unmount of `/media/cdrom' failed
- [root@lancy sbin]# fuser /mnt/cdrom
- /mnt/cdrom: 4561c 5382c
- [root@lancy sbin]# ps -ef |egrep '(4561|5382)' |grep -v grep
- root 4561 4227 0 20:13 pts/1 00:00:00 bash
- root 5382 4561 0 21:42 pts/1 00:00:00 vim Autorun.inf
示例中,我想彈出光驅(qū),系統(tǒng)告訴我設(shè)備忙著,于是采用fuser命令,參數(shù)是你文件或scoket,fuser將查出那些使用了他。4561c,5382c表示目前用兩個進(jìn)程在占用著/mnt/cdrom,分別是4561,5382,進(jìn)程ID后的字母表示占用資源的方式。#p#
九、TCP_wrappers防火墻
linux上一種特殊的防火墻TCP_wrappers防火墻,TCP 封包會先經(jīng)過所謂的 IP 過濾機(jī)制( IP Filtering ),這是 Linux 提供的第一層保護(hù),他可以將你不想要的來源 IP (經(jīng)由 TCP 封包的 Head 資料)先當(dāng)?shù)粼僬f!如果可以通過的話,在就是要通過TCP_wrappers過濾。如果上面兩個都通過了,再就根據(jù)每個服務(wù)訪問控制的設(shè)定決定客戶機(jī)能得到不同的權(quán)限和信息.TCP_wrappers防火墻主要涉及到兩個文件/etc/hosts.allow和/etc/hosts.deny,可作iptables的補(bǔ)充來保護(hù)你的Linux安全,比如只允許內(nèi)網(wǎng)IP訪問你的NFS服務(wù)器。
這里說下Linux是怎么識別其順序的,這里好多朋友容易混淆了;當(dāng)某個ip想訪問你的Linux下的特定服務(wù)時,系統(tǒng)首先會檢查/etc/hosts.alllow文件,如是有的話就放行,沒有的話繼續(xù)檢查/etc/hosts.deny文件,有的話拒絕,沒有的就放行,不過一般的做法就直接在/etc/hosts.allow里放允許通行的ip,/etc/hosts.deny里放不允許通行的ip。另外,這里跟大家分享一個經(jīng)驗(yàn)心得吧: Linux下的服務(wù)眾多,samba,nfs,rsync,tcp_wrapper,xinetd等,而每個又都有各自支持的寫法,這樣對于考試學(xué)習(xí)及工作記憶很不方便,其實(shí)它們都支持192.168.0.1/255.255.255.0這樣的點(diǎn)分十進(jìn)制寫法;另,iptables是不支持的,它只支持192.168.0.1/24比特建網(wǎng)制。
十、推薦下Linux/unix中常用的掃描端口工具-Nmap
下面是Nmap支持的四種最基本的掃描方式:
- TCP connect()端口掃描(-sT參數(shù),-sP是用于掃描整個局域網(wǎng)段)
- TCP同步(SYN)端口掃描(-sS參數(shù))
- UDP端口掃描(-sU參數(shù))
- TCP ACK掃描(-sA參數(shù))
我這里以自己的線上郵件服務(wù)器為例說明下:
- [root@mail postfix]# nmap -P0 -sS 211.143.6.X
- Starting Nmap 4.11 ( http://www.insecure.org/nmap/ ) at 2009-03-29 16:21 CST
- Interesting ports on 211.143.6.X:
- Not shown: 1668 closed ports
- PORT STATE SERVICE
- 22/tcp open ssh
- 25/tcp open smtp
- 80/tcp open http
- 110/tcp open pop3
- 111/tcp open rpcbind
- 143/tcp open imap
- 443/tcp open https
- 465/tcp open smtps
- 587/tcp open submission
- 993/tcp open imaps
- 995/tcp open pop3s
- 1014/tcp open unknown
lsof -i:1014,發(fā)現(xiàn)又是rpc.statd,這東東,每次用的端口都不一樣??;它不能正確處理SIGPID信號,遠(yuǎn)程攻擊者可利用這個漏洞關(guān)閉進(jìn)程,進(jìn)行拒絕服務(wù)攻擊;發(fā)現(xiàn)rpc.statd是由服務(wù)nfslock開啟,關(guān)閉它即可service nfslock stop;chkconfig nfslock off
關(guān)于網(wǎng)站的安全,我這里也有一些自己的淺見,特與大家共享下:
- iptables最好寫成腳本形式,想開哪個端口開哪個,想關(guān)哪個關(guān)哪個,iptables服務(wù)都可關(guān)閉;可以用crontab每5分鐘自動關(guān)閉一次iptables,注意別把自己SSH停掉了,畢竟公司離機(jī)房還是很遠(yuǎn)的!
- 不定期掃描,發(fā)現(xiàn)可疑端口就關(guān)閉,實(shí)在不太懂就cat /etc/services或google下查找端口。
- 多注意連接數(shù)和系統(tǒng)性能,有時能從上面發(fā)現(xiàn)問題,有條件的話就布置nagois監(jiān)控服務(wù)器。
- 建議掌握netcat、hping、nmap、等安全工具及網(wǎng)絡(luò)分析工具tcpdump或wireshark,配合監(jiān)測iptables的安全策略。
- 多注意自己服務(wù)器的內(nèi)核漏洞,畢竟現(xiàn)在的linux攻擊都是內(nèi)核級的;請至少保證內(nèi)核為2.6.9以上(不含2.6.9)。
- 密切關(guān)注防火墻日志/var/log/messages。
【51CTO.com獨(dú)家特稿,合作站點(diǎn)轉(zhuǎn)載請注明原文譯者和出處。】
【編輯推薦】
- 明明白白你的Linux服務(wù)器——硬件篇
- Linux服務(wù)器如何擺平黑客攻擊
- 詳細(xì)介紹如何進(jìn)行Linux服務(wù)器攻擊的分級防御
- Linux服務(wù)器安裝下載所需的軟件與安裝和配置