<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    隨筆-49  評論-67  文章-27  trackbacks-0

    原文出處

    http://www.dbanotes.net/OpenSource/Using_xinetd.html

    [OpenSource] 使用xinetd

    作者:Jose Nazario
    譯者:Fenng
    日期:25-Oct-2004
    出處:http://www.dbanotes.net
    版本:@2001/11/27 Version 0.01 @2003/05/23 Version 1.00

    Jose描述了如何著手配置調整xinetd

    xinetd取代了inetd,并且提供了訪問控制、加強的日志和資源管理功能。xinetd已經成為Red Hat 7 和 Mandrake 7.2的Internet標準超級守護進程。這篇文章將引導你如何應用一些它的特性,這些特性基于xinetd 2.1.8.8 pre3版本。

    導言

    xinetd的最初的作者(Panagoitis Tsirigotis panos@cs.colorado.edu)好像已經停止了這個項目。 Rob Braun (bbraun@synack.net)繼續了該項目,現在負責維護這個軟件包。為了能使 select()在我的老的libc5系統上也可以使用,我不得不給當前的包添加幾對頭文件,這是我注意到的問題。或許你需要它們,如下:

    xinetd/internals.c.orig
    Fri Jun 16 19:00:15 2000
    +++ xinetd/internals.c
    Fri Jun 16 19:00:53 2000
    @@ -12,6 +12,8 @@
     #include <time.h>
     #include <fcntl.h>
     #include <syslog.h>
     #include <unistd.h>
     #include <sys/time.h>
     #include "sio.h"
    

    關于 xinetd

    xinetd用括號括起的、擴展了的語法取代了inetd中的通用的行。另外,還添加了日志和訪問控制功能。 雖然inetd可以使用Venema的 tcp_wrappers 軟件 (tcpd) 控制 TCP 的連接,但是你不能用它來控制 UDP 連接。此外,inetd對RPC(portmapper)類型的服務也處理不好。另外,雖然使用 inetd 你可以控制連接速度 ( 通過給wait或是no wait 變量附加一個數值,例如nowait.1表示每隔一秒鐘一個實例),你不能控制實例的最大數。這能導致進程表攻擊(例如,一個有效的拒絕服務攻擊)。通過使用xinetd,我們可以防止Dos

    我通常使用下面的命令啟動xinetd,把它放在我的Internet服務啟動腳本中:

    /usr/sbin/xinetd -filelog /var/adm/xinetd.log -f /etc/xinetd.conf
    

    這告訴 xinetd 對所有的服務都進行紀錄,日志保存到文件 /var/adm/xinetd.log中,并且使用配置文件/etc/xinetd.conf。這篇文章中的大量篇幅都將用在這個配置文件上。

    編譯時選項

    你應該注意3個編譯時的選項:libwrap、loadavg (用于監視負載均衡) 和 IPv6 support,它們提供了額外的訪問控制。對于大多數libwrap"明白"的守護進程 (如portmapper 和sendmail),在配置腳本中的"with-libwrap"選項告訴xinetd支持tcp_wrappers文件/etc/hosts.allow和/etc/hosts.deny。這些選項對xinetd作用就如同它們之于 inetd那樣,并且支持所有的 xinetd控制的守護進程。注意如果你從零開始做xinetd的話,就可以做訪問控制,不再需要tcpd。不管怎樣。對libwrap 的支持是有用的--如果你從inetd/tcpd遷移并且也不想改變你的訪問文件的話 。

    第二個有趣的設置選項是支持負載均衡監控,通過在./configure腳本中使用with-loadavg選項可以達到。sendmail支持在高負載的時候停止連接--假定它已經脫離了控制并且正在當掉機器。用這個選項可以激活max_load 選項以限制任何連接或是基于負載均衡機器的所有服務。

    最后,添加 IPv6支持 可以通過在 ./configure 腳本中使用 with-inet6 capability選項來完成。 這使xinetd 支持IPv6地址和連接。注意要使其生效的話你的核心(和網絡)必須支持 IPv6。當然IPv4 仍然被支持。

    配置文件

    xinetd 配置文件,通常可以手工或是自動從inetd.conf文件生成。前者費時間且容易出錯;后者可以通過 itox軟件或者xconv.pl 腳本輕易完成。雖然itox軟件正在被取消而傾向于使用 xconv.pl 腳本,它仍是很有用的。但是,要注意重復的運行它會覆蓋原有的配置文件。itox和 xconv都以同樣的方式工作,我們用 itox來進行演示:

    $ itox < /etc/inetd.conf > xinetd.conf
    

    新一些的工具(xconv)可以理解注釋,并且在對tcpd的使用上要比itox做得更好,使用itox,你不得不指定守護進程的路徑 (如 /usr/sbin)。 你想要包含的第一段就是默認的段,就像名字暗示的那樣,默認的xinetd服務。

    defaults
    {
       instances       = 25
       log_type        = FILE /var/adm/servicelog
       log_on_success  = PID HOST EXIT
       flags           = NORETRY
       log_on_failure  = HOST RECORD ATTEMPT
       only_from       = 129.22.0.0
       no_access       = 129.22.210.61 
       disabled        = nntp uucp tftp bootps who
                         shell login exec 
       disabled       += finger
    }
    

    馬上,我們可以了解 xinetd 設置參數的語法:<指示(directive)> <操作符(operator)> <值(value)>。xinetd所能理解的指示列在表一中,在這里我們將忽略 flags、type、env 和passenv指示符。 我對將對 only_from 和 no_access以及額外的日志選項加以更多的討論

    表 1. xinetd的指示符
    指示符 描述
    socket_type 網絡套接字類型, 流或者數據包
    socket_type 網絡套接字類型, 流或者數據包
    protocol IP 協議, 通常是TCP或者 UDP
    wait yes/no, 等同于inetd的wait/nowait
    user 運行進程的用戶 ID
    server 執行的完整路徑
    server_args 傳遞給server的變量,或者是值
    instances 可以啟動的實例的最大的值
    start max_load 負載均衡
    log_on_success 成功啟動的登記選項
    log_on_failure 聯機失敗的時候的日志信息
    only_from 接受的網絡或是主機
    no_access 拒絕訪問的網絡或是主機
    disabled 用在默認的 {} 中 禁止服務
    log_type 日志的類型和路徑 FILE /SYSLOG
    nice 運行服務的優先級
    id 日志中使用的服務名

    操作符非常簡單,“=”或者“+=”。用 =,右邊給定的值傳給左邊的指示符。+=也是非常直接的,用于給一個已經指定的指示符添加一個值。沒有它,原先的指示符就會被覆蓋,這樣可以用來展開訪問列表,或者跨越多行。

    用如下的格式描述服務:

    服務名 
    {
    指示符 = 值
    指示符 += 值
    }

    服務名一定要在 /etc/services列出 ,并且要使用合適的socket和協議。

    關于訪問控制

    關于訪問控制的有幾句話。 首先,xinetd控制連接而不是控制數據分組,它只是個用戶方的守護進程,如同inetd 一樣。同樣的,可以打斷一個被服務器禁止的主機的SYN或是connect()。但不能中止象FIN [端口掃描使用帶有FIN 標志位的TCP包,通常是nmap這樣的工具運行產生的]這樣的"秘密" 掃描。不要把xinetd 當作一個firewall 用以阻止端口掃描。一個有經驗的入侵者能夠用這些信息收集你的不同服務的訪問控制列表。幸運的是, 這些可以被xinetd紀錄。當你看到日志的時候你的疑慮會消除的。

    第二,xinetd(2.1.8.8pre3版本),當一個系統試圖連接的時候進行名字查找。以前,它在啟動的時候進行查找, 但是現在已經改變。

    使用訪問控制真的很簡單。第一個指示符是 only_from, 列出了我們可以接受從哪一個網絡或是主機的連接。這個規則可以被 no_access覆蓋。 你可以使用網絡號,如 10.0.0.0 或者 10或者是網絡名(包括 .my.com 或者 .my.com)。主機名或者主機的 IP地址也可以在這里使用指示符0.0.0.0 匹配所有的主機并監聽所有的地址。通過使用 no_access一旦符合標準拒絕就會被解析。再說一遍,網絡和主機可以指定。

    服務配置

    讓我們看一些基本的應用。我們先看第一個基本的服務echo,它是inetd 和xinetd固有的服務。

    service echo
    {
            socket_type     = stream
            protocol        = tcp
            wait            = no
            user            = root
            type            = INTERNAL
            id              = echo-stream
    }
    

    echo 以root權限運行, 是一個tcp 流并在內部處理。echo-stream指示符將出現在日志中。如果沒有only_from或是 no_access在指示符中,對這個服務的訪問的配置將是不受限制的。

    現在,讓我們看一個正規的服務,daytime:

    service daytime
    {
            socket_type     = stream
            protocol        = tcp
            wait            = no
            user            = nobody
            server          = /usr/sbin/in.date
            instances       = 1
            nice            = 10
            only_from       = 0.0.0.0
    }
    

    再說一次,任何人都可以連接, 不過我們指明它以nobody的身份運行來返回信息。和前一個例子相比,這個并沒有額外的什么。現在我們看另一個服務 secure shell version 1。下面的設置可以防止sshd所帶來的資源耗盡問題。

    service ssh1
    {
            socket_type     = stream
            protocol        = tcp
            instances       = 10
            nice            = 10
            wait            = no
            user            = root
            server          = /usr/local/sbin/sshd1
            server_args     = -i
            log_on_failure  += USERID
            only_from       = 192.168.0.0
            no_access       = 192.168.54.0 
            no_access       += 192.168.33.0
    }
    

    在這里,我們建立了前面我們所作的。當作為超級用戶inetd或者 xinetd重新調用sshd 需要用 -i 參數, 所以我們把它放在了 server_args 指示符后。注意:把這個標記添加到server標識符出會導致失敗。在任何時候只有十個人可以同時使用,在這個服務器上這不是問題,這個例子我們從日志得到。另外作為默認信息,如果不能連接的話,連接方的用戶 ID在RFC 1413中描述。最后,我們列出了兩個網絡不能訪問這個服務。

    日志和 xinetd

    日志中有幾個值可以用于得到你的服務器的信息

    表2 不同的日志指示值
    成功/失敗 描述
    PID success 當一個連接成功時登記產生的進程的pid
    HOST both 登記遠程主機地址
    USERID both 登記遠程用戶的RFC 1413 ID
    EXIT success 登記產生的進程的完成
    DURATION success 登記任務持續的時間
    ATTEMPT failure 登記連接失敗的原因
    RECORD failure 關于連接失敗的額外的信息

    這樣,可以添加一些標準的行指明日志,就像下面的樣子。對一個成功連接的服務,我們通常想登記服務產生的進程id,連接的主機和退出的時間:

    log_on_success = PID HOST EXIT
    

    這樣可以給出我們用來排錯的有用的信息和正常的服務器操做信息。針對失敗,我們可以記錄我們想要的:

    log_on_failure = HOST RECORD ATTEMPT
    

    我們記錄了連接的主機、拒絕連接的原因和關于連接中的主機的額外的信息(有的時候是那些試圖連接的用戶ID)。推薦你這樣做,可以對你的服務器有一個好的把握。

    還看上面,在我們的默認段中,我們的日志寫在/var/adm/servicelog中。我們指定所有信息,成功和失敗的都要被xinetd記錄。我們的大多數信息看起來像這樣:

    00/9/13@16:05:07: START: pop3 pid=25679 from=192.168.152.133
    00/9/13@16:05:09: EXIT: pop3 status=0 pid=25679
    00/10/3@19:28:18: USERID: telnet OTHER :www
    

    使用這個信息,可以輕易對 xinetd 排錯和進行和正常操作。也可以容易發現安全問題(如你試圖阻止的連接企圖),在日志中簡單的用 grep 作 ''FAIL'' 過濾,這些項顯示如下:

    00/10/4@17:04:58: FAIL: telnet address from=216.237.57.154
    00/10/8@22:25:09: FAIL: pop2 address from=202.112.14.184
    

    真正的安全問題需要另外的文章,但是,這足以說明,既然地址可以偽造,不要把地址報告看作固定的信息。xinetd.log文件(包含了從 xinetd得到的信息)在連接出錯的時候作為排錯信息很有用。

    00/10/25@21:10:48 xinetd[50]: ERROR: service echo-stream,
    accept:
    Connection reset by peer
    

    重配置 xinetd

    在xinetd.conf運行的時候,你可以編輯 xinetd.conf 文件。要重新配置,發送一個信號SIGUSR1 給 xinetd 進程:

    # ps -ax | grep xinetd
    50 ? S 5:47 /usr/sbin/xinetd -filelog /var/adm/xinetd.log -f /etc/xinetd.conf
    # kill -SIGUSR1 50
    

    察看日志文件的尾部(用tail命令)確保你的配置和改動已經生效。如果你是個遠程用戶的話要確保你退出后還可以重新登陸進來。注意使用-HUP對xinetd重新配置,會實際導致 xinetd 停止操作。從設計的角度看,這可以阻止黑客重新配置你的xinetd并且在無需理解文檔的情況下就可以重新載入它。

    何時使用xinetd

    以我個人而言,對所有的服務我都使xinetd;唯一一個對性能有影響的服務是我的Apache web 守護進程。太多的進程不得不啟動,對它來說這太快了從而時間效率是個問題。DNS 服務也不應該用 xinetd,性能消耗太大。

    對sendmail 服務我也使用了xinetd。這樣對于允許連接的客戶,我能夠進行完美的控制。針對 sendmail我的設置如下:

    service smtp
    {
            socket_type   = stream
            protocol      = tcp
            wait          = no
            user          = root
            server        = /usr/sbin/sendmail
            server_args   = -bs
            instances     = 20
            nice          = 10
            only_from     += 0.0.0.0
            no_access     += 129.22.122.84 204.0.224.254
    }
    

    即使是在一個高流量的郵件服務器上,對性能的影響也是可以忽略不計的。我還把 sshd 載入到 xinetd 以便阻止對它的進程表攻擊。

    結論

    希望這篇文章對你配置或是根據需要調整inetd能有幫助。正如你所看到的,它提供的特性要比inetd大得多,甚至包含了tcp_wrappers。Solar Designer (http://www.openwall.com/) 提供一個針對稍舊一點的xinetd的版本的(2.2.1版本)的補丁,允許基于IP的實例控制,這有助于阻止簡單的進程表攻擊。注意,不管怎樣,簡單的偽造可以繞過它。我不知道是否這個包對以后的 xinetd是否也適用。

    附:xinetd 代表 Extended Internet Services Daemon 下面附上一個xinetd.conf手冊頁上的參考設置:

    	#
    	# Sample configuration file for xinetd
    	#
    
    	defaults
    	{
    	     log_type		 = FILE /var/log/servicelog
    	     log_on_success	 = PID
    	     log_on_failure	 = HOST RECORD
    	     only_from		 = 128.138.193.0 128.138.204.0
    	     only_from		 = 128.138.252.1
    	     instances		 = 10
    	     disabled		 = rstatd
        }
    
    	#
        # Note 1: the protocol attribute is not required
        # Note 2: the instances attribute overrides the default
        #
         
    	service login
        {
    	    socket_type	 = stream
    	    protocol		 = tcp
    	    wait		 = no
    	    user		 = root
    	    server		 = /usr/etc/in.rlogind
    	    instances		 = UNLIMITED
        }
    
        #
        # Note 1: the instances attribute overrides the default
        # Note 2: the log_on_success flags are augmented
        #
    
        service shell
        {
    	     socket_type	 = stream
    	     wait		 = no
    	     user		 = root
    	     instances		 = UNLIMITED
    	     server		 = /usr/etc/in.rshd
    	     log_on_success	 += HOST RECORD
        }
    
        service ftp
        {
    	     socket_type	 = stream
    	     wait		 = no
    	     nice		 = 10
    	     user		 = root
    	     server		 = /usr/etc/in.ftpd
    	     server_args	 = -l
    	     instances		 = 4
    	     log_on_success	 += DURATION HOST USERID
    	     access_times	 = 2:00-9:00 12:00-24:00
        }
    
        # Limit telnet sessions to 8 Mbytes of memory and a total
        # 20 CPU seconds for child processes.
    
        service telnet
        {
    	     socket_type	 = stream
    	     wait		 = no
    	     nice		 = 10
    	     user		 = root
    	     server		 = /usr/etc/in.telnetd
    	     rlimit_as		 = 8M
    	     rlimit_cpu		 = 20
        }
    
        #
        # This entry and the next one specify internal services. Since
        # this is the same service using a different socket type, the
        # id attribute is used to uniquely identify each entry
        #
        
    	service echo
        {
    	     id			 = echo-stream
    	     type		 = INTERNAL
    	     socket_type	 = stream
    	     user		 = root
    	     wait		 = no
        }
        
        service echo
        {
    	     id			 = echo-dgram
    	     type		 = INTERNAL
    	     socket_type	 = dgram
    	     user		 = root
    	     wait		 = no
        }
    
        service servers
    	{
    	     type		 = INTERNAL UNLISTED
    	     protocol		 = tcp
    	     port		 = 9099
    	     socket_type	 = stream
    	     wait		 = no
        }
    
        #
        # Sample RPC service
        #
        service rstatd
        {
    	     type		 = RPC
    	     socket_type	 = dgram
    	     protocol		 = udp
    	     server		 = /usr/etc/rpc.rstatd
    	     wait		 = yes
    	     user		 = root
    	     rpc_version	 = 2-4
    	     env		 = LD_LIBRARY_PATH=/etc/securelib
        }
    
        #
        # Sample unlisted service
        #
        
    	service unlisted
        {
    	     type		 = UNLISTED
    	     socket_type	 = stream
    	     protocol		 = tcp
    	     wait		 = no
    	     server		 = /home/user/some_server
    	     port		 = 20020
        }
    

    翻譯后記:一日在網上看到自己在2年前的這個翻譯文檔,細讀一下,發現謬誤不少,遂找到原文,更正了一些不當之處。翻譯不當之處肯定還是存在的,歡迎指出!


    參考信息(譯者提供)


    xinetd - http://www.xinetd.org/

    Frederic Raynal的文章 - http://www.linuxfocus.org/English/November2000/article175.shtml

    xinetd HOWTO - http://www.dbanotes/net/Books/xinted.pdf




    本文譯者

    Fenng,某美資公司DBA,業余時間混跡于各數據庫相關的技術論壇且樂此不疲。目前關注如何利用ORACLE數據庫有效地構建企業應用。對Oracle tuning、troubleshooting有一點研究。
    個人技術站點:http://www.dbanotes.net/ 。可以通過電子郵件 dbanotes@gmail.com 聯系到他。
    posted on 2007-03-04 01:45 思考 閱讀(704) 評論(0)  編輯  收藏 所屬分類: Linux技術
    主站蜘蛛池模板: 亚洲1区2区3区精华液| 国产一级淫片a免费播放口| 亚洲A丁香五香天堂网| 抽搐一进一出gif免费视频| 日韩亚洲AV无码一区二区不卡| 欧洲精品成人免费视频在线观看 | 中文字幕亚洲日本岛国片| 国产精品区免费视频| 亚洲欧洲无码一区二区三区| 国产综合亚洲专区在线| 四虎永久在线精品免费观看视频| 免费福利资源站在线视频| 亚洲人成在线播放网站岛国| 日本二区免费一片黄2019| 日韩a在线观看免费观看| 一个人看的www在线免费视频| 免费在线黄色网址| 免费A级毛片在线播放| 亚洲国产成人AV网站| 免费乱码中文字幕网站| 98精品全国免费观看视频| 看Aⅴ免费毛片手机播放| 免费欧洲毛片A级视频无风险| 免费一级毛片在线播放视频| 亚洲hairy多毛pics大全| 亚洲另类激情综合偷自拍| 亚洲av再在线观看| 破了亲妺妺的处免费视频国产 | 亚洲狠狠色丁香婷婷综合| 亚洲激情中文字幕| 亚洲精品成a人在线观看| 欧美好看的免费电影在线观看| 中文字幕在线免费视频| 国产精品亚洲二区在线| 亚洲成电影在线观看青青| 国精无码欧精品亚洲一区| 亚洲福利精品一区二区三区| 免费看国产成年无码AV片| 真实国产乱子伦精品免费| 国产在线观看免费视频软件| 日本视频免费观看|