· KLDP.org · KLDP.net · KLDP Wiki · KLDP BBS ·
Linuxdoc Sgml/Multicast-HOWTO

<!doctype linuxdoc system>
<!--  Multicast over TCP/IP HOWTO -->
<article>
<title> Multicast over TCP/IP HOWTO
<author>Juan-Mariano de Goyeneche<url url="mailto:jmseyas@dit.upm.es" 
name="jmseyas@dit.upm.es">
<date>v1.0, 20 March 1998
<trans>±èÇöÇÊ<url url="mailto:khp@kldp.org" name="khp@kldp.org">
<tdate>v0.9, 10 July 2000

<abstract>
ÀÌ ¹®¼­¿¡¼­´Â TCP/IP ³×Æ®¿÷¿¡¼­ ¸ÖƼij½ºÆ®¿Í °ü·ÃµÈ Àü¹ÝÀûÀÎ »çÇ×À» ¼³¸íÇÑ´Ù. µû¶ó¼­ 
»ó´çºÎºÐ ¸®´ª½º¿¡ ±¹ÇѵǴ ³»¿ëÀÌ ¾Æ´Ï´Ù. (¾ÆÁ÷..GNU/¸®´ª½º¸¦ ¾²Áö ¾ÊÀ» °æ¿ì¿¡¸¸) 
¸ÖƼij½ºÆ®´Â Áö±Ý±îÁöµµ Ȱ¹ßÈ÷ ¿¬±¸ÁßÀÎ  ºÐ¾ßÀÌ´Ù. µû¶ó¼­ ÀÌ ±ÛÀÇ ÀÛ¼º ½ÃÁ¡¿¡¼­´Â 
Ç¥ÁØ¾È ´ëºÎºÐÀÌ ÃʾÈ(draft)ÀÏ »ÓÀÌ´Ù. ÀÌÁ¡ ¿°µÎ¿¡ µÎ°í ÀÐÀ¸½Ã±â ¹Ù¶õ´Ù.
</abstract>

<!-- Table of contents -->
<toc>

<sect>¼Ò°³<p>
³ª´Â ÀÌ ¹®¼­¿¡¼­ TCP/IP ³×Æ®¿÷¿¡¼­ ¸ÖƼij½ºÆ®¿¡ ´ëÇØ °¡´ÉÇÑ ÇÑ ±¤¹üÀ§Çϸç ÃÖ½ÅÀÇ 
±×¸®°í Á¤È®ÇÑ Á¤º¸¸¦ ´Ù·çµµ·Ï ³ë·ÂÇÒ °ÍÀÌ´Ù. ¿©·¯ºÐÀÇ ¾î¶°ÇÑ ÀǰßÀÌ¶óµµ È¯¿µÇÑ´Ù. ³»¿ë 
Áß¿¡ ¿À·ù°¡ Àְųª Á¶¾ð ¹× Ãß°¡ÇÒ ³»¿ëÀÌ ÀÖ´Ù¸é ÀúÀÚ¿¡°Ô º¸³»Áֱ⠹ٶõ´Ù.

<sect1>¸ÖƼij½ºÆ®(Multicast)¶õ ¹«¾ùÀΰ¡?<p>
¸ÖƼij½ºÆ®´Â °ð Çʿ伺ÀÌ´Ù. ¸¸ÀÏ ÀÎÅͳݻóÀÇ ¿©·¯-Àüü°¡ ¾Æ´Ñ-È£½ºÆ®¿¡°Ô·Î Àü¼ÛÇØ¾ßÇÒ 
»ó´çÇÑ·®ÀÇ Á¤º¸¸¦ °¡Áö°í ÀÖ´Ù¸é ¹Ù·Î ¸ÖƼij½ºÆ®°¡ ±× ÇØ´äÀÌ´Ù. ¿¹¸¦ µé¾î, ÀÎÅͳݿ¡ 
ºÐ»êµÇ¾î È£½ºÆ®µé·Î ¿ø°Ý ȸÀǸ¦ Çϱâ À§ÇØ ½Ç½Ã°£À¸·Î ¿µ»ó°ú À½¼ºÀ» Àü¼ÛÇÏ´Â °æ¿ì, 
¸ÖƼij½ºÆ®¸¦ »ç¿ë ÇÒ ¼ö ÀÖ´Ù.

¸ÖƼij½ºÆ®´Â »ç¿ëÀÚ°¡ ÀÚ½ÅÀÇ ¼ö½Å±â¸¦ Á¶Á¤(°ü½É ÀÖ´Â  ä³ÎÀÇ Á֯ļö ¼±ÅÃ)ÇÔÀ¸·Î¼­ 
Á¤º¸¸¦ ¹Þ´Â´Ù´Â Á¡¿¡¼­ TV³ª ¶óµð¿À¿Í À¯»çÇÏ´Ù. ´Ù¸¥ °ÍÀº Á¦Ãĵΰí ÀÚ½ÅÀÌ¿øÇÏ´Â °Í¸¸ 
¼ö½ÅÇÑ´Ù.

<sect1>À¯´Ïij½ºÆ®(Unicast)ÀÇ ¹®Á¦Á¡<p>
ºê·Îµåij½ºÆ®(Broadcast)µµ ¾Æ´Ï¸ç ¸ÖƼij½ºÆ®µµ ¾Æ´Ñ °ÍÀ» À¯´Ïij½ºÆ®¶ó ÇÑ´Ù. º°·Î
ÁÁÁö ¾ÊÀº Á¤ÀÇ °°Àºµ¥...ÆÐŶÀ» Àü¼ÛÇÒ ¶§ ¼Û½Å ÇÁ·Î¼¼½º Çϳª, ¼ö½Å ÇÁ·Î¼¼½º Çϳª°¡ 
Á¸ÀçÇÒ ¶§ À̰ÍÀ» À¯´Ïij½ºÆ®¶ó ÇÑ´Ù. TCP´Â  ±× ÀÚü°¡  º»ÁúÀûÀ¸·Î À¯´Ïij½ºÆ®¸¦ 
ÁöÇâÇÑ´Ù.  ÇÑÆí, UDP´Â ÈξÀ ´Ù¾çÇÑ
Çü½ÄÀ» °¡Áú ¼ö ÀÖÁö¸¸ ¼ö½ÅÇÏ´Â ÇÁ·Î¼¼½º°¡  ´Ü ÇϳªÀÏ ¶§ ÀÌ ¿ª½Ã  À¯´Ïij½ºÆ®¶ó ÇÒ ¼ö 
ÀÖ´Ù.

ÀÎÅÍ³Ý Ãʱ⿡´Â À¯´Ïij½ºÆ®·Î ÃæºÐÇß¾ú´Ù. 1993³â  4.4 BSD¿¡¼­ ÃÖÃÊ·Î ¸ÖƼij½ºÆ®¸¦ 
±¸ÇöÇØ¼­ ¼¼»ó¿¡ ³»³õ¾ÒÀ» ¶§±îÁö´Â ¾Æ¹«µµ ±×°ÍÀ» ÇÊ¿ä·Î ÇÏ´Â °Í  °°Áö ¾Ê¾Ò´Ù. ±×·±µ¥ 
¿Ö ¸ÖƼij½ºÆ®¶ó ºÒ¸®´Â °ÍÀÌ ³ª¿À°Ô µÈ °ÍÀϱî?

¸»ÇÒ Çʿ䵵 ¾øÀÌ ÀÎÅͳÝÀº ÃʱâÀÇ ¸ð½ÀÀ¸·ÎºÎÅÍ ¾öû³­ º¯È­¸¦ °Þ¾ú´Ù. ƯÈ÷ À¥ÀÇ µîÀåÀº 
»óȲÀ» ¿ÏÀüÈ÷ µÚ¹Ù²Ù¾î ³õ¾Ò´Ù. »ç¶÷µéÀº mail, FTP ±× ÀÌ»óÀÇ °ÍÀ», ÀڽŵéÀÇ 
ȨÆäÀÌÁö¿¡¼­ ±×¸²À» º¸±â ¿øÇß°í ´õ ³ª¾Æ°¡ À½¼º°ú µ¿¿µ»óÀ» ¿øÇß´Ù.

¿À´Ã³¯ÀÇ ±â¼úÀ̶ó¸é, ´ç½ÅÀÇ À¥À» º¸°íÀÚÇÏ´Â ¸ðµç  ÀÌ¿¡°Ô À¯´Ïij½ºÆ® ¿¬°áÀ» ÇÑ´Ù°í 
ÇØµµ ÃæºÐÈ÷ ±× "ºñ¿ë(cost)"¸¦ °¨´çÇÒ ¼ö ÀÖ´Ù. ÇÏÁö¸¸ À½ÇâÀ̳ª  ¿µ»óÀ» º¸³»°íÀÚ ÇÑ´Ù¸é 
¾öû³­ ´ë¿ªÆøÀÌ ÇÊ¿äÇÏ´Ù. ¸ÖƼij½ºÆ®¸¦ °í·Á¿¡ ³Ö´Â´Ù¸é µÎ °¡Áö ¼±ÅÃÀÌ ÀÖ´Ù. ¾Æ´Ï, 
¸ÖƼij½ºÆ®°¡ µîÀåÇϱâ Àü±îÁö´Â µÎ °¡Áö ¼±ÅÃÀÌ Á¸ÀçÇß¾ú´Ù. À¯´Ïij½ºÆ®¸¦  ÅëÇØ °¢ 
¼ö½ÅÀÚº°·Î µ¶¸³µÈ ¿¬°áÀ» ÇÒ °ÍÀΰ¡, ¾Æ´Ï¸é ºê·Îµåij½ºÆ®¸¦ ÇÒ °ÍÀΰ¡.

ÀüÀÚ´Â ºÎÀûÀýÇÏ´Ù. À½¼º/¿µ»óÀÇ ´ÜÀÏ ¿¬°áÁ¶Â÷µµ »ó´çÇÑ ´ë¿ªÆøÀ» Â÷ÁöÇÒ ÅÍÀε¥ ÀÌ·¯ÇÑ 
¿¬°áÀÌ ¼ö¹é ¶Ç´Â ¼öõÀ̶ó°í »ó»óÇØ º¸¶ó. ¾Æ¸¶µµ ´ç½ÅÀÇ ÄÄÇ»ÅÍ¿Í ³×Æ®¿÷Àº ºØ±«ÇÏ°í ¸» 
°ÍÀÌ´Ù.

ºê·Îµåij½ºÆ®°¡ ÇØ´äÀÎ µí ÇÏÁö¸¸ ±×°Íµµ È®½ÅÇÒ ¼ö°¡ ¾ø´Ù. ¿ì¸® LAN¿¡ ÀÖ´Â ¸ðµç 
È£½ºÆ®°¡ ȸÀÇ¿¡ Âü¼®ÇÑ´Ù¸é ºê·Îµåij½ºÆ®°¡ È®½ÇÈ÷ ÇØ´äÀÌ µÉ ¼ö ÀÖ´Ù. ¸ðµç ÆÐŶÀº 
Çѹø¾¿¸¸ Àü¼ÛµÇ¸ç ´Ù¸¥ ¸ðµç È£½ºÆ®´Â ºê·Îµåij½ºÆ® ÁÖ¼Ò¸¦ ÅëÇØ ÆÐŶÀ» ¼ö½ÅÇÒ °ÍÀÌ´Ù. 
ÇÏÁö¸¸, ¹®Á¦´Â ÀϺΠȣ½ºÆ®¸¸ÀÌ ÀÌ ÆÐŶ¿¡ ¼ö½ÅÇÏ·ÁÇÒ  °æ¿ì´Ù. °Ô´Ù°¡, Á¤¸»·Î ȸÀÇ¿¡ 
Âü¿©ÇϰíÀÚÇÏ´Â ´Ü ÇϳªÀÇ È£½ºÆ®°¡ ¸î °³ÀÇ ¶ó¿ìÅ͸¦ °ÅÃÄ¾ß µµ´Þ ÇÒ  ¼ö ÀÖ´Â ¿ÜºÎ 
LAN¿¡ Á¸ÀçÇÑ´Ù¸é ¾î·Á¿î ¹®Á¦°¡ µÈ´Ù. ¾Ë´Ù½ÃÇÇ, ºê·Îµåij½ºÆ®´Â ´ÜÀÏ LAN ³»ºÎ¿¡¼­¸¸ 
°¡´ÉÇѵ¥, ºê·Îµåij½ºÆ® ÆÐŶÀ» ¶ó¿ìÆÃÇÏ¿© ¿ÜºÎ LAN¿¡ Àü´ÞÇÒ ¹æ¹ýÀÌ ¾ø´Ù.

ÃÖ¼±ÀÇ ÇØ°áÃ¥Àº ÆÐŶÀ» -¸¶Ä¡ TV³ª ¶óµð¿À ä³Îó·³-ÀϺΠƯÁ¤ÇÑ Áּҷθ¸ º¸³»´Â 
°ÍÀÌ´Ù. ±×·¯¸é ȸÀÇ¿¡ Âü¿©ÇϰíÀÚÇÏ´Â ¸ðµç È£½ºÆ®´Â ÀÌ ÆÐŶÀÌ ³×Æ®¿÷À» Åë°úÇÒ ¶§, 
¸ñÀûÁö ÁÖ¼Ò(destination address)¸¦ °¨ÁöÇÏ¿© ÀоîµéÀÎ ÈÄ ÀÚ½ÅÀÇ IP°èÃþ(layer)À¸·Î º¸³»¾î 
º¹È£È­(demultiplexing)ÇÑ´Ù. Áï, ¸ÖƼij½ºÆ®´Â ÆÐŶÀÌ ´Ü Çѹø¸¸ ¼Û½ÅµÇ¾î¼­ ³×Æ®¿÷ÀÇ ¸ðµç 
È£½ºÆ®µéÀÌ ±×°ÍÀ»  Àд´ٴ Á¡¿¡¼­´Â ºê·Îµåij½ºÆ®¿Í °°Áö¸¸, ÀÌ ÆÐŶµéÀÌ ¿ÀÁ÷ 
Ä¿³Î(kernel)¿¡¼­ ¿øÇÒ °æ¿ì¿¡¸¸ ÀÐ°í  Ã³¸®ÇÑ´Ù´Â Á¡¿¡¼­ ºê·Îµåij½ºÆ®¿Í ´Ù¸£´Ù.

ÀÌ Æ¯º°ÇÑ ÆÐŶµéÀº IP ÆÐŶÀ̱⠶§¹®¿¡ Ä¿³Î ¼öÁØ(kernel level)¿¡¼­ ¶ó¿ìÆÃÇÑ´Ù. Ä¿³Î¿¡ 
¶ó¿ìÆÃ °æ·Î¸¦ ¾Ë·ÁÁÖ´Â ¶ó¿ìÆÃ ¾Ë°í¸®Áò¿¡ Â÷ÀÌÁ¡ÀÌ ÀÖÀ» °ÍÀÌ´Ù.

<sect>¸ÖƼij½ºÆ®<p>
<sect1>Multicast ÁÖ¼Ò<p>
IP ÁÖ¼Ò´Â 32ºñÆ® Áß¿¡¼­ »óÀ§ ºñÆ®µé¿¡ ÀÇÇØ¼­ Ŭ·¡½º(class)·Î ºÐ·ùµÈ´Ù.

<verb>
     Bit -->  0                           31            Address Range:
             +-+----------------------------+
             |0|       Class A Address      |       0.0.0.0 - 127.255.255.255
             +-+----------------------------+
             +-+-+--------------------------+
             |1 0|     Class B Address      |     128.0.0.0 - 191.255.255.255
             +-+-+--------------------------+
             +-+-+-+------------------------+
             |1 1 0|   Class C Address      |     192.0.0.0 - 223.255.255.255
             +-+-+-+------------------------+
             +-+-+-+-+----------------------+
             |1 1 1 0|  MULTICAST Address   |     224.0.0.0 - 239.255.255.255
             +-+-+-+-+----------------------+
             +-+-+-+-+-+--------------------+
             |1 1 1 1 0|     Reserved       |     240.0.0.0 - 247.255.255.255
             +-+-+-+-+-+--------------------+
</verb>

¿ì¸®°¡ ÁÖÀÇ ±í°Ô ÇÒ °ÍÀº "D Ŭ·¡½º ÁÖ¼Ò"´Ù. ¸ñÀûÁö ÁÖ¼Ò°¡ 
"1110"À¸·Î ½ÃÀÛÇÏ´Â IP  µ¥ÀÌÅͱ׷¥Àº ¸ÖƼij½ºÆ® µ¥ÀÌÅͱ׷¥ÀÌ´Ù.

³ª¸ÓÁö 28ºñÆ®´Â ¼Û½ÅÇÒ µ¥ÀÌÅͱ׷¥ÀÇ ¸ÖƼij½ºÆ®<em>±×·ì</em>À»  ±¸ºÐÇϴµ¥ ¾²ÀδÙ.
¹æ¼ÛÀ» µè±â À§ÇØ ¶óµð¿À¸¦ ¾î¶² Á֯ļö¿¡ ¸ÂÃß´Â °Í°ú À¯»çÇÏ°Ô Æ¯Á¤ÇÑ ¸ÖƼij½ºÆ® 
±×·ìÀ¸·Î Àü¼ÛµÇ¾î¿À´Â ÆÐŶÀ» ¼ö½ÅÇϱâ À§Çؼ­ ¿ì¸®ÀÇ Ä¿³ÎÀ» ƯÁ¤ÇÑ ±×·ì¿¡ ¸ÂÃß¾î¾ß 
ÇÑ´Ù. ÀÌ °úÁ¤ÀÌ ÀÌ·ç¾î Á³À» ¶§, <em>È£½ºÆ®°¡, ÁöÁ¤ÇÑ ÀÎÅÍÆäÀ̽º¸¦ ÅëÇØ ±×·ì¿¡ 
Âü¿©Çß´Ù</em>°í ÇÒ ¼ö ÀÖ´Ù. ÈÄ¿¡ ´õ ÀÚ¼¼È÷ ´Ù·ê °ÍÀÌ´Ù.

<em>¿¹¾àµÈ ¸ÖƼij½ºÆ® ±×·ì(well known multicast groups)</em>À̶ó ºÒ¸®´Â Ưº°ÇÑ 
±×·ìµéÀÌ Àִµ¥ ÀÌ·¯ÇÑ ±×·ìÀº ´ÙÀ½°ú °°Àº Ư¼öÇÑ ¿ëµµ·Î ¾²À̱⠶§¹®¿¡ °³ÀÎÀûÀÎ 
ÇÁ·Î±×·¥ Á¦ÀÛ ½Ã¿¡ »ç¿ëÇÒ ¼ö ¾ø´Ù.

<itemize>
<item>224.0.0.1 Àº Àüü È£½ºÆ® ±×·ìÀÌ´Ù. ¸ÖƼij½ºÆ® ÀÎÅÍÆäÀ̽º´Â ½Ãµ¿½Ã ÀÌ ±×·ì¿¡ 
Âü¿©ÇؾßÇϹǷΠÀÌ ÁÖ¼Ò·Î pingÀ» º¸³»¸é ¸ðµç ¸ÖƼij½ºÆ® È£½ºÆ®µéÀÌ ÀÀ´äÇÒ °ÍÀÌ´Ù.
<item>224.0.0.2 Àº Àüü ¶ó¿ìÅÍ ±×·ìÀÌ´Ù.
<item>224.0.0.4 Àº Àüü DVMRP ¶ó¿ìÅÍ ±×·ìÀÌ´Ù.
<item>224.0.0.5 Àº Àüü OSPF ¶ó¿ìÅÍ ±×·ìÀÌ´Ù.
<item>224.0.013 Àº Àüü PIM ¶ó¿ìÅÍ ±×·ìÀÌ´Ù.
<item>...
</itemize>

ÀÌ Æ¯¼ö ±×·ìµéÀº ¸ðµÎ RFC¹®¼­ "Assigned Numbers"¿¡ Á¤±âÀûÀ¸·Î µî·ÏµÈ´Ù.

¾î¶°ÇÑ °æ¿ìµçÁö, 224.0.0.0¿¡¼­ 224.0.0.225ÀÇ ¹üÀ§´Â Áö¿ªÀûÀÎ ¸ñÀû(°ü¸®³ª  À¯Áö/º¸¼ö)À» 
À§ÇØ ¿¹¾àµÇ¾î ÀÖÀ¸¸ç ¸ÖƼij½ºÆ® ¶ó¿ìÅ͵鵵 ÀÌ ¹üÀ§ ³»ÀÇ ÁÖ¼Ò·Î ¸ñÀûÁö·Î ÇÏ´Â 
µ¥ÀÌÅͱ׷¥Àº Æ÷¿öµùÇÏÁö ¾ÊÀ» °ÍÀÌ´Ù. ÀÌ¿Í À¯»çÇÏ°Ô 239.0.0.0¿¡¼­ 239.255.255.255ÀÇ 
¹üÀ§´Â"administrative scoping"À» À§ÇÏ¿© ¿¹¾àµÇ¾î ÀÖ´Ù. ("administrative 
scoping")¿¡ °üÇØ¼­´Â 2.3.1À» ÂüÁ¶ÇÒ °Í).

<sect1>ÀûÀÀ ´Ü°è(Levels of Conformance)<p>
È£½ºÆ®°¡ ¸¸Á·ÇؾßÇÏ´Â ¸ÖƼij½ºÆ® ±Ô°Ý¿¡´Â ¼¼ °¡Áö ÀûÀÀ ´Ü°è°¡ ÀÖ´Ù.

<bf>Level 0 :</bf> <em>the no support for IP Multicasting</em>
IPv4¿¡¼­´Â ¸ÖƼij½ºÆ®°¡ Àǹ«ÀûÀ¸·Î ±¸ÇöÇØ¾ßÇÏ´Â °ÍÀÌ ¾Æ´Ï±â ¶§¹®¿¡ ÀÎÅͳݿ¡ ÀÖ´Â 
¸¹Àº È£½ºÆ®¿Í ¶ó¿ìÅ͵éÀº Level 0 »óÅ¿¡ ÀÖ´Ù. (ÇÏÁö¸¸ IPv6¿¡¼­´Â Àǹ«ÀûÀ¸·Î 
¸ÖƼij½ºÆ®¸¦ Áö¿øÇϵµ·Ï Çϰí ÀÖ´Ù.) ´õ ÀÌ»ó ¼³¸íÀº ÇÊ¿ä ¾ø´Ù. ÀÌ »óÅ¿¡ Àִ ȣ½ºÆ®´Â 
¸ÖƼij½ºÆ® ÆÐŶÀ» º¸³»°Å³ª ¹ÞÀ» ¼ö ¾øÀ¸¸ç, ¸ÖƼij½ºÆ® ÆÐŶÀ» ¿ÏÀüÈ÷ ¹«½ÃÇÑ´Ù.

<bf>Level 1 :</bf>  <em>the support for  sending but not receiving multicast 
IP datagrams</em>
µû¶ó¼­, µ¥ÀÌÅͱ׷¥À» º¸³»±â À§Çؼ­ ¸ÖƼij½ºÆ® ±×·ì¿¡ °¡ÀÔÇÒ ÇÊ¿ä´Â ¾ø´Ù. Level 0 
È£½ºÆ®¸¦ Level 1 ȣȯ »óÅ·Π¸¸µé±â À§Çؼ­´Â IP ¸ðµâÀ»  ¾à°£ º¯°æÇØ¾ß ÇÑ´Ù. ÀÚ¼¼ÇÑ 
³»¿ëÀº 2.3¿¡¼­ ´Ù·é´Ù.

<bf>Level 2 : </bf>  <em>the full support for IP multicasting</em>
Level 2 È£½ºÆ®´Â ¸ÖƼij½ºÆ® µ¥ÀÌÅͱ׷¥ ¼Û½Å°ú ¼ö½ÅÀÌ °¡´ÉÇØ¾ß ÇÑ´Ù. ¶Ç, ¸ÖƼij½ºÆ® 
±×·ì¿¡ Âü°¡Çϰí Å»ÅðÇÒ ¼ö ÀÖ¾î¾ß ÇÏ¸ç »õ·Î °»½ÅµÈ ¸ÖƼij½ºÆ® Á¤º¸¸¦ ¶ó¿ìÅÍ¿¡ ¾Ë ¸± ¼ö 
ÀÖ¾î¾ß ÇÑ´Ù. µû¶ó¼­, È£½ºÆ®ÀÇ TCP/IP ½ºÅÿ¡ ÀÎÅÍ³Ý ±×·ì°ü¸® ÇÁ·ÎÅäÄÝ Internet Group 
Management Protocol  (IGMP) ÀÌ ±¸ÇöµÇ¾î ÀÖ¾î¾ß ÇÑ´Ù.

<sect1>¸ÖƼij½ºÆ® µ¥ÀÌÅͱ׷¥ Àü¼Û<p>
ÀÌ»óÀ¸·Î ¹Ì·ç¾îº¸¾Æ, ¸ÖƼij½ºÆ® Æ®·¡ÇÈÀº UDP·Î Æ®·£½ºÆ÷Æ® °èÃþ¿¡¼­ ó¸®ÇÏ´Â °ÍÀÌ 
ºÐ¸íÇÏ´Ù. TCP´Â Á¡´ëÁ¡(point-to-point)¿¬°áÀ» Á¦°øÇÏ´Â °ÍÀ̹ǷΠ¸ÖƼij½ºÆ® Æ®·¡ÇÈ¿¡ 
ÀûÇÕÇÏÁö ¾Ê´Ù. (»õ·Î¿î  ¸ÖƼij½ºÆ® ÁöÇâ Æ®·£½ºÆ÷Æ® ÇÁ·ÎÅäÄÝ ¼³°è¿Í ±¸Çö¿¡ ´ëÇÑ ¿¬±¸°¡ 
Ȱ¹ßÈ÷ ÁøÇàÁßÀÌ´Ù. 9Àå "¸ÖƼij½ºÆ® Æ®·£½ºÆ÷Æ® ÇÁ·ÎÅäÄÝ"À» ÂüÁ¶ÇÒ °Í)

À̷лó, ÀÀ¿ëÇÁ·Î±×·¥¿¡¼­ ´ÜÁö UDP ¼ÒÄÏÀ» ¿­°í class D ¸ÖƼij½ºÆ® ÁÖ¼Ò¸¦ ¸ñÀûÁö·Î 
ÇÏ´Â µ¥ÀÌÅͱ׷¥À» ºÎ¾î³Ö±â¸¸ ÇÏ¸é µÈ´Ù. ±×·¸Áö¸¸, ¼Û½Å ÇÁ·Î¼¼½º°¡  ÅëÁ¦±ÇÀ» °¡Áö±â 
À§Çؼ­ ÇØÁÖ¾î¾ß ÇÒ ÀÛ¾÷ÀÌ ÀÖ´Ù.

<sect2>TTL.<p>
IP Çì´õÀÇ TTL(Time To Live) Çʵå´Â ¸ÖƼij½ºÆ®¿¡¼­ Áß¿äÇÑ Àǹ̸¦ °¡Áø´Ù. ÀÌ Çʵå´Â 
¶ó¿ìÆÃ ¿¡·¯·Î ÀÎÇÏ¿© µ¥ÀÌÅͱ׷¥ÀÌ ³×Æ®¿÷À» ¿µ¿øÈ÷ ¶°µ¹¾Æ´Ù´Ï´Â °ÍÀ» ¹æÁöÇÑ´Ù. 
¶ó¿ìÅÍ´Â ³×Æ®¿÷°£À» À̵¿ÇÏ´Â µ¥ÀÌÅͱ׷¥ÀÇ TTL Çʵ带 °¨¼Ò½Ã۸ç TTL Çʵ尡 0ÀÌ 
µÇ´Â µ¥ÀÌÅͱ׷¥Àº  ¹ö¸°´Ù(drop). IPv4 ¸ÖƼij½ºÆ®¿¡¼­ TTLÀº ¹®Åΰª(threshold)ÀÇ Àǹ̸¦ 
Áö´Ñ´Ù.  ´ÙÀ½ ¿¹¸¦ º¸¸é ±×  ¿ëµµ°¡ ºÐ¸íÇØÁø´Ù.

¿ì¸® ºÎ¼­ÀÇ ¸ðµç È£½ºÆ®°¡ ¼ÓÇÏ´Â ¾ÆÁÖ ±æ°í ´ë¿ªÆøÀ» ¸¹ÀÌ Â÷ÁöÇÏ´Â ¿µ»óȸÀǸ¦ ÇÑ´Ù°í 
°¡Á¤ÇÏÀÚ. ¿ì¸®ÀÇ LAN¿¡´Â ¾öû³­ ¿ë·®ÀÇ Æ®·¡ÇÈÀÌ ¹ß»ýÇÒ °ÍÀ̸ç, ¾Æ¸¶ ¿ì¸® ºÎ¼­´Â 
´Ù¾çÇÑ LANÀÌ Á¸ÀçÇÏ´Â Å« ³×Æ®¿÷ÀÏ °ÍÀÌ´Ù. ÀÌ °æ¿ì ¿ì¸®´Â LANÀ» ÅëÇÏ¿© ȸÀǸ¦ ¿­±â 
¿øÇÏÁö¸¸, ¿ì¸®ÀÇ ¸ÖƼij½ºÆ® Æ®·¡ÇÈ ¶§¹®¿¡ ÀÎÅÍ³Ý Àüü°¡ ºØ±«µÇ´Â °ÍÀ» ¿øÄ¡ ¾ÊÀ» 
°ÍÀÌ´Ù. µû¶ó¼­, ¸ÖƼij½ºÆ® Æ®·¡ÇÈÀÌ ¶ó¿ìÅͰ£À» ¾ó¸¶³ª <em>¸Ö¸®</em>À̵¿ÇÒ ¼ö ÀÖµµ·Ï 
ÇÒ °ÍÀÎÁö Á¦ÇÑÇÒ Çʿ䰡 ÀÖ´Ù. À̰ÍÀÌ TTLÀÇ ¿ëµµÀÌ´Ù. 

¶ó¿ìÅÍ´Â °¢°¢ÀÇ ÀÎÅÍÆäÀ̽º¿¡ ´ëÇØ TTL ¹®ÅÎÄ¡(threshold)°¡ ÇÒ´çÇϰí ÀÖÀ¸¸ç ÀÌ 
¹®ÅÎÄ¡º¸´Ù Å« TTL°ªÀ» °¡Áø µ¥ÀÌÅͱ׷¥¸¸ÀÌ Æ÷¿öµùµÈ´Ù. µ¥ÀÌÅͱ׷¥ÀÌ, ¾î¶² ¹®ÅÎÄ¡°¡ 
ÇÒ´çµÇ¾îÀÖ´Â ¶ó¿ìÅ͸¦ Áö³¯ ¶§, TTL°ªÀÌ ¹®ÅÎÄ¡¸¸Å­ °¨¼ÒµÇ´Â °ÍÀÌ ¾Æ´Ï¶ó´Â Á¡¿¡ 
ÁÖÀÇÇ϶ó. ¿ÀÁ÷ ºñ±³¸¸ÀÌ ÀÌ·ç¾îÁø´Ù (¾Õ¿¡¼­ ¾ð±ÞÇßµíÀÌ TTLÀº µ¥ÀÌÅͱ׷¥ÀÌ ¶ó¿ìÅ͸¦ 
Áö³¯ ¶§¸¶´Ù 1¾¿¸¸ °¨¼ÒµÈ´Ù).

´ÙÀ½ ¸®½ºÆ®¿¡ TTL¹®ÅÎÄ¡¿Í ±×¿¡ ÇØ´çµÇ´Â ¹üÀ§°¡ Ç¥½ÃµÇ¾î ÀÖ´Ù.
<verb>
  ----------------------------------------------------------------------
  TTL     Scope
  ----------------------------------------------------------------------
     0    È£½ºÆ® ³»ºÎ·Î Á¦ÇÑ. ÀÎÅÍÆäÀ̽º·Î Ãâ·ÂµÇÁö ¾ÊÀ½.
     1    µ¿ÀÏ ¼­ºê³ÝÀ¸·Î Á¦ÇÑ. ¶ó¿ìÅÍ´Â Æ÷¿öµùÇÏÁö ¾ÊÀ½.
   <32    µ¿ÀÏ »çÀÌÆ®(site), ´Üü³ª ºÎ¼­·Î Á¦ÇÑ.
   <64    µ¿ÀÏ Áö¿ª(region)À¸·Î Á¦ÇÑ.
  <128    µ¿ÀÏ ´ë·úÀ¸·Î Á¦ÇÑ.
  <255    ¹«Á¦ÇÑ. Àü¼¼°è.
  ----------------------------------------------------------------------
</verb>

"»çÀÌÆ®(site)" ³ª "Áö¿ª(region)" ¿¡ ´ëÇÑ Á¤È®ÇÑ Á¤ÀÇ´Â ¾ø´Ù. 
±×°ÍÀº ÀÌ Á¦ÇÑÀ» °¡ÇÒ °ü¸®ÀÚ¿¡°Ô ´Þ·ÁÀÖ´Ù. 

ÀÌ TTL±â¹ýÀº ¸ðµç ¿ä±¸¿¡ ºÎÀÀÇÒ ¸¸Å­ À¯¿¬¼ºÀ» Á¦°øÇÏÁö ¸øÇϸç, ƯÈ÷ °ãÃÄÁö´Â 
Áö¿ª(overlapping regions)À» ´Ù·ç°Å³ª Áö¸®Àû(geographic)À̰ųª À§»óÀû(topologic)ÀûÀÎ 
±×¸®°í ´ë¿ªÆø Á¦ÇÑÀûÀÎ ¿¬°á¿¡´Â ÀûÇÕÇÏÁö ¾Ê´Ù. ÀÌ·¯ÇÑ ¹®Á¦¸¦ ÇØ°áÇϱâ À§ÇÏ¿© 1994³â   
administratively scoped IPv4 multicast regions ÀÌ Á¦Á¤µÇ¾ú´Ù (D. Meyer's   
"Administratively Scoped IP Multicast" Internet draft ÂüÁ¶). À̰ÍÀº TTLÀ» 
ÀÌ¿ëÇÏÁö ¾Ê°í IP ÁÖ¼Ò¸¦ ÀÌ¿ëÇÏ¿© ¹üÀ§Á¦ÇÑ(scoping)À» °¡ÇÑ´Ù. 239.0.0.0 ¿¡¼­ 
239.255.255.255±îÁöÀÇ IPÁÖ¼Ò°¡ ÀÌ °ü¸®¿ë ¹üÀ§Á¦ÇÑÀ» À§ÇØ ¿¹¾àµÇ¾î ÀÖ´Ù.

<sect2>·çÇÁ¹é(Loopback)<p>
Àü¼Û È£½ºÆ®°¡ Level 2 ÀûÀÀ ´Ü°è¿¡ ÀÖÀ¸¸ç µ¥ÀÌÅͱ׷¥À» Àü¼ÛÇÏ´Â ±×·ìÀÇ ¸â¹ö·Î Âü¿©Çϰí 
ÀÖÀ» ¶§, ÆÐŶ º¹»çº»ÀÌ ·çÇÁ¹é µÈ´Ù. À̰ÍÀº ³×Æ®¿÷ ÀÎÅÍÆäÀ̽º Ä«µå°¡ ÇØ´ç ³×Æ®¿÷ 
ÀÎÅÍÆäÀ̽º°¡  ÀÚ½ÅÀÌ ³×Æ®¿÷À¸·Î Àü¼ÛÇÑ ÆÐŶÀ» ³×Æ®¿÷À¸·ÎºÎÅÍ ´Ù½Ã Àоî¿Â´Ù´Â °ÍÀÌ 
¾Æ´Ï¶ó, IP °èÃþÀÌ µ¥ÀÌÅͱ׷¥À» ÀνÄÇÏ¿© Àü¼Û Àü¿¡ ÆÐŶÀ» IP ÀԷ ť¿¡ º¹»çÇØ ³Ö´Â 
°ÍÀ» ÀǹÌÇϸç ÀÌ ±â´ÉÀº ±âº» °ª(default)À¸·Î ¼³Á¤µÇ¾î ÀÖ´Ù.

ÀÌ·¯ÇÑ ±â´ÉÀº ÇÊ¿äÇÑ °æ¿ìµµ ÀÖ°í ±×·¸Áö ¾ÊÀ» °æ¿ìµµ ÀÖ´Ù. µû¶ó¼­ Àü¼Û ÇÁ·Î¼¼½º´Â ÀÌ 
±â´ÉÀ» ¿øÇÑ´Ù¸é ÄѰųª ²ø ¼ö ÀÖ´Ù.

<sect2>ÀÎÅÍÆäÀ̽º ¼±ÅÃ<p>

´Ù¼öÀÇ ³×Æ®¿÷ ÀÎÅÍÆäÀ̽º°¡ ºÎÂøµÇ¾î Àִ ȣ½ºÆ®¿¡¼­´Â ÀÀ¿ë ÇÁ·Î±×·¥À¸·Î ÇÏ¿©±Ý ¾î¶² 
ÀÎÅÍÆäÀ̽º·Î Àü¼ÛÀ» Ãâ·ÂÇØ¾ßÇÏ´ÂÁö °áÁ¤ÇÒ ¼ö ÀÖµµ·Ï ÇØ ÁÖ¾î¾ßÇÑ´Ù. ¸¸ÀÏ ÁöÁ¤ °ªÀÌ 
¾ø´Ù¸é Ä¿³ÎÀÌ °ü¸®ÀÚÀÇ ¼³Á¤¿¡ ±âÃÊÇÏ¿© ±âº» °ªÀ» Á¤ÇÑ´Ù.

<sect1>¸ÖƼij½ºÆ® µ¥ÀÌÅͱ׷¥ ¼ö½Å<p>

<sect2>¸ÖƼij½ºÆ® ±×·ì Âü¿©(Join)<p>
ºê·Îµåij½ºÆ®´Â ¸ÖƼij½ºÆ®º¸´Ù ºñ±³Àû ±¸ÇöÇϱ⠽±´Ù. ºê·Îµåij½ºÆ®´Â Ä¿³Î¿¡ ÆÐŶ ó¸® 
±ÔÄ¢À» Ãß°¡·Î ¾Ë·ÁÁÙ Çʿ䰡 ¾ø´Ù. Ä¿³ÎÀº ºê·Îµåij½ºÆ® ÆÐŶÀ» Àаí ÀûÀýÇÑ 
ÀÀ¿ëÇÁ·Î±×·¥À¸·Î Àü´ÞÇÏ´Â ¹æ¹ýÀ» ¾Ë°í ÀÖ´Ù.

±×·¯³ª ¸ÖƼij½ºÆ®¿¡¼­´Â ¿ì¸®°¡ ¾î¶² ±×·ì¿¡ °ü½ÉÀÌ ÀÖ´ÂÁö Ä¿³Î¿¡ ¾Ë·ÁÁÙ Çʿ䰡 ÀÖ´Ù. 
Áï, Ä¿³Î¿¡ ¾î¶² ±×·ì¿¡ "Âü¿©(join)@quot;Çϵµ·Ï ¿äÃ»ÇØ¾ß ÇÑ´Ù´Â °ÍÀÌ´Ù. Çϵå¿þ¾î¿¡ 
µû¶ó, ¸ÖƼij½ºÆ® µ¥ÀÌÅͱ׷¥À» Çϵå¿þ¾î°¡ Á÷Á¢ ÇÊÅ͸µÇϰųª ¾Æ´Ï¸é IP °èÃþ¿¡¼­ ÇÏ´Â 
°æ¿ìµµ ÀÖ´Ù. ¾î¶²  °æ¿ì¿¡´Â  ¾çÂÊ  ¸ðµÎ¿¡¼­  ÀÌ·ç¾îÁö±âµµ  ÇÑ´Ù.  ¿ÀÁ÷  "Âü¿© 
(join)"¸¦ ÅëÇØ¼­ µî·ÏµÈ ±×·ì¸¸ÀÌ ¹Þ¾Æµé¿©Áø´Ù.

º»ÁúÀûÀ¸·Î ¿ì¸®°¡ ±×·ì¿¡ Âü¿©ÇÑ´Ù´Â °ÍÀº Ä¿³Î¿¡°Ô ´ÙÀ½°ú °°Àº À̾߱⸦ ÇÏ´Â °ÍÀ» 
ÀǹÌÇÑ´Ù. <em>" ±âº» ¼³Á¤À¸·Î ¸ÖƼij½ºÆ® µ¥ÀÌÅͱ׷¥À» ó¸®ÇÏÁö ¾Ê´Â´Ù´Â °ÍÀ» 
¾Ë°í ÀÖÁö¸¸, ³»°¡ ÀÌ ¸ÖƼij½ºÆ® ±×·ì¿¡ Âü¿©ÇϰíÀÚ ÇÑ´Ù´Â Á¡À» ±â¾ïÇØÁֱ⠹ٶõ´Ù. 
±×·¯´Ï ÀÌ ³×Æ®¿÷ ÀÎÅÍÆäÀ̽º¿¡¼­ º¸ÀÌ´Â ÆÐŶ°¡¿îµ¥, ÀÌ ¸ÖƼij½ºÆ® ±×·ì ÁÖ¼Ò¸¦ ¸ñÀûÁö 
Çʵ忡 Æ÷ÇÔÇϰí ÀÖ´Â ¸ÖƼij½ºÆ® µ¥ÀÌÅͱ׷¥À» Àаí (³ª»Ó¸¸ ¾Æ´Ï¶ó ±×°Í¿¡ °ü½ÉÀ» °¡Áö°í 
ÀÖ´Â ¸ðµç) ÇÁ·Î¼¼½º¿¡°Ô Àü´ÞÇØ Áֱ⠹ٶõ´Ù. "</em>.

<bf>°í·ÁÇÒ °Í :</bf> ¿ì¼± ±×·ì¿¡ ´ÜÁö Âü¿©¸¸ ÇÏ´Â °ÍÀÌ ¸ðµç°Ô  ¾Æ´Ï¶ó´Â Á¡À» 
ÁÖ¸ñÇ϶ó. ¿ì¸®´Â ƯÁ¤ÇÑ ³×Æ®¿÷ ÀÎÅÍÆäÀ̽º »ó¿¡¼­ ±×·ì¿¡ Âü¿©ÇÑ´Ù. ¹°·Ð, Çϳª ÀÌ»óÀÇ 
ÀÎÅÍÆäÀ̽º·Î °°Àº ±×·ì¿¡ Âü¿©ÇÏ´Â °ÍÀÌ °¡´ÉÇÏ´Ù. ¸¸ÀÏ ÀÎÅÍÆäÀ̽º¸¦ È®½ÇÈ÷ ÁöÁ¤ÇÏÁö 
¾Ê´Â´Ù¸é µ¥ÀÌÅͱ׷¥ÀÌ Àü¼ÛµÉ ¶§ ¶ó¿ìÆÃ Å×ÀÌºí¿¡ ÀǰÅÇÏ¿© Ä¿³ÎÀÌ ÁöÁ¤ÇÒ °ÍÀÌ´Ù. ¶ÇÇÑ, 
Çϳª ÀÌ»óÀÇ  ÇÁ·Î¼¼½º°¡ µ¿ÀÏÇÑ ÀÎÅÍÆäÀ̽º·Î µ¿ÀÏÇÑ ¸ÖƼij½ºÆ® ±×·ì¿¡ Âü¿©ÇÏ´Â °Íµµ 
°¡´ÉÇÏ´Ù. ¸ðµç ÇÁ·Î¼¼½ºµéÀº ÇØ´ç ÀÎÅÍÆäÀ̽º·Î º¸³»Áö´Â µ¥ÀÌÅͱ׷¥À» ¼ö½ÅÇÑ´Ù. 

Àü¿¡ ¾ð±ÞÇßµíÀÌ, ¸ðµç ¸ÖƼij½ºÆ® È£½ºÆ®µéÀº ½Ãµ¿½Ã¿¡ Àüü È£½ºÆ® ±×·ì¿¡ Âü¿©Çϱâ 
¶§¹®¿¡ 224.0.0.1 ·Î pingÀ» º¸³»¸é  ³×Æ®¿÷ ³»¿¡¼­ ¸ðµç È£½ºÆ®µéÀÌ ÀÀ´äÀ» º¸³¾ °ÍÀÌ´Ù.

³¡À¸·Î, ÇÁ·Î¼¼½º°¡ ¸ÖƼij½ºÆ®  µ¥ÀÌÅͱ׷¥À» ¹Þ±â À§Çؼ­´Â  , Ä¿³Î¿¡°Ô,  ±×·ì¿¡ Âü¿©ÇÑ 
ÈÄ µ¥ÀÌÅͱ׷¥À» ¼Û½ÅÇÏ´Â Æ÷Æ®¸¦   ¹­µµ·Ï(bind)  ¿äÃ»ÇØ¾ß   ÇÑ´Ù.   UDP  °èÃþÀº   
ÆÐŶÀ» ÇØ¼®(demultiplex)Çϱâ À§ÇØ ¸ñÀûÁö ÁÖ¼Ò¿Í Æ÷Æ®¹øÈ£¸¦ °°ÀÌ »ç¿ëÇÏ¸ç ¾î¶² ¼ÒÄÏÀ¸·Î 
ȤÀº  ¾î¶² ¼ÒÄϵé·Î ÆÐŶÀ» º¸³¾Áö  °áÁ¤ÇÑ´Ù.

<sect2>¸ÖƼij½ºÆ® Group Å»Åð<p>
ÇÁ·Î¼¼½º°¡ ¸ÖƼij½ºÆ® ±×·ìÀ» ¶°³¯ ¶§´Â Ä¿³Î¿¡ ±× ±×·ìÀ» ¶°³ª°íÀÚ ÇÑ´Ù°í ¾Ë¸°´Ù. 
À̰ÍÀÌ Ä¿³ÎÀÌ ±× ±×·ìÀ¸·Î ¿À´Â ¸ÖƼij½ºÆ® µ¥ÀÌÅͱ׷¥À» ´õ ÀÌ»ó ¹ÞÁö ¾ÊÀ½À» ÀǹÌÇÏ´Â 
°ÍÀÌ ¾Æ´Ï¶ó´Â Á¡À» ÀÌÇØÇØ¾ß ÇÑ´Ù. ¸¸ÀÏ "multicast join" ½ÅûÀ» Á¦ÃâÇÑ 
ÇÁ·Î¼¼½º°¡ ´õ ÀÖ°í ±× ±×·ì¿¡ ¿©ÀüÈ÷ °ü½ÉÀ» °¡Áö°í ÀÖ´Â »óŶó¸é Ä¿³ÎÀº ¿©ÀüÈ÷ ÆÐŶÀ» 
¼ö½ÅÇÒ °ÍÀÌ´Ù. ÀÌ·¯ÇÑ  °æ¿ì È£½ºÆ®´Â ¸ðµç ÇÁ·Î¼¼½º°¡ ±× ±×·ìÀ» ¶°³ª±â·Î °áÁ¤ÇÒ ¶§±îÁö 
¿©ÀüÈ÷ ±×·ì¿¡ ³²¾Æ ÀְԵȴÙ.

<bf>Ãß°¡ :</bf> ±×·ìÀ» ¶°³­´Ù ÇÒÁö¶óµµ,  ¼ö½ÅÇÏ´ø Æ÷Æ®¿¡ ¿©ÀüÈ÷ ¿¬°á(bind)µÈ ä·Î 
³²¾ÆÀÖÀ» °ÍÀÌ¸ç ¾ÆÁ÷ ¸ÖƼij½ºÆ® ±×·ì¿¡ Âü¿©Çϰí ÀÖ´Â ÇÁ·Î¼¼½º°¡ ´õ ÀÖÀ¸¸é  ¸ÖƼij½ºÆ® 
trafficÀ» °è¼Ó ¼ö½ÅÇÏ°Ô µÉ °ÍÀÌ´Ù.

¸ÖƼij½ºÆ® group ¿¡ Âü¿©ÇÔ¿¡ À־, ¿äÁ¡Àº IP ¿Í data link °èÃþ¿¡ ÇØ´ç ±×·ìÀ¸·Î 
ÇâÇÏ´Â ¸ÖƼij½ºÆ® µ¥ÀÌÅͱ׷¥À»  ¹Þµµ·Ï ÁöÁ¤ÇÏ´Â °ÍÀÌ´Ù. (°æ¿ì¿¡ µû¶ó¼­´Â ¸í½ÃÀûÀ¸·Î 
Çϵå¿þ¾î¿¡ ÁöÁ¤ÇÏ´Â °æ¿ìµµ ÀÖ´Ù) À̰ÍÀº ÇÁ·Î¼¼½º ´ÜÀ§(per-process membership)°¡ 
¾Æ´Ï¶ó  È£½ºÆ® ´ÜÀ§(per-host membership)ÀÌ´Ù.

<sect2>IP ¸ÖƼij½ºÆ® ÁÖ¼Ò¿¡¼­ Ethernet/FDDI ÁÖ¼Ò·ÎÀÇ »ç»ó
(mapping)<p>
Ethernet°ú FDDI ¿¡¼­ ÇÁ·¹ÀÓ(frames)Àº 48 ºñÆ®ÀÇ ¸ñÀûÁö ÁÖ¼Ò°ø°£À» °¡Áø´Ù. ¸ÖƼij½ºÆ® 
IP ÁÖ¼Ò¸¦ ethernet/FDDI·Î »ç»óÇϱâ À§ÇÑ  ¸ÖƼij½ºÆ® ARP °°Àº °ÍÀ» ÇÇÇϱâ À§Çؼ­, 
IANA´Â ¸ÖƼij½ºÆ®¸¦ À§ÇØ ÁÖ¼Ò°ø°£À» ¿¹¾àÇß´Ù. ¸ñÀûÁö°¡, 01-00-5e-00-00-00 ¿¡¼­ 
01-00-5e-ff-ff-ff (16Áø¼ö)»çÀÌÀÇ ¸ðµç ethernet/FDDI ÇÁ·¹ÀÓÀº ¸ÖƼij½ºÆ® ±×·ìÀ» À§ÇÑ 
µ¥ÀÌÅ͸¦ °¡Áø´Ù. Á¢µÎ¾î(prefix) 01-00-5e ´Â ÇØ´ç ÇÁ·¹ÀÓÀÌ ¸ÖƼij½ºÆ® ÀÓÀ» ³ªÅ¸³»¸ç, 
¹Ù·Î ´ÙÀ½ ºñÆ®´Â  Ç×»ó 0ÀÌ´Ù. µû¶ó¼­, ³ª¸ÓÁö 23 ºñÆ®¸¸ÀÌ ¸ÖƼij½ºÆ® ÁÖ¼Ò¸¦ À§ÇØ 
»ç¿ëµÈ´Ù. ±×·±µ¥, ¸ÖƼij½ºÆ® ±×·ìÀÇ IP´Â 28ºñÆ® ±æÀÌÀ̹ǷΠ1´ë1 »ç»óÀº ºÒ°¡´ÉÇÏ´Ù. 
¿ÀÁ÷ IP ¸ÖƼij½ºÆ® ±×·ìÀÇ 23°³ ÇÏÀ§ ºñÆ®(Least Significant Bit)¸¸ÀÌ ÇÁ·¹ÀÓ¿¡ À§Ä¡ÇÑ´Ù. 
³²´Â 5°³ÀÇ »óÀ§ ºñÆ®´Â  ¹«½ÃµÇ¸ç32°³ÀÇ(2^5=32) ¼­·Î ´Ù¸¥ ¸ÖƼij½ºÆ® ±×·ìÀÌ µ¿ÀÏÇÑ 
ethernet/FDDI address»ç»óµÈ´Ù. À̰ÍÀº ethernet °èÃþÀÌ ¿ÏÀüÇÑ ÇÊÅÍ·Î ÀÛ¿ëÇÏÁö  ¸øÇÔÀ» 
ÀǹÌÇϸç, IP °èÃþÀÌ data link °èÃþÀ» Åë°úÇØ¿Â µ¥ÀÌÅͱ׷¥À» ¹ÞÀ» °ÍÀÎÁö ¹ö¸± °ÍÀÎÁö¸¦ 
°áÁ¤ÇØ¾ß  ÇÒ °ÍÀÌ´Ù. IP °èÃþÀÌ ÃÖÈÄÀÇ ¿Ïº®ÇÑ ÇÊÅÍÀÌ´Ù. 

FDDI»óÀÇ   IP   ¸ÖƼij½ºÆÃ¿¡   °üÇÑ    ÀÚ¼¼ÇÑ   ³»¿ëÀº   RFC   1390 
"Transmission of IP and ARP over FDDI Networks" ¿¡ ³ª¿ÍÀÖ´Ù. IP 
Multicast  ÁÖ¼ÒÀÇ ethernetÀ¸·ÎÀÇ   »ç»ó¿¡ °üÇÑ ´õ¿í   ÀÚ¼¼ÇÑ ³»¿ëÀº 
draft-ietf-mboned-intro-multicast-03.txt "Introduction to IP Multicast 
Routing"À» ÂüÁ¶Ç϶ó.

Token-Ring LAN »ó¿¡¼­ÀÇ IP ¸ÖƼij½ºÆ®¿¡ °ü½ÉÀÌ  ÀÖ´Ù¸é RFC 1469¸¦ ÂüÁ¶Ç϶ó.

<sect>Ä¿³Î ¿ä±¸ »çÇ×°ú ¼³Á¤<p>
Linux´Â ´ç¿¬È÷(¼³¸¶ ÀǽÉÀ»?) ¿ÏÀüÇÑ Level 2 ¸ÖƼij½ºÆ®¸¦ Áö¿øÇÑ´Ù. ¸ðµç ¼Û¼ö½Å 
¿ä±¸»çÇ×À» ¸¸Á·ÇÏ¸ç ¸ÖÆ¼Ä³½ºÆ® µ¥ÀÌÅͱ׷¥¿¡ °üÇØ¼­ ¶ó¿ìÅÍ(mrouter)ó·³ ÀÛµ¿ÇÑ´Ù.

¸ÖƼij½ºÆ® ¼Û¼ö½ÅÀÌ Çϰí½Í´Ù¸é Ä¿³Î ¼³ Á¤½Ã "IP: multicasting"¿¡ yes¶ó°í 
ÇØÁֱ⸸ ÇÏ¸é µÈ´Ù. Linux box¸¦ ¸ÖƼij½ºÆ® ¶ó¿ìÅÍ  (mrouter)·Î »ç¿ëÇÏ°í ½Í´Ù¸é 
"IP: forwarding/gatewaying", "IP: multicast routing" ±×¸®°í 
"IP: tunneling"À» ¼±ÅÃÇØÁÖ¸é µÈ´Ù. ÈÄÀÚ´Â »õ·Î¿î ¹öÀüÀÇ  mrouted°¡ 
¸ÖƼij½ºÆ® µ¥ÀÌÅͱ׷¥À» À¯´Ïij½ºÆ® µ¥ÀÌÅͱ׷¥¿¡ ĸ½¶È­(encapsulation)ÇØ¼­ º¸³»±â À§ÇØ 
IP tunneling ¿¡ ÀÇÁ¸Çϱ⠶§¹®ÀÌ´Ù. À̰ÍÀº À¯´Ïij½ºÆ® Àü¿ë  ³×Æ®¿÷¿¡ ºÐ»êµÇ¾îÀÖ´Â 
¸ÖƼij½ºÆ® È£½ºÆ®µé°£ÀÇ ¿¬°á(tunneling)À» À§Çؼ­ ÇÊ¿äÇÏ´Ù.  (mrouted´Â ¶ó¿ìÆÃ 
¾Ë°í¸®Áò-¶ó¿ìÆÃ Á¤Ã¥-À» ±¸ÇöÇϰí Ä¿³Î¿¡ ¸ÖƼij½ºÆ®  µ¥ÀÌÅͱ׷¥À» ¾î¶»°Ô ¶ó¿ìÆÃÇÒ 
°ÍÀÎÁö ¾Ë·ÁÁÖ´Â daemonÀÌ´Ù).

¾î¶°ÇÑ ¹öÀüÀÇ Ä¿³ÎµéÀº ¸ÖƼij½ºÆ®  ¶ó¿ìÆÃÀ» "EXPERIMENTAL"·Î ºÐ·ùÇϰí 
Àֱ⠶§¹®¿¡, "Code maturity level options"¼½¼Ç¿¡¼­  "Prompt for 
development  and/or incomplete code/drivers"¿É¼ÇÀ» °¡´ÉÇÏ°Ô ÇØ ÁÖ¾î¾ß ÇÑ´Ù. ¸¸ÀÏ 
mrouted°¡ ½ÇÇàÁßÀÏ ¶§ ¿ì¸®ÀÇ Linux box°¡ ¼ÓÇØÀÖ´Â µ¿ÀÏ ³×Æ®¿÷¿¡¼­ »ý¼ºµÈ trafficÀº 
Á¤»óÀûÀ¸·Î ´Ù¸¥ ³×Æ®¿÷¿¡ Æ÷¿öµùÇØÁִµ¥, ´Ù¸¥ ³×Æ®¿÷ÀÇ trafficÀ»  º¼ ¼ö ¾ø´Ù¸é ICMP 
¿¡·¯¸Þ½ÃÁö¸¦ ¹Þ°íÀÖÁö´Â ¾Ê´ÂÁö È®ÀÎÇØ º¸¶ó. °ÅÀÇ ¸ðµç °æ¿ì°¡ IP tunnelingÀ» Ȱ¼ºÈ­ 
½ÃÄѳõÁö ¾ÊÀº °æ¿ì ÀÏ °ÍÀÌ´Ù. ÀÏ´Ü ¾Ë°í³ª¸é Á¤¸» °£´ÜÇÑ °ÍÀÌÁö¸¸, Á¤¸»ÀÌÁö, ¸ð¸£´Â 
°æ¿ì¿¡´Â ½Ã°£ ²Ï³ª °É¸®°í  ÀÌÀ¯µµ ½±»ç¸® ¾Ë±â ¾î·Æ´Ù. ÀÌ·± »óȲ¿¡¼­´Â ½º´ÏÆÛ(sniffer)°¡ 
Á¤¸» À¯¿ëÇÏ´Ù!

(¸ÖƼij½ºÆ® ¶ó¿ìÆÃ¿¡ ´ëÇØ¼­´Â "Routing Policies and Forwarding Techniques" 
¼½¼Ç¿¡¼­, mrouted ¿Í tunnel ¿¡ ´ëÇØ¼­´Â "The MBone" °ú "Multicast 
applications"¿¡¼­ Ãß°¡·Î ¼³¸íÇÑ´Ù).

ÀÏ´Ü Ä¿³ÎÀ» ÄÄÆÄÀÏÇÏ°í ¼³Ä¡ÇÑ ÈÄ¿¡´Â ¸ÖƼij½ºÆ® Æ®·¡ÇÈÀ» À§ÇÑ ±âº» ¶ó¿ìÆÃ°æ·Î¸¦  ¼³Á¤ 
ÇØ¾ßÇÑ´Ù. ¿ì¸®ÀÇ ¸ñÇ¥´Â 224.0.0.0 ³×Æ®¿÷À¸·ÎÀÇ °æ·Î¸¦ Ãß°¡ÇÏ´Â °ÍÀÌ´Ù.

´ëºÎºÐÀÇ »ç¶÷µéÀÌ ÀÌ ´Ü°è¿¡¼­ °Þ´Â ¹«Á¦´Â ¸¶½ºÅ© °ªÀ¸·Î ÀÎÇÑ ¾î·Á¿òÀÌ´Ù. ¸¸ÀÏ Terry 
DawsonÀÇ À¯¸íÇÑ NET-3-HOWTO¸¦ Àоú´Ù¸é, ¿Ã¹Ù¸¥ °ªÀ» ¾Ë¾Æ ¸ÂÃß±â ¾î·ÆÁö ¾ÊÀ» 
°ÍÀÌ´Ù. ±× ¹®¼­¿¡¼­ ¼³¸íÇßµíÀÌ, ³Ý¸¶½ºÅ©(subnetmask)´Â ¿ì¸®ÀÇ IP ÁÖ¼ÒÀÇ ³×Æ®¿÷ ºÎºÐÀ»  
¸ðµÎ 1·Î ä¿ì°í È£½ºÆ® ºÎºÐÀ» ¸ðµÎ 0À¸·Î ä¿î 32ºñÆ® ¼ýÀÚÀÌ´Ù. ¼½¼Ç 2.1¿¡¼­ º¸¾ÒµíÀÌ 
Ŭ·¡½ºD ¸ÖƼij½ºÆ® ÁÖ¼Ò´Â ³×Æ®¿÷/È£½ºÆ®Çü½ÄÀ¸·Î ±¸ºÐµÇ¾îÀÖÁö ¾Ê´Ù. ´ë½Å 18ºñÆ®ÀÇ ±×·ì 
±¸ºÐÀÚ¿Í  4ºñÆ®ÀÇ Å¬·¡½ºD ±¸ºÐÀÚ·Î ÀÌ·ç¾îÁ®ÀÖ´Ù. ÀÌ 4ºñÆ®°¡ ³×Æ®¿÷ ºÎºÐ¿¡ ´ëÀÀµÇ°í 
28ºñÆ®°¡ È£½ºÆ®  ºÎºÐ¿¡ ´ëÀÀµÈ´Ù. µû¶ó¼­ ¼­ºê³Ý¸¶½ºÅ©´Â 
11110000000000000000000000000000 ½±°Ô ÀÐÀÚ¸é, 240.0.0.0ÀÌ µÈ´Ù. ±×·¯¸é ¿ÏÀüÇÑ ¸í·É¾î´Â 
´ÙÀ½°ú °°ÀÌ µÉ °ÍÀÌ´Ù.

route add 224.0.0.0 netmask 240.0.0.0 dev eth0

route ÇÁ·Î±×·¥ÀÇ ¹öÀü¿¡ µû¶ó¼­ addµÚ¿¡ -net À» ºÙ¿©¾ß ÇÏ´Â °æ¿ìµµ ÀÖ´Ù.

¿©±â¼­ eth0ÀÌ ¸ÖƼij½ºÆ® °¡´ÉÇÏ´Ù°í °¡Á¤ÇßÀ¸¸ç, ´Þ¸® ÁöÁ¤µÇÁö ¾ÊÀ» °æ¿ì ¸ÖƼij½ºÆ® 
Æ®·¡ÇÈÀÌ eth0À¸·Î Ãâ·ÂµÉ °ÍÀÌ´Ù. À̰ÍÀÌ ¿ì¸®¿¡°Ô ÇØ´çµÇÁö ¾Ê´Â´Ù¸é dev º¯¼ö °ªÀ» ´Ù¸¥  
°ªÀ¸·Î ¹Ù²Ù¾î ÁÖ¾î¾ßÇÑ´Ù.

¿©±â¼­ ´Ù½Ã Çѹø /proc  ÆÄÀϽýºÅÛÀÇ À¯¿ë¼ºÀÌ ÀÔÁõµÈ´Ù.  ¿ì¸®´Â ¿ì¸®È£½ºÆ®°¡ Âü¿©Çϰí 
ÀÖ´Â ±×·ìÀ» /proc/net/igmp¸¦ ÅëÇØ¼­ È®ÀÎÇØ º¼ ¼ö ÀÖ´Ù.

<sect>The MBone.<p>
ÀåÁ¡°ú ÇÔ²² ´ÜÁ¡µµ ÀÖ´Â ±â¼úÀÌ´Ù. ³ªÀÇ »ç°ßÀÌÁö¸¸, ÀåÁ¡Àº ºÐ¸íÇÏ´Ù´Â Á¡ÀÌ´Ù. ÁÖµÈ 
´ÜÁ¡Àº ¾ÆÁ÷ ¼ö¹éÀÇ È£½ºÆ®µé, ƯÈ÷ ¶ó¿ìÅ͵éÀÌ ¾ÆÁ÷ Áö¿øÇÏÁö ¾Ê°í ÀÖ´Ù´Â Á¡ÀÌ´Ù. 
°á°úÀûÀ¸·Î ¸ÖƼij½ºÆ®¸¦ »ç¿ëÇÏ´Â »ç¶÷µéÀº »õ·Î¿î Àåºñ¸¦ ±¸ÀÔÇÏ°í ¿î¿µÃ¼Á¦¸¦ ¼öÁ¤Çϸç 
ÀÚ½ÅÀÇ Àå¼Ò¿¡ ¸ÖƼij½ºÆ®¶ó´Â ¼¶À» ¸¸µç´Ù. ±×¸®°í ±×µéÀº ´Ù¸¥ °÷¿¡¼­ ÀڽŰú ºñ½ÁÇÑ 
ÀÏÀ» Çϰí ÀÖ´Â »ç¶÷µé°ú Åë½ÅÇÒ ¼ö¾øÀ½À» ¾Ë°ÔµÈ´Ù. ±×µé »çÀÌÀÇ ¸ÖƼij½ºÆ®¸¦ Áö¿øÇÏÁö 
¾Ê´Â ´Ü ÇϳªÀÇ ¶ó¿ìÅÍ ¶§¹®¿¡...

ÇØ´äÀº ºÐ¸íÇÏ´Ù. ±×µéÀº °¡»ó ¸ÖƼij½ºÆ® ³×Æ®¿÷À» ÀÎÅÍ³Ý ÃÖ »ó´Ü¿¡ ¸¸µé±â·Î °áÁ¤ÇÑ´Ù. 
Áï ¸ÖÆ¼Ä³½ºÆ® ¶ó¿ìÅ͸¦ °¡Áø »çÀÌÆ®µéÀº ±×µé°£¿¡ Á÷Á¢ÀûÀ¸·Î Åë½ÅÇÏ´Â °ÍÀÌ´Ù. ÇÏÁö¸¸ 
À¯´Ïij½ºÆ® ¶ó¿ìÅ͸¦ ÅëÇØ¼­ ¿¬°áµÈ »çÀÌÆ®µéÀº ´Ù¸¥ ¸ÖƼij½ºÆ® ¼¶À¸·Î À¯´Ïij½ºÆ® 
°¸½¶È­µÈ ¸ÖƼij½ºÆ® Æ®·¡ÇÈÀ» º¸³»¾ß ÇÒ °ÍÀÌ´Ù. Áß°£¿¡ °ÉÃÄÁø ¶ó¿ìÅ͵é-À¯´Ïij½ºÆ®Àü¿ë 
¶ó¿ìÅ͵é-Àº À¯´Ïij½ºÆ® Æ®·¡ÇÈÀ» ´Ù·ç´Â °ÍÀÌ µÇ¹Ç·Î ¹®Á¦°¡ µÇÁö ¾Ê´Â´Ù. ³¡À¸·Î ¼ö½Å 
Ãø¿¡¼­´Â ĸ½¶È­µÈ Æ®·¡ÇÈÀ» ´Ù½Ã ¿ø·¡ÀÇ ¸ÖƼij½ºÆ® Æ®·¡ÇÈÀ¸·Î ÇØ¼®ÇÒ  °ÍÀÌ´Ù. ÀÌ·¸°Ô 
¸ÖƼij½ºÆ® Æ®·¡ÇÈÀ» À¯´Ïij½ºÆ® Æ®·¡ÇÈÀ¸·Î ´Ù½Ã ¸ÖƼij½ºÆ® Æ®·¡ÇÈÀ¸·Î º¯È¯ÇÏ´Â °ÍÀ» 
¸ÖƼij½ºÆ® Åͳθµ(tunneling)À̶ó ÇÑ´Ù.

Áï, MBone ¶Ç´Â ¸ÖƼij½ºÆ® ¹éº»(Multicast Backbone)Àº ¸ÖƼij½ºÆ® ¼¶µéÀ» ¸ÖƼij½ºÆ®
ÅͳηΠÀ̾îÁÖ´Â °¡»ó ¸ÖƼij½ºÆ® ³×Æ®¿÷(virtual multicast network)ÀÌ´Ù.

ÀÌ MBone¿¡ °üÇÑ È°µ¿µéÀÌ È°¹ßÇÏ´Ù. ±×·¯ÇÑ ¹Ý¸é Áö±Ýµµ ÀÎÅͳݿ¡¼­´Â ½Ç½Ã°£ ¿Àµð¿À ¹× 
ºñµð¿À·Î dzºÎÇÑ ¿ø°ÝȸÀǰ¡ ÀÌ·ç¾îÁö´Â ÁßÀÌ´Ù. ÃÖ±Ù Linus Torvalds°¡ Silicon Valley 
Linux Users Group¿¡¼­ ¹ßÇ¥ÇÑ °ÍÀÌ ¶óÀ̺ê·Î ÀÎÅÍ³Ý Àü¼ÛµÈ ÀÏÀÌ ÀÖ´Ù.

MBone¿¡ °üÇÑ ´õ ÀÚ¼¼ÇÑ ÀÚ·á´Â ´ÙÀ½À» Âü°íÇ϶ó. 
<url url="http://www.mediadesign.co.at/newmedia/more/mbone-faq.html">

<sect>¸ÖƼij½ºÆ® ÀÀ¿ëÇÁ·Î±×·¥µé<p>
¸ÖƼij½ºÆ®¸¦ ´Ù·ç´Â ´ëºÎºÐÀÇ »ç¶÷µéÀº Á¶¸¸ °£¿¡ MBone¿¡ ¿¬°áÇÒ °ÍÀ̸ç mrouted¸¦ 
ÇÊ¿ä·Î ÇÒ °ÍÀÌ´Ù. ¿ì¸® ¿ª½Ã ¸ÖƼij½ºÆ®¶ó¿ìÅͰ¡ ¾ø´Â »óÅ¿¡¼­ ´Ù¸¥ ¼­ºê³ÝÀ¸·Î 
¸ÖƼij½ºÆ® Æ®·¡ÇÈÀ» Àü´ÞÇϱ⠿øÇÑ´Ù¸é mrouted°¡ ÇÊ¿äÇÏ´Ù. mrouted´Â ¸ÖƼij½ºÆ® 
µ¥ÀÌÅͱ׷¥À» À¯´Ïij½ºÆ® Çü½ÄÀ¸·Î ĸ½¶È­ÇÏ¿© (IP¿¡¼­ IP·Î) À¯´Ïij½ºÆ® ¶ó¿ìÅ͸¦ ÅëÇØ 
¸ÖƼij½ºÆ® Æ®·¡ÇÈÀ» Àü¼ÛÇÒ ¼ö ÀÖµµ·Ï ÇØÁÖ¸ç, ÀÌ ¿Ü¿¡µµ ¸î °¡Áö ±â´ÉÀÌ ÀÖ´Ù. °¡Àå 
Áß¿äÇÑ °ÍÀº ¸ÖƼij½ºÆ® µ¥ÀÌÅͱ׷¥ÀÇ ¹ß½ÅÁö¿Í ¸ñÀûÁö¸¦ °¨ÁöÇÏ¿© ¾î¶»°Ô ¶ó¿ìÆÃÀ» ÇÒ 
°ÍÀÎÁö ¾Æ´Ï¸é ÇÏÁö ¾ÊÀ» °ÍÀÎÁö  Ä¿³Î¿¡ ¾Ë·ÁÁشٴ Á¡ÀÌ´Ù. ¸ÖƼij½ºÆ® ¶ó¿ìÅ͸¦ °¡Áö°í 
ÀÖ´Ù°í ÇÏ´õ¶óµµ mrouted´Â Ä¿³Î¿¡ µ¥ÀÌÅͱ׷¥À¸·Î ¹«¾ùÀ» ÇÒÁö ¾Ë·ÁÁØ´Ù. (¾î¶»°Ô°¡ 
¾Æ´Ï¶ó ¹«¾ùÀÌ´Ù. mrouted´Â "À̰ÍÀ» Àú ÀÎÅÍÆäÀ̽º°¡ ¿¬°áµÈ ³×Æ®¿÷À¸·Î 
Æ÷¿öµùÇ϶ó."°í ¸»ÇÏÁö¸¸, ½ÇÁ¦·Î Æ÷¿öµùÀº Ä¿³ÎÀÌ ¼öÇàÇÑ´Ù.) ½ÇÁ¦ Æ÷¿öµù ÀÛ¾÷ 
ºÎºÐ(¾îµð¼­ ÇÒ °ÍÀΰ¡)°ú Æ÷¿öµù ¾Ë°í¸®Áò ºÎºÐ(¾î¶»°Ô ÇÒ °ÍÀΰ¡)À» ±¸ºÐÇÏ¸é Æ÷¿öµù 
Äڵ带 ¿ÀÁ÷ Çѹø¸¸ ÀÛ¼ºÇؼ­ Ä¿³Î¿¡ ³ÖÀ¸¸é µÇ±â ¶§¹®¿¡ ¾ÆÁÖ À¯¿ëÇÏ´Ù. Æ÷¿öµù 
¾Ë°í¸®Áò°ú Á¤Ã¥Àº ÃßÈÄ¿¡ »ç¿ëÀÚ °ø°£ÀÇ µ¥¸ó(user space daemon)¿¡¼­ ±¸ÇöµÇ¸ç, µû¶ó¼­, 
Ä¿³ÎÀ» Àç ÄÄÆÄÀÏ ÇÒ ÇÊ¿ä ¾øÀÌ ¶ó¿ìÆÃ Á¤Ã¥À» ½±°Ô ¼öÁ¤ÇÒ ¼ö ÀÖ´Ù.

´ÙÀ½ »çÀÌÆ®¿¡¼­ ¸®´ª½º·Î Æ÷ÆÃµÈ mrouted¸¦ ±¸ÇÒ ¼ö ÀÖ´Ù. 
<url url="ftp://www.video.ja.net/mice/mrouted/Linux/"> 
ÀÌ »çÀÌÆ®ÀÇ ¹Ì·¯´Â ´ÙÀ½À» ÂüÁ¶Ç϶ó.
<url url="ftp://www.video.ja.net/mice/README.mirrors"> 

´ÙÀ½À¸·Î ¸®´ª½º·Î Æ÷ÆÃµÈ ¸ÖƼij½ºÆ® ÀÀ¿ëÇÁ·Î±×·¥µé °¡¿îµ¥ MBone¿¡ ¿¬°áÇϵµ·Ï ÀÛ¼ºµÈ 
°Íµé¿¡ ´ëÇØ ¾Ë¾Æº»´Ù. ¿©±â¿¡ ÀÖ´Â ¸®½ºÆ®´Â Michael EslerÀÇ "Linux Multicast 
Information"¿¡¼­ °¡Á®¿Ô´Ù.
<url url="http://www.cs.virginia.edu/~mke2e/multicast/">. 
¸ÖƼij½ºÆ®¿Í ¸®´ª½º¿¡ ´ëÇÑ Á¤º¸°¡ ¾ÆÁÖ ¸¹¾Æ ÃßõÇÒ ¸¸ ÇÏ´Ù.

<bf>À½¼º ȸÀÇ(Audio Conference)</bf>
<itemize>
<item>NeVoT- NetworkVoice Terminal  <url 
url="http://www.fokus.gmd.de/step/nevot">
<item>RAT -UCL Robust-Audio Tool   <url 
url="http://www-mice.cs.ucl.ac.uk/mice/rat">
<item>vat - LBL visual audio tool   <url url="http://www-nrg.ee.lbl.gov/vat/">
</itemize>

<bf>¿µ»ó ȸÀÇ(Video Conference)</bf>
<itemize>
<item>ivs     -Inria     videoconferencing     system  <url 
url="http://www.inria.fr/rodeo/ivs.html">
<item>nv - Network video tool   <url url="ftp://ftp.parc.xerox.com/pub/net-research/">
<item>nv w/  Meteor -   Release of nv   w/ support for   the Matrox Meteor   
(UVa) 
<url url="ftp://ftp.cs.virginia.edu/pub/gwtts/Linux/nv-meteor.tar.gz">
<item>vic - LBL video conferencing tool   <url url="http://www-nrg.ee.lbl.gov/vic/">
<item>vic w/  Meteor -  Release  of vic  w/ support  for  the Matrox  Meteor (UVa)  
<url url="ftp://ftp.cs.virginia.edu/pub/gwtts/Linux/vic2.7a38-meteor.tar.gz">
</itemize>

<bf>±âŸ À¯Æ¿¸®Æ¼</bf>
<itemize>
<item>mmphone     Multimediaphone     service    <url 
url="http://www.eit.com/software/mmphone/phoneform.html">
<item>wb - LBL shared white board <url url="http://www-nrg.ee.lbl.gov/wb/">
<item>webcast - Reliable multicast application  for linking Mosaic browsers<url 
url="http://www.ncsa.uiuc.edu/SDG/Software/XMosaic/CCI/webcast.html">
</itemize>

<bf>ȸÀÇ µµ±¸(Session Tools)</bf>

¾à°£ ¼³¸íÇÒ Çʿ䰡 À־ À̰͵éÀº µÚ¿¡ ³õ¾Ò´Ù.
ȸÀǸ¦ ÇϰԵǸé ȸÀǸ¦ À§ÇÑ ¼­ºñ½ºµé(À½¼º, ¿µ»ó, °øÀ¯ Ä¥ÆÇ, µîµî...)¿¡ ¸ÖƼij½ºÆ® ±×·ì°ú
Æ÷Æ®µéÀ» ÇÒ´çÇÑ´Ù. ȸÀǸ¦ ½ÃÀÛÇÏ¸é ¸ÖÆ¼Ä³½ºÆ® ±×·ì°ú Æ÷Æ®, ÇÁ·Î±×·¥(vic, vat, ...)µî¿¡
°üÇÑ Á¤º¸°¡ ÁÖ±âÀûÀ¸·Î MBoneÀ¸·Î  Àü¼ÛµÈ´Ù. ȸÀÇ µµ±¸µéÀº  ÀÌ·¯ÇÑ Á¤º¸¸¦ "µè°í
"
¿ì¸®°¡ °ü½É Àִ ȸÀǰ¡ ¾ðÁ¦ ÀÖ´ÂÁö (ȤÀº ÀÖÀ»Áö) ¾Ë¾Æº¸±â ½±°Ô ¾Ë·ÁÁØ´Ù.
¶ÇÇÑ, ȸÀÇ¿¡ Âü¿©ÇÏ´Â °úÁ¤À» ½±°Ô ÇØÁØ´Ù. ÇÁ·Î±×·¥À» ½ÇÇà½ÃÄѼ­ Âü¿©ÇÒ ±×·ì/Æ÷Æ®¹øÈ£¸¦
¾Ë·ÁÁÖ´Â ´ë½Å Ŭ¸¯ÇÏ´Â °Í¸¸À¸·Î ¼¼¼Çµµ±¸µéÀÌ ÀûÀýÇÑ ÇÁ·Î±×·¥À» ½ÇÇà½ÃŰ°í ±× ÇÁ·Î±×·¥¿¡
ÀûÀýÇÑ Á¤º¸¸¦ Á¦°øÇÑ´Ù. ȸÀǵµ±¸µéÀº º¸Åë »ç¿ëÀÚ ÀÚ½ÅÀÇ È¸ÀǸ¦ MBone¿¡ ¾Ë¸®´Â ¿ªÇÒµµ 
ÇÑ´Ù.

<itemize>
<item>gwTTS - University of Virginia tele-tutoring system <url 
url="http://www.cs.Virginia.EDU/~gwtts">
<item>isc - Integrated session controller <url url="http://www.fokus.gmd.de/step/isc">
<item>mmcc - Multimedia onference control <url url="ftp://ftp.isi.edu/confctrl/mmcc">
<item>sd - LBL session directory tool <url url="ftp://ftp.ee.lbl.gov/conferencing/sd">
<item>sd-snoop - Tenet Group session directory snoop utility <url 
url="ftp://tenet.berkeley.edu/pub/software">
<item>sdr - UCL's next generation session directory <url 
url="ftp://cs.ucl.ac.uk/mice/sdr">
</itemize>

<sect>¸ÖƼij½ºÆ® ÇÁ·Î±×·¡¹Ö<p>
¸ÖƼij½ºÆ® ÇÁ·Î±×·¡¹Ö... ȤÀº, ¿ì¸®¸¸ÀÇ ÀÀ¿ëÇÁ·Î±×·¥ ÀÛ¼ºÇϱâ.

¸ÖƼij½ºÆ®¸¦ Áö¿øÇϱâ À§Çؼ­ ¸î °¡Áö È®ÀåµÈ ÀÀ¿ë ÇÁ·Î±×·¡¹Ö ÀÎÅÍÆäÀ̽º(API)°¡ 
ÇÊ¿äÇÏ´Ù. ±× °¡¿îµ¥ ´ëºÎºÐÀº setsockopt() (Ä¿³Î¿¡ Á¤º¸¸¦ Àü´ÞÇÔ) ¿Í getsockopt() 
(¸ÖƼij½ºÆ® °ü·Ã Á¤º¸ ±¸ÇÔ) µÎ °¡Áö ½Ã½ºÅÛ È£ÃâÀ» ÅëÇØ ó¸®ÇÑ´Ù. »õ·Î¿î ½Ã½ºÅÛ È£Ãâ 
µÎ°³°¡ ¸ÖƼij½ºÆ®¸¦ Áö¿øÇϱâ À§ÇØ Ãß°¡µÇ¾ú´Ù´Â ¶æÀÌ ¾Æ´Ï´Ù. setsockopt()/getsockopt()´Â 
4.2 BSD ½ÃÀýºÎÅÍ ÀÖ¾ú´Ù. ´ÜÁö Ä¿³Î¿¡ Àü´ÞÇØ ÁÖ¾î¾ßÇÏ´Â »õ·Î¿î ¸ÖƼij½ºÆ® ¿É¼ÇÀÌ 
Ãß°¡µÇ¾úÀ» »ÓÀÌ´Ù.

setsockopt()/getsockopt() ÇÔ¼öÀÇ ¼±¾ðÀÌ´Ù.
<code>
      int getsockopt(int s, int level, int optname, void* optval, int* optlen);

       int setsockopt(int s, int level, int optname, const void* optval, int optlen);
</code>

ù ¹øÂ° º¯¼ö s´Â ½Ã½ºÅÛ È£ÃâÀ» Àû¿ëÇÒ ¼ÒÄÏÀÌ´Ù. ¸ÖƼij½ºÆ®¿¡¼­ ÀÌ ¼ÒÄÏÀº AF_INET 
°è¿­  À̾î¾ßÇϸç, ¼ÒÄÏ Å¸ÀÔÀº SOCK_DGRAM ¶Ç´Â SOCK_RAW¸¦ ¾µ ¼ö ÀÖ´Ù. ´ëºÎºÐÀº 
SOCK_DGRAMÀ¸·Î ¾²Áö¸¸, ¶ó¿ìÆÃ µ¥¸óÀ»  Á¦ÀÛÇϰųª ¼öÁ¤ÇÒ °èȹÀ̶ó¸é SOCK_RAW 
ÀÌ ÇÊ¿äÇÒÁö ¸ð¸¥´Ù.

µÎ ¹øÂ° º¯¼ö levelÀº ¿É¼ÇÀ̳ª, ÁúÀÇ(query), ¸Þ½ÃÁö(message)¸¦ ó¸®ÇÒ ·¹À̾ ÀǹÌÇÑ´Ù. 
¼ÒÄÏ ·¹À̾î´Â SOL_SOCKET, IP ·¹À̾î´Â IPPROTO_IP, µîµîÀÌ´Ù. ¸ÖƼij½ºÆ® 
ÇÁ·Î±×·¡¹Ö¿¡ levelÀº Ç×»ó IPPROTO_IP À̾î¾ß ÇÑ´Ù. 

optnameÀº ¿ì¸®°¡ ¼³Á¤ °ªÀ» ÁöÁ¤ÇÏ´Â °ÍÀÎÁö ¾òÀ¸·Á ÇÏ´Â °ÍÀÎÁö¸¦ ÀǹÌÇÑ´Ù. ¼³Á¤ °ª 
ÀÚü´Â(Ä¿³Î¿¡ ¼³Á¤Çϰųª Ä¿³Î·ÎºÎÅÍ Àоî¿À´Â µÎ °æ¿ì ¸ðµÎ) optvalÀÌ´Ù. ¸ÖƼij½ºÆ® 
ÇÁ·Î±×·¡¹Ö¿¡¼­ optnames´Â ´ÙÀ½°ú °°´Ù.

<verb>
      optname              setsockopt()          getsockopt()
  IP_MULTICAST_LOOP           yes                     yes
  IP_MULTICAST_TTL            yes                     yes
  IP_MULTICAST_IF             yes                     yes
  IP_ADD_MEMBERSHIP           yes                      no
  IP_DROP_MEMBERSHIP          yes                      no
</verb>

optlenÀº optvalÀÌ °¡¸®Å°´Â µ¥ÀÌÅͱ¸Á¶ÀÇ Å©±â¸¦ ÀǹÌÇÑ´Ù. ´Ü, getsockopt()¿¡¼­´Â ¹Ýȯ 
°ªÀÌ µÈ´Ù. Ä¿³ÎÀº optname °ªÀ» optvalÀÌ °¡¸®Å°´Â ¹öÆÛ¿¡ ½á³ÖÀº ÈÄ optlenÀ» ÅëÇØ 
ÀÚ·áÀÇ Å©±â¸¦ ¾Ë·ÁÁØ´Ù.

setsockopt()/getsockopt()¸ðµÎ ½ÇÇà °á°ú ¼º°øÇϸé 0, ¿¡·¯°¡ ¹ß»ýÇϸé -1À» ¹ÝȯÇÑ´Ù.

<sect1>IP_MULTICAST_LOOP.<p>
ÇÁ·Î±×·¡¸Ó¶ó¸é, µ¥ÀÌÅ͸¦ È£½ºÆ®·Î ·çÇÁ¹é ½Ãų °ÍÀÎÁö °áÁ¤ÇؾßÇÑ´Ù. ¸¸ÀÏ, ÇÁ·Î¼¼½º°¡ 
¿©·¯ °³À̰ųª µ¥ÀÌÅ͸¦ ¸®½º´×"listening"ÁßÀÎ »ç¿ëÀÚ°¡ ÀÖ´Ù¸é ·çÇÁ¹éÀ» 
°¡´ÉÇÏ°Ô ÇØ¾ßÇÑ´Ù. ÇÏÁö¸¸, Ä«¸Þ¶ó À̹ÌÁö¸¦ Àü¼ÛÇϴµ¥ ÀÚ±â È­¸é¿¡¼­ À̹ÌÁö¸¦ º¼ Çʿ䰡 
¾ø´Ù¸é, ¾Æ¸¶µµ ·çÇÁ¹éÀÌ ÇÊ¿ä ¾øÀ» °ÍÀÌ´Ù. ÈÄÀÚÀÇ °æ¿ì ÇÁ·Î±×·¥Àº ÄÄÇ»ÅÍ¿¡ ºÎÂøµÈ 
Ä«¸Þ¶ó·ÎºÎÅÍ ¿µ»óÀڷḦ ÀÌ¹Ì °¡Áö°í ÀÖÀ» °ÍÀ̱⠶§¹®¿¡, ´Ù½Ã ¼ÒÄÏÀ¸·ÎºÎÅÍ ÀڷḦ ¹Þ±â 
¿øÇÏ´Â °æ¿ì´Â µå¹° °ÍÀÌ´Ù. ·çÇÁ¹éÀº ±âº» °ªÀ¸·Î Ȱ¼ºÈ­µÇ¾î ÀÖ´Ù.

optvalÀÌ Æ÷ÀÎÅÍÀ̱⠶§¹®¿¡ ´ÙÀ½Ã³·³ ÇØ¼­´Â ¾È µÈ´Ù.

setsockopt(socket, IPPROTO_IP, IP_MULTICAST_LOOP, 0, 1);

·çÇÁ¹éÀ» Á¤Áö½ÃŰ·Á¸é ´ÙÀ½°ú °°ÀÌ Çϰí

u_char loop;
setsockopt(socket, IPPROTO_IP, IP_MULTICAST_LOOP, &loop, sizeof(loop));

·çÇÁ¹éÀ» Ȱ¼ºÈ­½ÃŰ·Á¸é loop¸¦ 1·Î, ÁßÁö½ÃŰ·Á¸é 0À¸·Î ¼³Á¤ÇÑ´Ù.

¼ÒÄÏÀÇ ÇöÀç ·çÇÁ¹é»óŸ¦ È®ÀÎÇÏ·Á¸é ´ÙÀ½°ú °°ÀÌ ÇÑ´Ù.

u_char loop;
int size;

getsockopt(socket, IPPROTO_IP, IP_MULTICAST_LOOP, &loop, &size)

<sect1>IP_MULTICAST_TTL.<p>
Ưº°È÷ ÁöÁ¤ÇÏÁö ¾Ê´Â´Ù¸é, ¸ÖƼij½ºÆ® µ¥ÀÌÅͱ׷¥Àº Áö¿ª ³×Æ®¿÷ ¿ÜºÎ·Î Àü¼ÛµÇ´Â °ÍÀ» 
¹æÁöÇϱâ À§ÇØ TTL 1À» ±âº» °ªÀ¸·Î Àü¼ÛµÈ´Ù. TTLÀ» ¿øÇÏ´Â °ªÀ¸·Î(0¿¡¼­ 255±îÁö) 
¹Ù²Ù±â À§Çؼ­ TTL°ªÀ» º¯¼ö¿¡ ³Ö°í ÇÁ·Î±×·¥¿¡¼­ ´ÙÀ½°ú °°ÀÌ ½áÁÖ¸é µÈ´Ù.(¿©±â¼­´Â 
"ttl"À̶ó°í Çß´Ù.)

u_char ttl;
setsockopt(socket, IPPROTO_IP, IP_MULTICAST_TTL, &ttl, sizeof(ttl));

IP_MULTICAST_LOOP¿¡¼­¿Í Èí»çÇÏ´Ù.

<sect1>IP_MULTICAST_IF.<p>
ÀϹÝÀûÀ¸·Î ½Ã½ºÅÛ °ü¸®ÀÚ´Â ±âº» ÀÎÅÍÆäÀ̽º¸¦ ÁöÁ¤Çϸç, ¸ÖƼij½ºÆ® µ¥ÀÌÅͱ׷¥Àº 
±×ÂÊÀ¸·Î º¸³»Áø´Ù. ÇÁ·Î±×·¡¸Ó´Â ÀÌ ¿É¼ÇÀ» »ç¿ëÇÏ¿© ÁöÁ¤µÈ ±âº» ÀÎÅÍÆäÀ̽º¸¦ ¹«½ÃÇϰí 
Á¤ÇØÁø ¼ÒÄÏ¿¡¼­ »ç¿ëÇÒ ÀÎÅÍÆäÀ̽º¸¦  ¼±ÅÃÇÒ ¼ö ÀÖ´Ù.

struct in_addr interface_addr;
setsockopt (socket, IPPROTO_IP, IP_MULTICAST_IF, &interface_addr, 
sizeof(interface_addr));

ÀÌÈĺÎÅÍ ÀÌ ¼ÒÄÏ¿¡¼­ »ý¼ºµÈ ¸ðµç ¸ÖƼij½ºÆ® Æ®·¡ÇÈÀº À§¿¡¼­ ¼±ÅÃÇÑ ÀÎÅÍÆäÀ̽º·Î 
Ãâ·ÂµÈ´Ù. ¿ø·¡ ¼³Á¤À» ȸº¹ÇÏ¿© °ü¸®ÀÚÀÇ ¼³Á¤À»  ¹«½ÃÇϰí Ä¿³ÎÀÌ ¿ÜºÎ Ãâ·Â 
ÀÎÅÍÆäÀ̽º¸¦ ¼±ÅÃÇϵµ·Ï ÇÏ·Á¸é ÀÎÅÍÆäÀ̽º¿¡ INADDR_ANY¸¦ ¼³Á¤Çϰí À§¿Í µ¿ÀÏÇÑ 
¿É¼ÇÀ¸·Î setsockopt()¸¦ È£ÃâÇÑ´Ù.

¿ÜºÎ Ãâ·Â ÀÎÅÍÆäÀ̽º¸¦ ¼±ÅÃÇÔ¿¡ À־, ´ÙÀ½ ioctlÀÌ À¯¿ëÇÒ °ÍÀÌ´Ù.
SIOCGIFADDR (ÀÎÅÍÆäÀ̽º ÁÖ¼Ò ¾ò±â),
SIOCGIFCONF (Àüü ÀÎÅÍÆäÀ̽º ¸ñ·Ï ¾ò±â),
SIOCGIFFLAGS (ÀÎÅÍÆäÀ̽º »óÅ Ç÷¡±×(flag)¸¦ ¾ò¾î¼­ ÀÎÅÍÆäÀ̽º°¡ ¸ÖƼij½ºÆ®
°¡´ÉÇÑÁö È®ÀÎ - IFF_MULTICAST Ç÷¡±×-).

È£½ºÆ®°¡ ¸ÖƼij½ºÆ® ¶ó¿ìÅÍ·Î ÀÛµ¿ÇÑ´Ù¸é, ¿©·¯ ÀÎÅÍÆäÀ̽º¸¦ °¡Áö°í Àְųª 
IP_MULTICAST_IF¿É¼ÇÀÌ ¼³Á¤µÇ¾î ÀÖÁö ¾ÊÀ» °æ¿ì, ´Ù¸¥ ÀÎÅÍÆäÀ̽º¿¡¼­ ¸ÖƼij½ºÆ® 
Æ÷¿öµùÀÌ °¡´ÉÇÏ´õ¶óµµ ¸ÖƼij½ºÆ®´Â ±âº» ÀÎÅÍÆäÀ̽º¸¦ ÅëÇØ ÀÌ·ç¾îÁø´Ù. 

<sect1>IP_ADD_MEMBERSHIP.<p>
Ä¿³Î¿¡ ¿ì¸®°¡ ¾î¶² ±×·ì¿¡ °ü½ÉÀÌ ÀÖ´ÂÁö ¾Ë·ÁÁÖ¾î¾ß ÇÑ´Ù°í Çß´ø °ÍÀ» ´Ù½Ã »ý°¢ÇØ º¸ÀÚ. 
±×·ì¿¡ °ü½É ÀÖ´Â ÇÁ·Î¼¼½º°¡ Çϳªµµ ¾ø´Ù¸é, ±× ±×·ìÀ» ÇâÇØ¼­ Àü¼ÛµÇ¾î¿À´Â ÆÐŶÀº ¸ðµÎ 
Æó±âµÈ´Ù. µû¶ó¼­ Ä¿³Î¿¡ ¿ì¸®ÀÇ °ü½É ±×·ìÀ» ¾Ë¸®°í, ±×·ìÀÇ È¸¿ø(member)ÀÌ µÇ±â 
À§Çؼ­´Â ´ÙÀ½°úÁ¤ÀÌ ÇÊ¿äÇÏ´Ù. ¿ì¼± ip_mreq ±¸Á¶Ã¼ÀÇ ³»¿ëÀ»  ä¿î´Ù. ±×¸®°í, optvalÀ» 
¼³Á¤ÇÏ¿©  setsockopt()¸¦ È£ÃâÇØ¼­ Ä¿³Î¿¡ ÀÌ ±¸Á¶Ã¼¸¦ ³Ñ°ÜÁÖ¸é µÈ´Ù. 

ip_mreq ±¸Á¶Ã¼´Â (/usr/include/linux/in.h¿¡ ÀÖÀ½) ´ÙÀ½°ú °°´Ù.

<code>
struct ip_mreq
{
        struct in_addr imr_multiaddr;   /* IP multicast address of group */
        struct in_addr imr_interface;   /* local IP address of interface */
};
</code>

<bf>ÁÖÀÇ :</bf> ÀÌ ±¸Á¶Ã¼ÀÇ "¹°¸®Àû"  Á¤ÀÇ´Â À§ÀÇ ÆÄÀÏ¿¡ ¸í½ÃµÇ¾î
ÀÖ´Ù. ÇÏÁö¸¸, ÄÚµåÀÇ À̽ļºÀ» À§Çؼ­ <linux/in.h>À»  Æ÷ÇÔ(include)½ÃÄѼ­´Â ¾È µÈ´Ù. 
´ë½Å <linux/in.h>¸¦ Æ÷ÇÔÇÏ´Â <netinet/in.h>À» Æ÷ÇÔ½ÃÄѶó.

ù ¹øÂ° ¸â¹ö, imr_multiaddr´Â ¿ì¸®°¡ Âü¿©ÇÒ ±×·ìÁÖ¼Ò¸¦ ¸»ÇÑ´Ù. ȸ¿ø(membership)Àº 
±×·ì»Ó¸¸ ¾Æ´Ï¶ó ÀÎÅÍÆäÀ̽º¿¡µµ °ü·ÃÀÌ  ÀÖ´Ù´Â Á¡À» ¸í½ÉÇØ¾ßÇÑ´Ù. µû¶ó¼­, µÎ ¹øÂ° ¸â¹ö, 
imr_interface°ªµµ ¾Ë·ÁÁÖ¾î¾ß ÇÑ´Ù. ¿ì¸®°¡ ºÐ»êµÈ È£½ºÆ®¿¡ ÀÖ´õ¶óµµ ÀÌ·¯ÇÑ ¹æ½ÄÀ¸·Î
°¢±â ´Ù¸¥ ÀÎÅÍÆäÀ̽º¸¦ ÀÌ¿ëÇÏ¿© °°Àº ±×·ì¿¡ Âü¿©ÇÒ ¼ö ÀÖ´Ù. imr_interface´Â ¿ÍÀϵåÄ«µå 
ÁÖ¼Ò(INADDR_ANY)¸¦ ÀÌ¿ëÇÒ ¼ö  ÀÖÀ¸¸ç ÀÌ °æ¿ì ÀÎÅÍÆäÀ̽º¸¦ ¼±ÅÃÇÏ´Â ÀÏÀº Ä¿³ÎÀÌ 
ÇÑ´Ù.

ÀÏ´Ü ÀÌ ±¸Á¶Ã¼¸¦ ä¿ì¸é (struct ip_mreq  mreq;·Î  Á¤ÀÇ Çß´Ù°í Çϸé) ´ÙÀ½ ¹æ¹ýÀ¸·Î 
setsockopt()¸¦ È£ÃâÇÏ¸é µÈ´Ù.

setsockopt (socket, IPPROTO_IP, IP_ADD_MEMBERSHIP, &mreq, sizeof(mreq));

µ¿ÀÏ ¼ÒÄÏÀ¸·Î ¿©·¯ ±×·ì¿¡ Âü¿© ÇÒ ¼ö ÀÖ´Ù´Â Á¡¿¡ ÁÖ¸ñÇ϶ó. ±×·ì ¼ö Á¦ÇÑÀº 
IP_MAX_MEMBERSHIPS¿¡ Á¤ÀǵǾî ÀÖÀ¸¸ç Ä¿³Î¹öÀü 2.0.33¿¡¼­ 20ÀÌ´Ù.

<sect1>IP_DROP_MEMBERSHIP.<p>
ÀÌ °úÁ¤Àº ±×·ì¿¡ Âü¿©ÇÏ´Â °Í°ú À¯»çÇÏ´Ù.

struct ip_mreq mreq;
setsockopt (socket, IPPROTO_IP, IP_DROP_MEMBERSHIP, &mreq, sizeof(mreq));

¿©±â¼­ mreq´Â ±×·ì¿¡ Âü¿© ÇÒ ¶§ »ç¿ëÇß´ø °Í°ú µ¿ÀÏÇÑ ±¸Á¶Ã¼´Ù. imr_interface¿¡ 
INADDR_ANY¸¦ »ç¿ëÇÑ´Ù¸é Ä¿³ÎÀÌ ¼±ÅÃÇÑ Ã¹ ¹øÂ° ÀÎÅÍÆäÀ̽º°¡ Á¦°ÅµÈ´Ù.

°°Àº ¼ÒÄÏÀ¸·Î ¾ÆÁÖ ¸¹Àº ±×·ì¿¡ Âü¿©ÇßÀ» °æ¿ì ¿¬°áÀ» Á¾·áÇϱâ À§ÇØ ¸ðµç ȸ¿ø °ü°è¸¦ 
»èÁ¦ÇÒ ÇÊ¿ä´Â ¾ø´Ù. ¼ÒÄÏÀ» ´ÝÀ¸¸é ¿¬°áµÈ ¸ðµç ȸ¿ø °ü°è´Â Ä¿³ÎÀÌ ÀÇÇØ »èÁ¦µÈ´Ù. ¼ÒÄÏÀ» 
¿¬ ÇÁ·Î¼¼½º¸¦ Á¾·á(kill)½Ãų ¶§µµ µ¿ÀÏÇÏ´Ù.

³¡À¸·Î ±×·ì¿¡¼­ ȸ¿øÀ» Á¦°ÅÇÏ´Â °úÁ¤ÀÌ È£½ºÆ®·Î ÇÏ¿©±Ý ±× ±×·ìÀ¸·Î ¿À´Âµ¥ÀÌÅͱ׷¥À» 
¹ÞÁö ¸øÇϵµ·Ï ÇÏ´Â °ÍÀ» ÀǹÌÇÏ´Â  °ÍÀº ¾Æ´Ï´Ù. µ¿ÀÏ ÀÎÅÍÆäÀ̽º·Î ±× ±×·ì¿¡ Âü¿©ÇÑ 
¼ÒÄÏÀÌ IP_DROP_MEMBERSHIPÀÇ »óŰ¡ µÇ´õ¶óµµ È£½ºÆ®´Â ±×·ì ¸â¹öÀÇ ¸ñ·ÏÀ» 
º¸°üÇÑ´Ù.

ADD_MEMBERSHIP °ú DROP_MEMBERSHIP Àº ¼º°ø, ½ÇÆÐ ¿©ºÎ¸¦ Áï½Ã ¹ÝȯÇÑ´Ù. 
(nonblocking operations)

<sect>¸ÖƼij½ºÆ® ³»ºÎ<p>
ÀÌ ÀýÀÇ ¸ñÀûÀº ¸ÖƼij½ºÆ®°¡ ¾î¶»°Ô ÀÛµ¿ÇÏ´ÂÁö¸¦ ÀÌÇØÇϴµ¥ ÇÊ¿äÇÑ Á¤º¸¸¦ Á¦°øÇÏ´Â  °Í
µµ ¾Æ´Ï°í
¸ÖƼij½ºÆ® ÇÁ·Î±×·¡¹Ö¿¡ ´ëÇÑ Á¤º¸¸¦ Á¦°øÇÏÀÚ´Â °Íµµ ¾Æ´Ï´Ù. ÇÏÁö¸¸ ¸ÖƼij½ºÆ®ÀÇ 
±â¹ÝÀ» ÀÌ·ç´Â ÇÁ·ÎÅäÄݰú ±¸ÇöÀ» »ìÆìº½À¸·Î¼­ ½±°Ô ÀúÁö¸£´Â ½Ç¼ö¿Í  À߸øµÈ ÀÌÇØ¸¦ ÇÇÇÒ 
¼ö ÀÖÀ» °ÍÀÌ´Ù.

<sect1>IGMP.<p>
IP_ADD_MEMBERSHIP °ú IP_DROP_MEMBERSHIP¿¡¼­ ÀÌ ¸í·ÉÀ¸·Î Ä¿³Î¿¡ Á¦°øÇÑ 
Á¤º¸´Â ¾î¶² ¸ÖƼij½ºÆ® µ¥ÀÌÅͱ׷¥À» ¹Þ°í ¾î¶² °ÍÀ» ¹ö¸± °ÍÀÎÁö¸¦ °áÁ¤Çϴµ¥ ¾²Àδٰí 
Çß´Ù. ¸Â´Â ¸»À̶ó°í ÇÒ ¼ö ÀÖÁö¸¸, ¸ðµÎ ¸Â´Â ¸»Àº ¾Æ´Ï´Ù. ÀÌ·¯ÇÑ ÀϹÝÈ­´Â Àü  ¼¼°è ¸ðµç 
¸ÖƼij½ºÆ®µ¥ÀÌÅͱ׷¥ÀÌ ¿ì¸®ÀÇ È£½ºÆ®·Î Àü´ÞµÈ ÈÄ, È£½ºÆ®¿¡¼­ ÇÁ·Î¼¼½º°¡ ¹ßÇàÇÑ 
ȸ¿ø°ü°è¸¦ È®ÀÎ ÈÄ µ¥ÀÌÅͱ׷¥ÀÇ Æó±â ¿©ºÎ¸¦ °áÁ¤ÇÑ´Ù´Â ¸»ÀÌ µÈ´Ù. »ý°¢ÇÒ Çʿ䵵 ¾øÀÌ, 
À̰ÍÀº ¾öû³­ ´ë¿ªÆø ³¶ºñÀÓÀ» ¾Ë ¼ö ÀÖ´Ù.

½ÇÁ¦·Î´Â È£½ºÆ®°¡ ÀÚ½ÅÀÇ ¶ó¿ìÅÍ¿¡°Ô, ±× ¶ó¿ìÅÍ´Â »óÀ§ ¶ó¿ìÅÍ¿¡°Ô, ±×¸®°í ±× »óÀ§ 
¶ó¿ìÅÍ¿¡°Ô....¾î¶² ¸ÖƼij½ºÆ® ±×·ì¿¡ °ü½ÉÀÌ ÀÖ´ÂÁö ¾Ë·ÁÁØ´Ù.  ¸ÖƼij½ºÆ® ±×·ì Æ®·¡ÇÈÀ» 
¹ÞÀ» °ÍÀÎÁö ¸» °ÍÀÎÁö °áÁ¤ÇÏ´Â ¾Ë°í¸®Áò ÀÚü¿¡´Â »ó´çÈ÷ º¯È­°¡ ½ÉÇѵ¥, ´Ü ÇѰ¡Áö 
º¯ÇÏÁö ¾Ê´Â °ÍÀÌ ÀÖ´Ù¸é, ÀÌ Á¤º¸¸¦ Àü´ÞÇÏ´Â ¹æ¹ýÀÌ´Ù. À̰ÍÀº IGMP(Internet Group 
Management ProtocolÀ»  ÀÌ¿ëÇÑ´Ù. ÇÁ·ÎÅäÄݹøÈ£ 2ÀÎ IGMP´Â ICMP¿Í À¯»çÇÑ »õ·Î¿î 
ÇÁ·ÎÅäÄÝÀε¥ IP µ¥ÀÌÅͱ׷¥À» ÀÌ¿ëÇÏ¸ç ·¹º§ 2 ÀûÀÀ´Ü°èÀÇ  È£½ºÆ®´Â ÀÌ ÇÁ·ÎÅäÄÝÀ» 
Àǹ«ÀûÀ¸·Î ±¸ÇöÇØ¾ß ÇÑ´Ù. Àü¼úÇÑ ¹Ù¿Í °°ÀÌ  À̰ÍÀº ¶ó¿ìÅÍ¿¡°Ô ȸ¿øÁ¤º¸¸¦ Àü¼ÛÇÏ´Â 
È£½ºÆ®¿Í ¶ó¿ìÅÍ»çÀÌÀÇ Åë½Å ¾çÂÊ ¸ðµÎ »ç¿ëÇÑ´Ù. ´ÙÀ½ ±Û¿¡¼­ È£½ºÆ®-¶ó¿ìÅͰ£ °ü°è¸¸À» 
¼³¸íÇϱâ·Î ÇÑ´Ù. ¿Ö³ÄÇϸé mrouted¼Ò½º Äڵ带 Á¦¿ÜÇϰí´Â ¶ó¿ìÅÍ-¶ó¿ìÅͰ£ Åë½ÅÀ» 
ÇØ¼³ÇÏ´Â ÀڷḦ ãÁö ¸øÇÏ¿´±â  ¶§¹®ÀÌ´Ù. (RFC 1075-Distance  Vector Multicast  
Routing ProtocolÀº ÀÌÁ¦ »ç¿ëÇÏÁö ¾ÊÀ¸¸ç, mrouted´Â ¾ÆÁ÷ ¹®¼­È­µÇÁö ¾ÊÀº º¯ÇüµÈ 
DVMRP¸¦ ±¸ÇöÇϰí ÀÖ´Ù.)

RFC 988-IGMP ¹öÀü 0Àº ÀÌÁ¦ »ç¿ëÇÏÁö ¾Ê´Â´Ù.

IGMP ¹öÀü 1Àº RFC-1112¿¡ Á¤ÀǵǾî ÀÖ°í, RFC-2236 (IGMP version 2) ¿¡¼­ °³Á¤µÇ¾î 
ÇöÀç±îÁö ¸¹ÀÌ »ç¿ëÇϰí ÀÖ´Ù.
¸®´ª½º Ä¿³Î¿¡¼­´Â IGMP ¹öÀü 1 Àüü¿Í ¹öÀü 2ÀϺΰ¡ ±¸ÇöµÇ¾î ÀÖ´Ù.

Áö±ÝºÎÅÍ ÀÌ ÇÁ·ÎÅäÄÝ¿¡ ´ëÇÑ ¾à½Ä¼³¸íÀ» º¸ÀÚ. RFC-2236À» ÆîÃÄ ³õ°í Á¤È®ÇÑ Á¤½Ä ¼³¸íÀ» 
º¸´Â °Íµµ ÁÁ´Ù.

¸ðµç IGMP ¸Þ½ÃÁö´Â ´ÙÀ½ ±¸Á¶¸¦ °¡Áø´Ù.

<verb>
      0                   1                   2                   3
      0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1
     +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
     |      Type     | Max Resp Time |           Checksum            |
     +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
     |                         Group Address                         |
     +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
</verb>

IGMP ¹öÀü 1 (ÀÌÇÏ IGMPv1) ´Â Àü¼Û½Ã "Max Resp Time" À» 
"Unused",Áï ¸ðµÎ 0 À¸·Î ÇÏ°í ¼ö½Å½Ã¿¡´Â ¹«½ÃÇÑ´Ù. "Type"¶õÀº 
4ºñÆ® ÆøÀ¸·Î ³ª´©¾î "Version"°ú "Type"À¸·Î »ç¿ëÇÑ´Ù. IGMPv1 
¿¡¼­´Â "ȸ¿øÁúÀÇ(Membership  Query)"¸¦ 0x11  (version  1, type 1)À¸·Î 
È®ÀÎÇϰí, IGMPv2 ¿¡¼­´Â 0x11  ·Î È®ÀÎÇϱ⠶§¹®¿¡ 8ºñÆ®¸¦ »ç½Ç»ó µ¿ÀÏÇÏ°Ô ÇØ¼® ÇÑ´Ù.

IGMPv2 ´Â ÁÖ·Î Ãß°¡»çÇ×µé·Î ÀÌ·ç¾îÁ® Àֱ⠶§¹®¿¡ IGMPv1 À» ÀÏ´Ü ¼³¸íÇÑ ÈÄ IGMPv2 
Ãß°¡»çÇ×À» ¼³¸íÇÏ´Â ÆíÀÌ ÁÁÀ» °Í °°´Ù.

´ÙÀ½ ³íÀÇ¿¡¼­ ¶ó¿ìÅÍ´Â ¸ðµç IP  ¸ÖƼij½ºÆ® µ¥ÀÌÅͱ׷¥À» ¹Þ´Â´Ù´Â °ÍÀ»  ±â¾ïÇ϶ó.

<sect1>IGMP version 1.<p>
¶ó¿ìÅÍ´Â ÁÖ±âÀûÀ¸·Î(1ºÐ¿¡¼­ 2ºÐ¿¡ Çѹø¾¿) TTL°ª 1ÀÇ  IGMP È£½ºÆ® ȸ¿ø ÁúÀǸ¦ Àüü 
È£½ºÆ® ±×·ì(224.0.0.1)À¸·Î º¸³½´Ù. ¸ðµç ¸ÖƼij½ºÆ® È£½ºÆ®µéÀÌ ÀÌ ¸Þ½ÃÁö¸¦¹ÞÁö¸¸ IGMP 
È£½ºÆ® ȸ¿ø º¸°í(Host  Membership Report)°¡ ÆøÁÖ(storm)ÇÏ´Â °ÍÀ» 
¹æÁöÇϱâ À§ÇØ Áï½Ã ÀÀ´äÇÏÁö ¾Ê´Â´Ù. ´ë½Å ÁúÀǸ¦ ¼ö½ÅÇÑ ÀÎÅÍÆäÀ̽º¿¡ ¼ÓÇÏ´Â °¢ ±×·ì¿¡ 
´ëÇØ,  ÀÓÀÇ Áö¿¬ ŸÀ̸Ӹ¦ ½ÃÀÛÇÑ´Ù.

Á¶¸¸ °£¿¡ ŸÀ̸Ӱ¡ ¿Ï·áµÇ¸é È£½ºÆ®´Â ¿ª½Ã TTL 1ÀÇ IGMP ȸ¿ø º¸°í¸¦ ¸ÖƼij½ºÆ® 
±×·ì¾îµå·¹½º·Î Àü¼ÛÇÑ´Ù. ÀÌ ¸Þ½ÃÁö´Â ÀÌ¹Ì  ±×·ì¿¡ Âü¿©Çϰí ÀÖ´Â ¸ðµç È£½ºÆ®µé°ú
ŸÀ̸Ӱ¡ ¿Ï·áµÇ±â¸¦ ±â´Ù¸®°í Àִ ȣ½ºÆ®µé¿¡°Ô Àü´ÞµÈ´Ù. ±×·¯¸é °¢ È£½ºÆ®µéÀº 
ŸÀ̸Ӹ¦ ÁßÁöÇÏ°í ´õ ÀÌ»ó ¾Æ¹«·± º¸°íµµ ÇÏÁö  ¾Ê´Â´Ù. ÇÏÁö¸¸ À̰ÍÀ¸·Î ¶ó¿ìÅÍ´Â ÀÚ½ÅÀÇ 
¼­ºê³Ý¿¡ ±× ¸ÖƼij½ºÆ® ±×·ìÀÇ ¸â¹ö°¡ Á¸ÀçÇÑ´Ù´Â °Í¸¸ ¾Ë¸é µÇ±â ¶§¹®¿¡ ȸ¿øÀÌ ¸îÀ̳ª 
ÀÖ´ÂÁö ¾Ë±â À§ÇØ ´õ ÀÌ»ó, º¸°í ¹ÞÀ» Çʿ䰡 ¾ø´Ù.

¸î ¹ø ÁúÀÇÇÑ ÈÄ¿¡µµ ±× ±×·ì¿¡ ´ëÇØ ¾Æ¹«·± ȸ¿ø º¸°í°¡ ¾øÀ¸¸é ¶ó¿ìÅÍ´Â ¸â¹ö°¡ ¾ø´Â 
°ÍÀ¸·Î °£ÁÖÇϰí ÇØ´ç ±×·ìÀÇ Æ®·¡ÇÈÀ» ¼­ºê³ÝÀ¸·Î Æ÷¿öµùÇÏÁö ¾Ê´Â´Ù. IGMPv1 ¿¡¼­´Â 
"±×·ì Å»Åð ¸Þ½ÃÁö(Leave Group messages)"°¡ ¾ø´Ù´Â Á¡¿¡ ÁÖ¸ñÇ϶ó.

È£½ºÆ®°¡ »õ ±×·ì¿¡ Âü¿©Çϸé Ä¿³ÎÀº ±×·ìÀ¸·Î º¸°í¸¦ º¸³»±â ¶§¹®¿¡ °¢°¢ÀÇ ÇÁ·Î¼¼½ºµéÀº 
»õ·Î¿î ȸ¿ø ÁúÀǰ¡ µµÂøÇÒ µ¿¾È(1,2ºÐ Á¤µµ) ±â´Ù¸± Çʿ䰡 ¾ø´Ù. 
"IP_ADD_MEMBERSHIP" Á¤¿¡¼­ º¸¾Ò°ÚÁö¸¸, ÀÌ IGMP ÆÐŶÀº 
IP_ADD_MEMBERSHI¸í·É¿¡ ´ëÇÑ ÀÀ´äÀ¸·Î Ä¿³ÎÀÌ »ý¼ºÇÑ´Ù. "»õ ±×·ì"À̶ó´Â  ¸»À» ÁÖÀÇ 
±íÀÌ º¸ÀÚ.  È£½ºÆ®°¡ ÀÌ¹Ì Âü¿©ÁßÀÎ ±×·ì¿¡ ´ëÇØ ÇÁ·Î¼¼½º°¡  IP_ADD_MEMBERSHIP 
¸í·ÉÀ» º¸³¾  °æ¿ì ¿ì¸®´Â  ÀÌ¹Ì ±×  ±×·ìÀÇ Æ®·¡ÇÈÀ»  ¹Þ°í ÀÖ±â  ¶§¹®¿¡ ¾Æ¹«·± IGMP 
ÆÐŶµµ ¸¸µé¾îÁöÁö ¾ÊÀ» °ÍÀÌ´Ù. ´ë½Å ±×·ì»ç¿ë Ä«¿îÅͰ¡ Áõ°¡ÇÑ´Ù. IGMPv1¿¡¼­ 
IP_DROP_MEMBERSHIP  ¸í·ÉÀº µ¥ÀÌÅͱ׷¥À» »ý¼º½ÃŰÁö ¾Ê´Â´Ù.

È£½ºÆ® ȸ¿ø ÁúÀǴ ŸÀÔ 0x11, È£½ºÆ® ȸ¿ø º¸°í´Â °¢°¢ ŸÀÔ 0x12·Î ±¸ºÐÇÑ´Ù.

Àüü È£½ºÆ® ±×·ì¿¡´Â º¸°íÇÏÁö ¾Ê´Â´Ù. ÀÌ ±×·ìÀ¸·ÎÀÇ È¸¿øÀº ¿µ±¸ÀûÀÌ´Ù.

<sect1>IGMP ¹öÀü 2.<p>
»ó±â ³»¿ë¿¡ ´ëÇÑ Ãß°¡ »çÇ× Áß Áß¿äÇÑ °Í ÇѰ¡Áö´Â ±×·ì ÀÌÅ» ¸Þ½ÃÁö(ŸÀÔ0x17)°¡ 
Æ÷ÇԵǾú´Ù´Â »ç½ÇÀÌ´Ù. ÀÌ ¸Þ½ÃÁö´Â ¼­ºê³Ý¿¡¼­ ¸¶Áö¸· È£½ºÆ®°¡ ±×·ìÀ» ÀÌÅ»ÇÏ´Â ½ÃÁ¡°ú 
ÁúÀÇ ½Ã°£ÀÌ ¸¸·áµÇ¾î ¶ó¿ìÅͰ¡ ´õ ÀÌ»ó ±×·ì¿¡ ³²¾ÆÀִ ȸ¿øÀÌ ¾ø´Ù°í °áÁ¤ÇÏ´Â ½ÃÁ¡ 
»çÀÌÀÇ ´ë¿ªÆø ³¶ºñ(ÀÌÅ» Áö¿¬-leave latency)¸¦ ÁÙÀ̱â À§ÇØ Ãß°¡µÇ¾ú´Ù. ±×·ì ÀÌÅ» 
¸Þ½ÃÁö´Â ±×·ìÀÇ ´Ù¸¥ ¸â¹öµé¿¡°Ô´Â ºÒÇÊ¿äÇÑ Á¤º¸À̱⠶§¹®¿¡ ³²¾ÆÀÖ´Â ±×·ìº¸´Ù Àüü 
¶ó¿ìÅÍ ±×·ì(224.0.0.2)ÂÊÀ¸·Î Àü¼ÛÇØ¾ß ÇÑ´Ù. (Ä¿³Î ¹öÀü 2.0.33 ÀÌÇÏ¿¡¼­´Â ÀÌ ¸Þ½ÃÁö¸¦  
±×·ìÀ¸·Î º¸³Â¾ú´Ù. È£½ºÆ®·Î¼­´Â ÇØ¸¦ ÀÔÀ» ÀÏÀº ¾øÁö¸¸, ¾µµ¥¾ø´Â Á¤º¸ÀÌ±â  ¶§¹®¿¡ ÀÌ 
Á¤º¸¸¦ ó¸®ÇÏ´Â °ÍÀº ½Ã°£³¶ºñÀÏ »ÓÀÌ´Ù.) ¾ðÁ¦ ÀÌÅ» ¸Þ½ÃÁö¸¦ º¸³¾ °ÍÀΰ¡, ¾ðÁ¦ º¸³»Áö 
¾ÊÀ» °ÍÀΰ¡ ÇÏ´Â ¹®Á¦¿¡ ´ëÇØ¼­´Â ¸î °¡Áö ¹Ì¹¦ÇÑ ¹®Á¦°¡ ÀÖ´Ù. °ü½ÉÀÌ ÀÖ´Ù¸é RFC¸¦ 
ÂüÁ¶ÇÒ °Í.

IGMPv2¶ó¿ìÅͰ¡ ÀÌÅ» ¸Þ½ÃÁö¸¦ ¹ÞÀ¸¸é ¶ó¿ìÅÍ´Â ±×·ìÀ» ÁöÁ¤ÇÏ¿©(group-specific) 
³²¾ÆÀÖ´Â ±×·ì¿¡°Ô ÁúÀǸ¦ º¸³½´Ù. À̰͵µ IGMPv2 ¿¡¼­ Ãß°¡µÈ »çÇ×ÀÌ´Ù. IGMPv1¿¡¼­ 
±×·ì ÁöÁ¤ ÁúÀÇ´Â ¾ø¾ú´Ù. ¸ðµç ÁúÀǰ¡ Àüü È£½ºÆ® ±×·ìÀ¸·Î º¸³»´Â ÁúÀÇ¿´´Ù. IGMP 
Çì´õ¿¡ Á¤ÀÇµÈ Å¸ÀÔ °ªÀº º¯ÇÏÁö ¾Ê¾ÒÁö¸¸(Àü°ú µ¿ÀÏÇÏ°Ô 0x11), "±×·ì ÁÖ¼Ò(Group 
Address)"Çʵå´Â ³²¾ÆÀÖ´Â ¸ÖƼij½ºÆ® ±×·ì ÁּҷΠä¿öÁø´Ù.

IGMPv1¿¡¼­ Àü¼Û½Ã 0À¸·Î  ä¿ì°í ¼ö½Å½Ã  ¹«½ÃÇϱâ·Î ÇÏ¿´´ø  "Max Resp 
Time" Çʵå´Â "Membership  Query"¿¡¼­¸¸ Àǹ̰¡ ÀÖ´Ù. ÀÌ Çʵå´Â 
º¸°íÇØ¾ßÇÒ ÇÑ°è ½Ã°£À» ¼³Á¤Çϴµ¥  ¾²ÀδÙ. ¼º´ÉÀ» Á¶ÀýÇÏ´Â ¸ÞÄ¿´ÏÁòÀ¸·Î »ç¿ëÇÑ´Ù°í º¼ 
¼ö ÀÖ´Ù.

IGMPv2¿¡¼­ »õ·Î¿î  ¸Þ½ÃÁö ŸÀÔ  0x16ÀÌ Ãß°¡µÇ¾ú´Ù.   À̰ÍÀº "Version 2 
Membership Report"·Î¼­ IGMPv2 È£½ºÆ®°¡ IGMPv2  ¶ó¿ìÅ͸¦ ¹ß°ßÇßÀ»  ¶§ 
Àü¼ÛÇÑ´Ù. (IGMPv2  È£½ºÆ®´Â "Max Response" Çʵ尡 0 À¸·Î ä¿öÁø ÆÐŶÀ» 
È®ÀÎÇÏ¿© IGMPv1 ¶ó¿ìÅͰ¡ Á¸ÀçÇÑ´Ù´Â °ÍÀ» ¾Ë¾Æ³½´Ù).

µ¿½Ã¿¡ ¿©·¯ ¶ó¿ìÅͰ¡ ÁúÀǸ¦ ÇÒ ¶§, IGMPv2  ´Â "discussions"¸¦ ȸÇÇÇÏ´Â 
¸ÞÄ¿´ÏÁòÀ» Á¦°øÇÑ´Ù. ÀÌ °æ¿ì ³·Àº IP ÁÖ¼Ò¸¦ °¡Áø ¶ó¿ìÅͰ¡ ÁúÀÇÀÚ(querier)°¡ µÇ°í ´Ù¸¥ 
¶ó¿ìÅʹ ŸÀ̸Ӹ¦ ¼³Á¤ÇÑ´Ù. ³·Àº ¹øÈ£ÀÇ ¶ó¿ìÅͰ¡ ¾î¶² ÀÌÀ¯·Î Á¦´ë·Î ÀÛµ¿ÇÏÁö ¸øÇϸé 
ŸÀ̸Ӱ¡ ¸¸·áµÈ ÈÄ ´Ù½Ã ÁúÀÇÀÚ¸¦ ¼³Á¤ÇÑ´Ù.

<sect1>Ä¿³Î °ü·Ã »çÇ×<p>
ÀÌ Àý¿¡¼­´Â ¸®´ª½º Ä¿³Î¿¡¼­ ¸ÖƼij½ºÆ®  ±¸ÇöÀ» ÇнÀÇϱâ À§ÇÑ ½Ç¸¶¸®¸¦  º¸¿©ÁÙ °ÍÀÌ´Ù. 
±¸Çö ÀÚü¸¦ ¼³¸íÇÏÁö´Â ¾Ê´Â´Ù. ´ÜÁö ¾îµð¼­ ãÀ» °ÍÀÎÁö¸¸ ¾Ë·ÁÁÖ´Ù.

ÀÌ ³»¿ëÀº 2.0.32¿¡¼­ÀÇ ¼³¸íÀ̹ǷΠÀÌ  ±ÛÀ» Àд ½ÃÁ¡¿¡¼­ Á» ¿À·¡µÈ  ³»¿ëÀÏÁöµµ ¸ð¸¥´Ù. 
(³×Æ®¿÷ ÄÚµå´Â 2.1.x¿¡¼­ ¸¹ÀÌ º¯°æµÇ¾ú´Ù.

¸®´ª½º Ä¿³Î¿¡¼­  ¸ÖƼij½ºÆ® ÄÚµå´Â  Ç×»ó #ifdef    CONFIG_IP_MULTICAST / #endif 
½ÖÀ¸·Î µÑ·¯½Î¿© Àֱ⠶§¹®¿¡ ÇÊ¿äÇÏ´Ù¸é ¾ðÁ¦µçÁö Ä¿³Î¿¡ 
Æ÷ÇÔ(inclusion/exclusion)½ÃŰ°Å³ª  ¹èÁ¦½Ãų ¼ö ÀÖ´Ù. (ÀÌ Æ÷ÇÔ/¹èÁ¦´Â ÄÄÆÄÀÏ ½Ã¿¡ 
ÇàÇØÁö¸ç  #ifdef ±¸¹®Àº ¼±Çà󸮱Ⱑ ÇÏ´Â ÀÛ¾÷À̶ó´Â °ÍÀ» ¾Ë°í ÀÖÀ» °ÍÀÌ´Ù. Æ÷ÇÔ¿©ºÎ 
°áÁ¤Àºmake config, make menuconfig ¶Ç´Â make xconfig¸¦ ½ÇÇà½Ãų ¶§ ÇÒ ¼ö ÀÖ´Ù.)

¸ÖƼij½ºÆ® ¶ó¿ìÅÍ ±â´ÉÀ» »ç¿ëÇÏ°í ½Í´Ù¸é #ifdef CONFIG_IP_MROUTE / #endif½Ö ¼ÓÀÇ 
ÄÚµåµéÀ» Ȱ¼ºÈ­ ½ÃÄÑ¾ß ÇÑ´Ù.

Ä¿³Î ¼Ò½º´Â º¸Åë /usr/src/linux¿¡ ÀÖ´Ù. ÇÏÁö¸¸ À§Ä¡´Â º¯ÇÒ ¼öµµ ÀÖ´Â °ÍÀ̱⠶§¹®¿¡ 
Ä¿³Î ¼Ò½ºÀÇ À§Ä¡¸¦ °£´Ü ¸í·áÇÏ°Ô LINUX¶ó°í   °¡Á¤ÇÏÀÚ.  ÀÌÁ¦   Ä¿³Î¼Ò½º¸¦   
/usr/src/linux   ¿¡  Ç®¾úÀ»   °æ¿ì, LINUX/net/ipv4/udp.c ´Â  
/usr/src/linux/net/ipv4/udp.c ¸¦ ÀǹÌÇÑ´Ù.

»ç¿ëÀÚ ÇÁ·Î±×·¥¿¡¼­ÀÇ ¸ÖƼij½ºÆ® ÀÎÅÍÆäÀ̽º´Â ¸ÖƼij½ºÆ® ÇÁ·Î±×·¡¹ÖÀ»  ¼³¸íÇÑ Àý¿¡¼­ 
setsockopt()/ getsockopt()¸¦ ÅëÇØ  ¸ðµÎ º¸¿© ÁÖ¾ú´Ù. ÀÌ µÎ ÇÔ¼ö´Â Àü´Þ¹ÞÀº º¯¼öÀÇ 
À¯È¿¼ºÀ» °Ë»çÇÑ ´ÙÀ½, ´Ù¸¥ ¸î °¡Áö ÇÔ¼ö¸¦ È£ÃâÇÏ¿© Ãß°¡ ÀûÀ¸·Î °Ë»çÇϰí, ¶Ç ´Ù¸¥ 
ÇÔ¼ö¸¦ È£ÃâÇÏ´Â ½ÄÀ¸·Î ±¸ÇöµÇ¾ú´Ù. (ÀÌ ¸ðµç ÇÔ¼ö È£Ãâ¿¡ °ü½ÉÀÌ ÀÖ´Ù¸é 
LINUX/net/socket.c (ÇÔ¼ö sys_socketcall() ¿Í sys_setsockopt()), LINUX/net/ipv4/af_inet.c 
(ÇÔ¼ö inet_setsockopt()) ±×¸®°í LINUX/net/ipv4/ip_sockglue.c (ÇÔ¼ö ip_setsockopt()) ¸¦ 
ÂüÁ¶Ç϶ó.)

LINUX/net/ipv4/ip_sockglue.cµµ   ÁÖÀÇ   ±í°Ô   º¸¾Æ¾ß  ÇÑ´Ù.   ¿©±â¿¡´Â   ÇÔ¼ö 
ip_setsockopt() ¿Í ip_getsockopt() °¡ µé¾î Àִµ¥ ´ëºÎºÐÀº (¾î¶² ¿¡·¯ üũ  ÈÄ¿¡) 
°¡´ÉÇÑ optnameÀ» °Ë»çÇÏ´Â  ½ºÀ§Ä¡°°Àº °ÍÀÌ´Ù. À¯´Ïij½ºÆ® ¿É¼Ç°ú ÇÔ²²,   
IP_MULTICAST_TTL, IP_MULTICAST_LOOP,    IP_MULTICAST_IF,     
IP_ADD_MEMBERSHIP, IP_DROP_MEMBERSHIP°°Àº ¸ðµç ¸ÖƼij½ºÆ® ¿É¼ÇÀ» ó¸®ÇÑ´Ù. 
ÀÌ ½ºÀ§Ä¡ ÀÌÀü¿¡ ¿É¼ÇÀ» °Ë»çÇÏ¿© ±×°ÍÀÌ ¸ÖƼij½ºÆ® ¶ó¿ìÅÍ ÁöÁ¤ ¿É¼ÇÀ̶ó¸é  ÇÔ¼ö 
ip_mroute_setsockopt() ¿Í  ip_mroute_getsockopt() ·Î ¶ó¿ìÆÃ µÈ´Ù. (ÆÄÀÏ 
LINUX/net/ipv4/ipmr.c ¿¡ ÀÖÀ½).

LINUX/net/ipv4/af_inet.c ¿¡¼­ ÀÌÀü Àý¿¡¼­ ³íÀÇÇß´ø  ¼ÒÄÏ »ý¼º ±âº» °ªÀ» º¼  ¼ö ÀÖ´Ù. 
(loopback enabled, TTL=1, ÇÔ¼ö inet_create() Áß¿¡¼­)

<code>
  #ifdef CONFIG_IP_MULTICAST
          sk->ip_mc_loop=1;
          sk->ip_mc_ttl=1;
          *sk->ip_mc_name=0;
          sk->ip_mc_list=NULL;
  #endif
</code>

´ÙÀ½ Äڵ尡 "¼ÒÄÏÀ» ´ÝÀ¸¸é Ä¿³ÎÀº ÀÌ ¼ÒÄÏ¿¡ ÀÖ´ø ¸ðµç ȸ¿øÀ»  Å»Åð½ÃŲ´Ù"´Â ³»¿ëÀ» 
´ÜÁ¤ÀûÀ¸·Î º¸¿©ÁØ´Ù. (À§¿Í µ¿ÀÏ ÆÄÀÏÀÇ ÇÔ¼ö inet_release()¿¡¼­)

<code>
  #ifdef CONFIG_IP_MULTICAST
                  /* Applications forget to leave groups before exiting */
                  ip_mc_drop_socket(sk);
  #endif
</code>

¸µÅ©   °èÃþÀÇ(Link  Layer)ÀÇ   ÀåÄ¡  µ¶¸³ÀûÀÎ(Device   independent)   ¿¬»êµéÀº   
LINUX/net/core/dev_mcast.c ¿¡ ÀÖ´Ù.

¾ÆÁ÷ µÎ °¡Áö Áß¿äÇÑ ÇÔ¼öµéÀ» ¼³¸íÇÏÁö ¾Ê¾Ò´Ù. ÀÔ·Â  ó¸® ÇÔ¼ö¿Í ¸ÖƼij½ºÆ® µ¥ÀÌÅͱ׷¥ 
Ãâ·Â ÇÔ¼öÀÌ´Ù. ´Ù¸¥   µ¥ÀÌÅͱ׷¥µé°ú  ¸¶Âù°¡Áö·Î   ÀÔ·Â  µ¥ÀÌÅͱ׷¥Àº   ÀåÄ¡  
µå¶óÀ̹ö·ÎºÎÅÍ ip_rcv() ÇÕ¼ö(LINUX/net/ipv4/ip_input.c)·Î Àü´ÞµÈ´Ù. ÀÌ ÇÔ¼ö¿¡¼­ ÇÏÀ§ 
°èÃþÀ¸·ÎºÎÅÍ ÀüÇØÁø ¸ÖƼij½ºÆ® ÆÐŶÀ» ¿Ïº®ÇÏ°Ô ÇÊÅ͸µÇÑ´Ù(ÇÏÀ§·¹À̾¼­ ÃÖ´ëÇÑ 
ÇÊÅ͸µÇÏÁö¸¸, IP °èÃþ¿¡¼­ ¿ì¸®°¡ °ü½ÉÀ» °¡Áö°í ÀÖ´Â ±×·ì¿¡ ´ëÇØ 100% ¾Ë°í ÀÖ±â 
¶§¹®¿¡  ÆÐŶÀ» ¿ÏÀüÇÏ°Ô ÇÊÅ͸µÇÑ´Ù°í Çß´ø°ÍÀ» ±â¾ïÇÏÀÚ.) È£½ºÆ®°¡ ¸ÖƼij½ºÆ® ¶ó¿ìÅÍ·Î 
ÀÛµ¿ÁßÀ̶ó¸é ¿ª½Ã ÀÌ  ÇÔ¼ö°¡ ÆÐŶ Æ÷¿öµù ¿©ºÎ¸¦  °áÁ¤Çϰí ÀûÀýÇÏ°Ô ipmr_forward()¸¦ 
È£ÃâÇÑ´Ù. (ipmr_forward() Àº LINUX/net/ipv4/ipmr.c¿¡ ±¸ÇöµÇ¾î ÀÖ´Ù.).

ÆÐŶ Ãâ·Â ÀÓ¹«¸¦ ¸ÃÀº ÄÚµå´Â LINUX/net/ipv4/ip_output.c¿¡ ´ã°ÜÁ®  ÀÖ´Ù. À̰÷¿¡¼­ 
ÆÐŶÀ» ·çÇÁ¹é   ÇÒÁö ¾È  ÇÒÁö(¾ÈÇÑ´Ù¸é  ip_queue_xmit()È£Ãâ)  °Ë»çÇϱâ 
¶§¹®¿¡IP_MULTICAST_LOOP ¿É¼ÇÀÌ È¿·ÂÀ» ¹ßÈÖÇÏ´Â °÷ÀÌ´Ù. ¶ÇÇÑ, ¿ÜºÎ·Î ÇâÇÏ´Â 
ÆÐŶÀÌ ¸ÖƼij½ºÆ®ÀÎÁö À¯´Ïij½ºÆ®ÀÎÁö¿¡ ÀǰÅÇÏ¿© TTLÀ» Á¤ÇÏ´Â °÷À̱⵵ ÇÏ´Ù. ÀüÀÚÀÇ   
°Ü¿ì   IP_MULTICAST_TTL    ·Î   Àü´ÞµÈ   º¯¼ö¸¦   »ç¿ëÇÑ´Ù(ÇÔ¼ö ip_build_xmit()).

mrouted(Ä¿³Î¿¡ ¸ÖƼij½ºÆ® µ¥ÀÌÅͱ׷¥ ¶ó¿ìÆÃ ¹æ¹ýÀ» ¾Ë·ÁÁÖ´Â ÇÁ·Î±×·¥)·Î  ÀÛ¾÷ÇÏ´Â 
µ¿¾È, ¿ì¸®´Â ¸ÖƼij½ºÆ® ¶ó¿ìÅÍ·Î ÀÛµ¿ÇÏ´Â ¿ì¸®ÀÇ ¸®´ª½º ¹Ú½º¿¡¼­ ¸¸µé¾îÁø ÆÐŶÀ»  
Á¦¿ÜÇÑ, ·ÎÄà ³×Æ®¿÷¿¡¼­ »ý¼ºµÈ ¸ÖƼij½ºÆ® µ¥ÀÌÅͱ׷¥Àº ¸ðµÎ ÀûÀýÇÏ°Ô ¶ó¿ìÆÃµÇ´Â °ÍÀ»  
 ¹ß°ßÇß´Ù. ip_input.c   ´Â Á¦´ë·Î   ÀÛµ¿Çϰí ÀÖ´Â°Í   °°¾ÒÁö¸¸ ip_output.c ´Â ±×·¸Áö 
¾Ê¾Ò´Ù. Ãâ·Â ÇÁ·Î±×·¥ÀÇ ¼Ò½º Äڵ带 Àд µ¿¾È ¿ÜºÎ·Î ³ª°¡´Â µ¥ÀÌÅͱ׷¥µéÀÌ ¶ó¿ìÆÃ 
¿©ºÎ¸¦ °áÁ¤ÇÏ´Â  ÇÔ¼ö ipmr_forward()¸¦ °ÅÄ¡Áö ¾Ê´Â °ÍÀ» ¹ß°ßÇß´Ù. ÆÐŶµéÀº ·ÎÄà 
³×Æ®¿÷À¸·Î Ãâ·ÂµÇ¾úÁö¸¸ ³×Æ®¿÷ Ä«µå´Â ÀÚ½ÅÀÌ Àü¼ÛÇÏ´Â  µ¥ÀÌÅͱ׷¥À»  ÀÐÀ» ¼ö ¾ø¾ú°í, 
ÀÌ·± µ¥ÀÌÅͱ׷¥µéÀº ¶ó¿ìÆÃµÇÁö ¾Ê¾Ò´Ù. ¿ì¸®°¡  ip_build_xmit() ÇÔ¼ö¿¡ ÀûÀýÇÑ  Äڵ带 
Ãß°¡ÇÏÀÚ ¸ðµç °ÍÀÌ ¿Ã¹Ù·Î ÀÛµ¿ÇÏ¿´´Ù. (¼Ò½º ¼öÁ¤Àº »çÄ¡¸¦ ¶°´Â °Íµµ À¯½ÄÇÑôÇÏ´Â °Íµµ 
¾Æ´Ï´Ù; ÇÊ¿ä´Ù!)

ipmr_forward() ´Â ¼ö Â÷·Ê ¾ð±ÞÇß¾ú´Ù. ipmr_forward() ´Â ¿ì¸®°¡ ÈçÈ÷ À߸ø ÀÌÇØÇϰí 
ÀÖ´Â °ÍÀ» Ç®¾îÁÙ ¼ö Àֱ⠶§¹®¿¡ ¾ÆÁÖ Áß¿äÇÑ ÇÔ¼öÀÌ´Ù. ¸ÖƼij½ºÆ® Æ®·¡ÇÈÀ» ¶ó¿ìÆÃÇÒ ¶§, 
ÆÐŶ »çº»À»  ¸¸µé°í ±×°ÍÀ» ¿Ã¹Ù¸¥ ¼ö½ÅÀÚ¿¡°Ô Àü´ÞÇÏ´Â °ÍÀº mroutedÀÚü°¡ ¾Æ´Ï´Ù. 
mrouted´Â ¸ðµç ¸ÖƼij½ºÆ® Æ®·¡ÇÈÀ» ¼ö½ÅÇÏ¿©, ±×  Á¤º¸¿¡ ±Ù°ÅÇÏ¿© , ¸ÖƼij½ºÆ® ¶ó¿ìÆÃ 
Å×À̺íÀ» °è»êÇØ ³»°í Ä¿³Î¿¡ ¶ó¿ìÆÃ ¹æ¹ýÀ» ¾Ë·ÁÁØ´Ù. "ÀÌ ÀÎÅÍÆäÀ̽º¿¡¼­ µé¾î¿À´Â  
Àú ±×·ìÀÇ µ¥ÀÌÅͱ׷¥Àº Àú ÀÎÅÍÆäÀ̽º·Î º¸³»¶ó."

ÀÌ   ¶ó¿ìÆÃ  Á¤º¸´Â   mrouted   µ¥¸ó(raw  ¼ÒÄÏ   »ý¼º½Ã   Áö¾îµÈ  ÇÁ·ÎÅäÄÝÀº    
IPPROTO_IGMPÀ̾î¾ß ÇÑ´Ù.)ÀÌ ¸¸µç raw   ¼ÒÄÏ¿¡¼­   setsockopt()¸¦   È£ÃâÇÏ¿©    
Ä¿³Î¿¡   ¼³Á¤ÇÑ´Ù.   ÀÌ   ¿É¼ÇÀº LINUX/net/ipv4/ipmr.c ÀÇ  
ip_mroute_setsockopt()ÇÔ¼ö¿¡¼­ ó¸®ÇÑ´Ù. ¼ÒÄÏ¿¡¼­ ¹ßÇàÇÑ Ã¹¹øÂ° ¿É¼Ç(would be  better 
to call them commands rather than options)Àº MRT_INITÀ̾î¾ß ÇÑ´Ù. ù  ¹øÂ°  ¹ßÇàÇÑ  
¿É¼ÇÀÌ  MRT_INITÀÌ  ¾Æ´Ï¶ó¸é  ´Ù¸¥   ¸ðµç ¸í·ÉÀº   ¹«½ÃÇÑ´Ù. (-EACCES¸¦ ¹Ý³³) ÇÑ 
È£½ºÆ® »ó¿¡´Â mroutedÀÇ ÀνºÅϽº°¡ ²À Çϳª¸¸ Á¸ÀçÇÒ ¼ö ÀÖ´Ù. À̰ÍÀ» ÃßÀûÇϱâ À§ÇØ  ù 
¹øÂ° MRT_INIT À» ¹Þ¾ÒÀ»  ¶§ ±¸Á¶Ã¼ sock* mroute_socketÀÌ MRT_INIT À» ¼ö½ÅÇÑ 
¼ÒÄÏÀ» °¡¸®Å°°Ô µÈ´Ù. ¸¸ÀÏ MRT_INIT À» ¹ßÇàÇßÀ»¶§ mroute_socketÀÌ ³Î(null)°ªÀ» 
°¡ÁöÁö ¾Ê´Â´Ù¸é ÀÌ¹Ì ´Ù¸¥ mrouted°¡ ÀÛµ¿ÁßÀÓÀ» ÀǹÌÇϹǷΠ-EADDRINUSE À» 
¹Ý³³ÇÑ´Ù.               ³ª¸ÓÁö    ´Ù¸¥     ¸í·Éµé(MRT_DONE,    MRT_ADD_VIF,    
MRT_DEL_VIF, MRT_ADD_MFC, MRT_DEL_MFC and MRT_ASSERT)˼ 
mroute_socket°ú ´Ù¸¥ ¼ÒÄÏ¿¡¼­ ¿Ã °æ¿ì -EACCES ¸¦ ¹Ý³³ÇÑ´Ù. 

¶ó¿ìÆÃµÈ ¸ÖƼij½ºÆ® µ¥ÀÌÅͱ׷¥Àº ¹°¸®Àû ÀÎÅÍÆäÀ̽º ȤÀº  (°¡»óÀûÀÎ) ÅͳÎÀ» ÅëÇØ 
Àü¼ÛÇϱ⠶§¹®¿¡, ÀϹÝÀûÀÎ Ãß»óÈ­(abstraction) ´Ü°è¸¦ VIFs,  Áï, °¡»ó ÀÎÅÍÆäÀ̽º (Virtual 
InterFaces)°í¾ÈÇØ³Â´Ù. mrouted´Â ¹°¸® ȤÀº ÅͳΠÀÎÅÍÆäÀ̽º¸¦  °¡¸®Å°´Â vif ±¸Á¶Ã¼¸¦ 
¶ó¿ìÆÃ  Å×ÀÌºí¿¡ Ãß°¡Çϱâ À§ÇÏ¿© Ä¿³Î¿¡ ³Ñ°ÜÁÖ°í, µ¥ÀÌÅͱ׷¥À» ¾îµð·Î Æ÷¿öµùÇÒÁö 
¾Ë·ÁÁÖ´Â ¸ÖƼij½ºÆ® Æ÷¿öµù ¸ñ·Ï(multicast forwarding entries)¿¡µµ ¾Ë·ÁÁØ´Ù.

VIFs ´Â MRT_ADD_VIF ·Î Ãß°¡Çϰí MRT_DEL_VIF ·Î  »èÁ¦ÇÑ´Ù.µÎ ÇÔ¼ö ¸ðµÎ vifctl 
±¸Á¶Ã¼¸¦ Ä¿³Î·Î ³Ñ±ä´Ù.
( /usr/include/linux/mroute.h) ¿¡¼­ ´ÙÀ½°ú °°ÀÌ Á¤ÀÇÇϰí ÀÖ´Ù.

<code>
  struct vifctl {
          vifi_t  vifc_vifi;              /* Index of VIF */
          unsigned char vifc_flags;       /* VIFF_ flags */
          unsigned char vifc_threshold;   /* ttl limit */
          unsigned int vifc_rate_limit;   /* Rate limiter values (NI) */
          struct in_addr vifc_lcl_addr;   /* Our address */
          struct in_addr vifc_rmt_addr;   /* IPIP tunnel addr */
  };
</code>

ÀÌ Á¤º¸¸¦ ÅëÇØ vif_device ±¸Á¶Ã¼¸¦ ¸¸µç´Ù.

<code>
  struct vif_device
  {
          struct device   *dev;                   /* Device we are using */
          struct route    *rt_cache;              /* Tunnel route cache */
          unsigned long   bytes_in,bytes_out;
          unsigned long   pkt_in,pkt_out;         /* Statistics */
          unsigned long   rate_limit;             /* Traffic shaping (NI) */
          unsigned char   threshold;              /* TTL threshold */
          unsigned short  flags;                  /* Control flags */
          unsigned long   local,remote;           /* Addresses(remote for tunnels)*/
  };
</code>

ÀÌ      ±¸Á¶Ã¼¿¡¼­     dev      Ç׸ñÀ»     ÁÖ¸ñÇ϶ó.      device      ±¸Á¶Ã¼´Â 
/usr/include/linux/netdevice.h ¿¡¼­ Á¤ÀÇÇϰí ÀÖ´Ù. ¾ÆÁÖ Å« ±¸Á¶Ã¼ÀÌÁö¸¸ ¿ì¸®´Â ´ÙÀ½ 
Çʵ忡¸¸ °ü½ÉÀ» µÎ¸é µÈ´Ù.

struct ip_mc_list*    ip_mc_list;   /* IP multicast filter chain    */

ip_mc_list ±¸Á¶Ã¼´Â /usr/include/linux/igmp.h¿¡¼­ ´ÙÀ½°ú °°ÀÌ Á¤ÀÇÇϰí ÀÖ´Ù. :

<code>
  struct ip_mc_list
  {
          struct device *interface;
          unsigned long multiaddr;
          struct ip_mc_list *next;
          struct timer_list timer;
          short tm_running;
          short reporter;
          int users;
  };
</code>

dev ±¸Á¶Ã¼ÀÇ  ip_mc_list ´Â ip_mc_list Çü ±¸Á¶Ã¼ÀÇ  ¿¬°á¸®½ºÆ®¸¦ °¡¸®Å°´Â Æ÷ÀÎÅÍÀÌ´Ù. 
ip_mc_list ´Â ÇØ´ç ³×Æ®¿÷ ÀÎÅÍÆäÀ̽º°¡ ¸â¹ö·Î Âü¿©Çϰí ÀÖ´Â ¸ÖƼij½ºÆ® ±×·ìÀ» 
´ã°íÀÖ´Ù. ¿©±â¼­ ´Ù½Ã Çѹø, ȸ¿øÀº ÀÎÅÍÆäÀ̽º¿Í °ü°è°¡ ÀÖÀ½À» ¾Ë ¼ö ÀÖ´Ù. 
LINUX/net/ipv4/ip_input.c ´Â µ¥ÀÌÅͱ׷¥ÀÌ (µ¥ÀÌÅͱ׷¥À» ¼ö½ÅÇÑ ÀÎÅÍÆäÀ̽º°¡ ¼ÓÇÏ´Â 
±×·ì °¡¿îµ¥) ¾î¶² ±×·ì¿¡ ¼ÓÇÑ °ÍÀÎÁö °áÁ¤Çϱâ À§ÇØ ÀÌ ¿¬°á¸®½ºÆ®¸¦ ¼øÈ¸ÇÑ´Ù.

<code>
  #ifdef CONFIG_IP_MULTICAST
                  if(!(dev->flags&IFF_ALLMULTI) && brd==IS_MULTICAfST
                     && iph->daddr!=IGMP_ALL_HOSTS
                     && !(dev->flags&IFF_LOOPBACK))
                  {
                          /*
                           *      Check it is for one of our groups
                           */
                          struct ip_mc_list *ip_mc=dev->ip_mc_list;
                          do
                          {
                                  if(ip_mc==NULL)
                                  {
                                          kfree_skb(skb, FREE_WRITE);
                                          return 0;
                                  }
                                  if(ip_mc->multiaddr==iph->daddr)
                                          break;
                                  ip_mc=ip_mc->next;
                          }
                          while(1);
                  }
  #endif
</code>

ip_mc_list±¸Á¶Ã¼¿¡¼­ users Çʵå´Â "IGMP ¹öÀü 1"¿¡¼­ ¼³¸íÇß´ø °ÍÀ» ±¸ÇöÇϱâ À§ÇØ 
»ç¿ëÇÑ´Ù. ÇÁ·Î¼¼½º°¡ ±×·ì¿¡ Âü¿© ÇÒ¶§, ÀÎÅÍÆäÀ̽º°¡ ÀÌ¹Ì  ±× ±×·ìÀÇ È¸¿øÀ̶ó¸é (´Ù½Ã 
¸»Çؼ­, µ¿ÀÏ ÀÎÅÍÆäÀ̽º·Î µ¿ÀÏ ±×·ì¿¡ Âü¿©ÇÑ ÇÁ·Î¼¼½º°¡ ÀÌ¹Ì ÀÖÀ¸¸é) ¸â¹ö ¼ö(users)¸¸ 
Áõ°¡½ÃŲ´Ù.  IGMP ¸Þ½ÃÁö¸¦ º¸³»Áö ¾ÊÀ½À», ´ÙÀ½ Äڵ忡¼­ º¼ ¼ö ÀÖ´Ù. 
(ip_mc_inc_group()      ¿¡¼­       °¡Á®¿ÔÀ¸¸ç,      ip_mc_join_group()       ¿Í 
LINUX/net/ipv4/igmp.c¿¡¼­ È£ÃâÇÑ´Ù.)

<code>
          for(i=dev->ip_mc_list;i!=NULL;i=i->next)
          {
                  if(i->multiaddr==addr)
                  {
                          i->users++;
                          return;
                  }
          }
</code>

¸â¹ö°¡ Å»ÅðÇÒ ¶§ Ä«¿îÅ͸¦ °¨¼ÒÇϸç, Ä«¿îÅͰ¡ 0¿¡  ´Ù´Ù¶úÀ» ¶§¿¡¸¸ ºÎ°¡ÀûÀÎ ÀÛ¾÷À» 
¼öÇàÇÑ´Ù. (ip_mc_dec_group()).

MRT_ADD_MFC ¿Í MRT_DEL_MFC ´Â  ¸ÖƼij½ºÆ® ¶ó¿ìÆÃ Å×ÀÌºí¿¡¼­  Æ÷¿öµù Ç׸ñÀ» 
¼ºÁ¤Çϰųª »èÁ¦ÇÑ´Ù. µÑ    ´Ù    mfcctl    ±¸Á¶Ã¼¸¦    ´ÙÀ½     Á¤º¸¿Í    ÇÔ²²    
Ä¿³Î·Î    ³Ñ±ä´Ù. (/usr/include/linux/mroute.h ¿¡¼­ Á¤ÀÇ)

<code>
  struct mfcctl
  {
          struct in_addr mfcc_origin;             /* Origin of mcast      */
          struct in_addr mfcc_mcastgrp;           /* Group in question    */
          vifi_t  mfcc_parent;                    /* Where it arrived     */
          unsigned char mfcc_ttls[MAXVIFS];       /* Where it is going    */
  };
</code>

ÀÌ»óÀÇ Á¤º¸¸¦ °¡Áö°í, ipmr_forward() ´Â  VIFs¸¦ "µ¹¾Æ´Ù´Ñ´Ù". ±×¸®°í ÀÏÄ¡ÇÏ´Â Æ÷¿öµù 
Ç׸ñÀ» ¹ß°ßÇÏ¸é µ¥ÀÌÅͱ׷¥À» º¹»çÇÏ¿© ipmr_queue_xmit()À» È£ÃâÇÑ´Ù. ±×·¯¸é, 
ipmr_queue_xmit() Àº ÆÐŶÀ» ÅͳÎÀ» ÅëÇØ º¸³¾ °æ¿ì ¶ó¿ìÆÃ Å×ÀÌºí¿¡ ¸í½Ã µÃ Ãâ·ÂÀåÄ¡¿Í 
¸ñÀûÁö ÁÖ¼Ò¸¦ ÀÌ¿ëÇØ  Àü¼ÛÇÑ´Ù. (Áï, ¹Ý´ëÆí ÅͳΠÁ¾´ÜÀÇ À¯´Ïij½ºÆ® ÁÖ¼Ò) ÇÔ¼ö 
ip_rt_event() ´Â(Ãâ·Â°ú Á÷Á¢ÀûÀÎ  °ü·ÃÀº ¾øÁö¸¸ ip_output.c ¿¡  µé¾î ÀÖ´Ù.) ÀåÄ¡ Ȱ¼ºÈ­ 
¸Þ½ÃÁö °°Àº ³×Æ®¿÷ ÀåÄ¡ °ü·ÃµÈ À̺¥Æ®(event)¸¦ ¹Þ´Â´Ù. ÀÌ ÇÔ¼ö´Â ÀåÄ¡°¡ Àüü È£½ºÆ® 
±×·ì¿¡ Âü¿©ÇÏ´Â °ÍÀ» º¸ÁõÇÑ´Ù.

IGMP ÇÔ¼öµéÀº LINUX/net/ipv4/igmp.c ¿¡¼­ ±¸ÇöÇÑ´Ù.  ÀÌ ÇÔ¼öµé¿¡ °üÇÑ Áß¿äÇÑ Á¤º¸´Â 
/usr/include/linux/igmp.h ¿Í /usr/include/linux/mroute.h  ¿¡   ÀÖ´Ù.  /proc/net   ÀÇ  
IGMP   °ü·Ã  Ç׸ñÀº LINUX/net/ipv4/ip_output.c¿¡ ÀÖ´Â ip_init() ¿¡¼­ ¸¸µç´Ù.

<sect>¶ó¿ìÆÃ Á¤Ã¥°ú Æ÷¿öµù ±â¼ú<p>
º°·Î ÁÁÁö ¾ÊÀº ¾Ë°í¸®ÁòÀº ¸ÖƼij½ºÆ® µ¥ÀÌÅÍ ¼ö½Å ÀÇ»ç¿Í »ó°ü¾øÀÌ Àü ¼¼°è·Î Æ®·¡ÇÈÀ» 
³»º¸³½´Ù. ÀÌ·± ÃÖÀûÈ­ µÇÁö ¾ÊÀº ¾Ë°í¸®ÁòÀ» ´ë½ÅÇÒ ¸î °¡Áö Æ÷¿öµù ±â¼ú°ú ¶ó¿ìÆÃ 
¾Ë°í¸®ÁòÀÌ °³¹ßµÇ¾ú´Ù.

°Å¸® º¤ÅÍ   ¸ÖƼij½ºÆ® ¶ó¿ìÆÃ  ÇÁ·ÎÅäÄÝ DVMRP   (Distance Vector  Multicast 
Routing Protocol) ´Â ¾Æ¸¶µµ ¿À´Ã³¯ ¸ÖƼij½ºÆ® ¶ó¿ìÅÍ ´ëºÎºÐÀÌ »ç¿ëÇϰí ÀÖ´Â  
¾Ë°í¸®ÁòÀÏ °ÍÀÌ´Ù. À̰ÍÀº °í¹ÐµµÇü(dense mode) ¶ó¿ìÆÃ ÇÁ·ÎÅäÄÝ, Áï, ³ôÀº ´ë¿ªÆø¿¡ 
¸â¹öµéÀÌ °í¹Ðµµ·Î ºÐ»êµÇ¾îÀÖ´Â  Àִ ȯ°æ¿¡¼­ Àß ÀÛµ¿ÇÑ´Ù. ÇÏÁö¸¸, ¸â¹öµéÀÌ ³·Àº 
¹Ðµµ·Î Èð¾îÁ®ÀÖ´Â °æ¿ì ¹®Á¦(scalability problem)°¡ ÀÖ´Ù.

DVMRP °°Àº °í¹ÐµµÇü ¶ó¿ìÆÃ ÇÁ·ÎÅäÄÝ·Î ¸ÖƼij½ºÆ® È®ÀåÇü ÃִܰŸ® ¿ì¼± ÇÁ·ÎÅäÄÝ 
MOSPF (Multicast Extensions to OSPF -Open Shortest Path First-)
, ÇÁ·ÎÅäÄÝ µ¶¸³Çü  °íÁýÀû ¸ÖƼij½ºÆ® PIM-DM  (Protocol-Independent Multicast Dense 
Mode) ±×¸®°í Á᫐ ±â¹Ý Æ®¸® CBT (Core Based Trees) °¡ ÀÖ´Ù.

OSPF ¹öÀü 2 ´Â RFC 1583 , MOSPF ´Â RFC  1584 , PIM-SM °ú CBT ´Â °¢°¢ RFC 
2117 °ú 2201 ÀÌ ±Ô°ÝÀ» ¸í½ÃÇϰí ÀÖ´Ù.

ÀÌ ¸ðµç   ¶ó¿ìÆÃ ÇÁ·ÎÅäÄݵéÀº   flooding, Reverse   Path Broadcasting   (RPB), 
Truncated Reverse Path
Broadcasting (TRPB), Reverse Path Multicasting  (RPM) or Shared Trees  °°Àº 
¸ÖƼij½ºÆ® Æ÷¿öµù ±â¼úÀ» »ç¿ëÇÑ´Ù.

³»¿ëÀÌ ³Ê¹« ±æ¾îÁö¹Ç·Î ÀÌ ¸ðµç °ÍµéÀ» ¿©±â¼­ ¼³¸íÇÏÁö´Â ¾Ê°Ú´Ù. À̰͵鿡 ´ëÇÑ ÇØ¼³Àº 
½±°Ô ã¾Æº¼ ¼ö ÀÖÀ» °ÍÀÌ´Ù. draft-ietf-mboned-in.txt ¹®¼­¸¦ ÀÐ¾î  º¼ °ÍÀ» ±ÇÇÑ´Ù. À§ÀÇ 
RFC µéÀÌ ÀÖ´Â °÷¿¡ °°ÀÌ ÀÖÀ» °ÍÀ̸ç, »ó±âÇÑ ±â¼ú°ú Á¤Ã¥µé¿¡ ´ëÇÑ ¾à°£ ÀÚ¼¼ÇÑ ³»¿ëÀ» 
´ã°íÀÖ´Ù.

<sect>¸ÖƼij½ºÆ® Æ®·£½ºÆ÷Æ® ÇÁ·ÎÅäÄÝ<p>

Áö±Ý±îÁö UDP¸¦ ÀÌ¿ëÇÑ ¸ÖƼij½ºÆ® Àü¼Û¿¡ ´ëÇØ ¾Ë¾Æº¸¾Ò´Ù. TCP¿¡¼­´Â ºÒ°¡´ÉÇϱâ 
¶§¹®¿¡ ÀÌ»óÀÌ ÀϹÝÀûÀÎ ³»¿ëÀÌ´Ù. ±×·¸Áö¸¸, Á»´õ »õ·Î¿î ¸ÖƼij½ºÆ®  Æ®·£½ºÆ÷Æ® 
ÇÁ·ÎÅäÄÝ (Multicast Transport Protocols) À» ¸¸µé¾î³»±â  À§ÇØ Áö³­ ¸î ³â°£ ÁýÁßÀûÀÎ 
¿¬±¸°¡ °è¼ÓµÇ°í ÀÖ´Ù.

»õ·Î °³¹ßµÈ ÇÁ·ÎÅäÄÝ °¡¿îµ¥ ¸î °¡Áö´Â ±¸Çö ´Ü°è¸¦ °ÅÃÄ Å×½ºÆ® ´Ü°è±îÁö À̸£°í ÀÖ´Ù. 
¸ðµç ÇüÅÂÀÇ ÀÀ¿ë¿¡ ÀûÇÕÇÑ ÀϹÝÀûÀÎ ¸ÖƼij½ºÆ® Æ®·£½ºÆ÷Æ® ÇÁ·ÎÅäÄÝÀº Á¸ÀçÇÏÁö ¾Ê´Â´Ù´Â 
°ÍÀÌ, ¿¬±¸¸¦ ÅëÇØ ¹àÇôÁö´Â °Í °°´Ù.

¾ÆÁÖ º¹ÀâÇϰí Á¶Á¤Çϱ⠾î·Á¿î ÇÁ·ÎÅäÄÝ¿¡¼­ ´ÙÀ½°ú  °°Àº ¹®Á¦µéÀ» »ý°¢ÇØ º¸ÀÚ. 
Áö¿¬(¸ÖƼ¹Ìµð¾î ȸÀÇ¿¡¼­), ÀÚ·á ¼Õ½Ç, ÆÐŶ Á¤·Ä(ordering), ÀçÀü¼Û, È帧 ¹× È¥Àâµµ Á¶Á¤, 
±×·ì °ü¸® µî.....°Ô´Ù°¡ ¼ö½ÅÀÚ°¡ Çϳª°¡ ¾Æ´Ï¶ó ¼ö¹é ¼öõ °³ÀÇ Àú¹Ðµµ ºÐ»ê 
È£½ºÆ®µéÀ̶ó¸é...ÀÌ·± °æ¿ì¿¡ Á¶Á¤¿¡ Å« °ï¶õÀ» °ÞÀ» °ÍÀÌ´Ù. µû¶ó¼­, ¼ö½ÅÇÑ ¸ðµç ÆÐŶ¿¡ 
´ëÇØ ¼ö½Å È®ÀÎ(ACKs)À» º¸³»´Â ´ë½Å, ¼ö½ÅÇÏÁö ¸øÇÑ ÆÐŶ¿¡ ´ëÇØ¼­¸¸ ¼ö½Å ºÒ·® 
½ÅÈ£(NACKs)¸¦ º¸³»´Â ½ÄÀÇ ¾Ë°í¸®ÁòÀ»  °³¹ßÇÑ´Ù. RFC 1458 ÀÌ ¸ÖƼij½ºÆ® ÇÁ·ÎÅäÄÝ 
¿ä±¸»çÇ×À» Á¦¾ÈÇϰí ÀÖ´Ù.

¸ÖƼij½ºÆ® ÇÁ·ÎÅäÄÝ¿¡ ´ëÇÑ ÀÚ¼¼ÇÑ ÇØ¼³Àº ¹®¼­ÀÇ ¹üÀ§¸¦ ³Ñ±â ¶§¹®¿¡ ´õ ÀÌ»ó ¼³¸íÇÏÁö 
¾ÊÀ» °ÍÀÌÁö¸¸, ´ë½Å, ÇÁ·ÎÅäÄÝ À̸§°ú ÀڷḦ ã¾Æ º¼ ¼ö ÀÖ´Â ¿äÁ¡¸¸ ¤°í ³Ñ¾î°¡µµ·Ï 
ÇϰڴÙ. Real-Time Transport Protocol  (RTP) Àº ºÐ»êÇü ¸ÖƼ¹Ìµð¾î ȸÀÇ(multi-partite 
multimedia conferences)¿Í °ü·Ã ÀÖÀ¸¸ç, Scalable Reliable Multicast (SRM) Àº wb (the 
distributed White-Board tool,  see section ``Multicast applications'')°¡ »ç¿ëÇÑ´Ù. Uniform 
Reliable  Group Communication Protocol (URGC) Àº Áß¾Ó ÁýÁᫎ Á¦¾î¿¡¼­ ÀÚ·á 
ó¸®(transaction) °¡ ½Å·ÚÀûÀ̸ç Á¤¿¬È÷ ÀÌ·ç¾îÁú ¼ö ÀÖµµ·Ï µµ¿ÍÁØ´Ù. Muse ´Â MBone 
¿¡¼­ ´º½º¸¦ Àü¼ÛÇÒ ¼ö ÀÖµµ·Ï ƯÁ¤ ÇÁ·Î±×·¥¿ëÀ¸·Î °í¾ÈµÈ °ÍÀ̸ç, Multicast File 
Transfer Protocol (MFTP) Àº ¹®ÀÚ ±×´ë·Î ÆÄÀÏ  Àü¼Û°úÁ¤  ȸÀÇ¿¡  Âü¿©ÇϵíÀÌ  Âü¿©  
ÇÒ¼ö  ÀÖµµ·Ï  ÇØÁÖ´Â   ÇÁ·ÎÅäÄÝÀÌ´Ù. Log-Based Receiver-reliable Multicast (LBRM) Àº 
±â·Ï ¼­¹ö(logging server) ·Î º¸³»Áö´Â ¸ðµç ÆÐŶÀ» ÃßÀûÇÏ¿© Àü¼ÛÃø¿¡ µ¥ÀÌÅ͸¦ ´Ù½Ã 
Àü¼ÛÇØ¾ßÇÏ´ÂÁö ¾Æ´Ï¸é ÀÌ»ó ¾øÀÌ ¼ö½ÅµÇ¾ú´ÂÁö ¾Ë·ÁÁִ ƯÀÌÇÑ ÇÁ·ÎÅäÄÝÀÌ´Ù. ¶Ç ÇѰ¡Áö, 
¸ÖƼij½ºÆ®  ÇÁ·ÎÅäÄÝÀ̸鼭 STORM (STructure-Oriented Resilient Multicast)À̶ó´Â 
Àç¹ÌÀÖ´Â À̸§À» °¡Áø ÇÁ·ÎÅäÄݵµ ÀÖ´Ù. À¥À» ã¾Æº¸¸é ÀÌ ¿Ü¿¡´Ù ¸¹Àº ¸ÖƼij½ºÆ® 
ÇÁ·ÎÅäÄÝÀÌ ÀÖÀ¸¸ç ¸ÖƼij½ºÆ®¸¦ ÀÌ¿ëÇØ »õ·Î¿î ÀϵéÀ» ¹úÀÌ·Á´Â  Àç¹ÌÀÖ´Â ³»¿ëÀÇ ±Ûµéµµ 
¸¹´Ù.(¿¹¸¦ µé¾î, ¸ÖƼij½ºÆ®¸¦ ÀÌ¿ëÇÑ À¥ ÆäÀÌÁö ÀÚµ¿ Àü¼Û °°Àº °Í)

¸ÖƼij½ºÆ® ÇÁ·ÎÅäÄݰ£ÀÇ ½Å·Ú¼ººñ±³´Â
<url url="http://www.tascnets.com/mist/doc/mcpCompare.html">À» Âü°íÇ϶ó.

¸ÖƼij½ºÆ®¿Í °ü·ÃÇÑ Èï¹Ì·Î¿î ¸µÅ©µé°ú ÃֽŠÁ¤º¸(ÀÎÅÍ³Ý ÃʾÈ, RFC, ³í¹®, ¸µÅ©)°¡ 
°¡µæÇÑ ¾ÆÁÖ ÁÁÀº »çÀÌÆ®´Ù.
<url url="http://research.ivv.nasa.gov/RMP/links.html">

¿©±âµµ ÁÁÀº Á¤º¸°¡ ¸¹´Ù. <url url="http://hill.lut.ac.uk/DS-Archive/MTP.html">

Katia ObraczkaÀÇ "Multicast Transport Protocols: A Survey and Taxonomy" 
¶ó´Â ±ÛÀº °¢ ÇÁ·ÎÅäÄÝ¿¡ ´ëÇÑ °£´ÜÇÑ ¼³¸íÀ» ÇÏ°í ±â´É»ó  Â÷ÀÌÁ¡À¸·Î ºÐ·ùÇϰí ÀÖ´Ù. ÀÌ 
±ÛÀº IEEE Communications magazine, January 1998, vol. 36, No. 1. ¿¡µµ ½Ç·ÁÀÖ´Ù.

<sect>Âü°í ÀÚ·á<p>
<sect1>RFC ¹®¼­<p>
<itemize>
<item>RFC 1112 "Host Extensions for IP Multicasting".  Steve Deering. August 
1989.
<item>RFC 2236 "Internet  Group Management Protocol,  version 2". W.Fenner.   
November 1997.
<item>RFC 1458   "Requirements for   Multicast Protocols".   Braudes, R  and   
Zabele, S.  May 1993.
<item>RFC 1469  "IP Multicast  over Token-Ring  Local Area   Networks". T. 
Pusateri.  June 1993.
<item>RFC 1390 "Transmission of IP and ARP over FDDI Networks". D. Katz.  
January 1993.
<item>RFC 1583 "OSPF Version 2". John Moy. March 1994.
<item>RFC 1584 "Multicast Extensions to OSPF". John Moy. March 1994.
<item>RFC 1585 "MOSPF: Analysis and Experience". John Moy. March 1994.
<item>RFC 1812 "Requirements for IP  version 4 Routers". Fred  Baker, Editor. 
June 1995
<item>RFC 2117 "Protocol Independent Multicast-Sparse Mode (PIM-SM):
 Protocol Specification". D. Estrin, D. Farinacci, A. Helmy, D.
 Thaler; S. Deering, M. Handley, V. Jacobson, C. Liu,  P. Sharma, and L. Wei. July 
1997.
<item>RFC 2189 "Core Based Trees  (CBT version 2) Multicast  Routing".  A. 
Ballardie. September 1997.
RFC 2201  "Core Based   Trees (CBT) Multicast   Routing Architecture". A.  Ballardie. 
September 1997.
</itemize>

<sect1>ÀÎÅÍ³Ý ÃʾÈ(draft)<p>
<itemize>
<item>"Introduction   to   IP   Multicast   Routing".   draft-ietf-mboned-intro- 
multicast- 03.txt. T. Maufer, C. Semeria. July 1997.
<item>"Administratively    Scoped    IP    Multicast". 
draft-ietf-mboned-admin-ip-space-03.txt. D. Meyer. June 10, 1997.
</itemize>

<sect1>À¥ ÆäÀÌÁö<p>
<itemize>
<item>Linux      Multicast      Homepage.      <url 
url="http://www.cs.virginia.edu/~mke2e/multicast.html">
<item>Linux    Multicast     FAQ.    <url 
url="http://andrew.triumf.ca/pub/linux/multicast-FAQ">
<item>Multicast    and    MBONE    on    Linux.<url 
url="http://www.teksouth.com/linux/multicast/">
<item>Christian   Daudt's   MBONE-Linux    Page. <url 
url="http://www.microplex.com/~csd/linux/mbone.html">
<item>Reliable     Multicast     Links   <url 
url="http://research.ivv.nasa.gov/RMP/links.html">
<item>Multicast    Transport     Protocols  <url 
url="http://hill.lut.ac.uk/DS-Archive/MTP.html">
</itemize>

<sect1>Âü°í ¼­Àû<p>
<itemize>
<item>"TCP/IP Illustrated: Volume 1 The Protocols". Stevens, W. Richard.
     Addison Wesley Publishing Company, Reading MA, 1994
<item>"TCP/IP Illustrated: Volume 2, The Implementation". Wright, Gary
     and W. Richard Stevens. Addison Wesley Publishing Company, Reading MA, 1995
<item>"UNIX Network Programming Volume 1. Networking APIs: Sockets and
     XTI". Stevens, W. Richard. Second Edition, Prentice Hall, Inc. 1998.
<item>"Internetworking with TCP/IP Volume 1 Principles, Protocols, and
     Architecture". Comer, Douglas E. Second Edition, Prentice Hall,
     Inc.  Englewood Cliffs, New Jersey, 1991
</itemize>

<sect>ÀúÀ۱ǰú Ã¥ÀÓ ÇÑ°è °íÁö<p>
Copyright 1998 Juan-Mariano de Goyeneche.

ÀÌ ÇÏ¿ìÅõ ¹®¼­´Â Free Software Foundation¿¡¼­ ¼±¾ðÇÑ
GNU General Public License ¹öÀü 2 ¶Ç´Â, ÃֽйöÀüÀÇ License¿¡ µû¶ó ÀÚÀ¯·Ó°Ô Àç ¹èÆ÷ÇÒ
¼ö ÀÖÀ¸¸ç ¼öÁ¤ÇÒ ¼ö ÀÖ´Ù.

ÀÌ ¹®¼­°¡ ¿©·¯¹®¿¡°Ô µµ¿òÀÌ µÇ±â¸¦ ¿øÇÏ´Â Àǵµ¿¡¼­ ¹èÆ÷ ÇÏ¿´Áö¸¸. ¾î¶°ÇÑ º¸Áõµµ ÇÏÁö
¾Ê´Â´Ù.ÀÚ¼¼ÇÑ »çÇ×Àº GNU General Public License¸¦ Âü°í Ç϶ó.


GNU General Public License´Â ¾Æ·¡ ÁÖ¼Ò·Î ÆíÁö¸¦ º¸³»¸é ¾òÀ» ¼ö ÀÖ´Ù.

The Free Software Foundation, 
59 Temple Place -  Suite 330, Boston, MA 02111-1307, USA 

ÀÌ ¹®¼­¸¦ CD-ROMÀ̳ª ´Ù¸¥ ¸Åü¿¡ ¼ö·ÏÇÏ¿© ¹èÆ÷ÇÒ °æ¿ì ÀúÀÚ¿¡°Ô »çº»À» º¸³»ÁÖ¸é
°í¸¿°Ú´Ù. GNU/Linux ¹®¼­È­¸¦ À§ÇØ Linux Documentation Project ³ª Free Software
Foundation¿¡ ¿©·¯ºÐÀÇ µµ¿òÀ» ÁÖ±â¹Ù¶õ´Ù. ÀÚ¼¼ÇÑ ³»¿ëÀº Linux HOWTO °ü¸®ÀÚ, Tim
Bynum <url url="linux-howto@sunsite.unc.edu">¿¡°Ô ¹®ÀÇÇÏ¸é µÈ´Ù.

<sect>°¨»çÀÇ ±Û<p>
À̰÷Àº ³»°¡ °¨»çµå¸± »ç¶÷À» ¹àÈú ÁÁÀº ±âȸÀÎ°Í °°´Ù. ÀÌ ÀåÀÇ ³»¿ëÀÌ ´Ù¼Ò Ä¿Áú°Í
°°´Ù..... ¾î·µç À̰÷Àº-Àû¾îµµ ³»°ÔÀ־-ÀÌ ¹®¼­¿¡¼­ °¡Àå Áß¿äÇÑ ºÎºÐÀÌ´Ù.

¿ì¼±, Elena Apolinario Fernandez de Sousa (Elena°¡ À̸§,³ª¸ÓÁö°¡ ¼ºÀÌ´Ù ;-) )¿¡°Ô
°¨»çµå¸®°í ½Í´Ù. ¿ì¸® ºÎ¼­¸¦ MBone°ú ¿¬°áÇÏ´Â °úÁ¤, ±×¸®°í ¿ì¸®°¡ ¸ÖƼij½ºÆ® ÅͳοëÀ¸·Î
Á¦ÀÛÇÑ CSCV ¼ÒÇÁÆ®¿þ¾î¸¦ µð¹ö±ëÇÏ´Â °úÁ¤¿¡¼­ ±×³à¿Í ÇÔ²² ÀÏÇϸç
¾òÀº ¸ðµç Áö½ÄÀ» ÀÌ ¹®¼­¿¡ ¹Ý¿µÇÏ·Á°í ³ë·ÂÇÏ¿´´Ù. ±×³à´Â ³×Æ®¿÷ ¹®Á¦¸¦ ã¾Æ³» ÇØ°áÇϰí
Ä¿³ÎÀÇ ¹ö±×¸¦ ¼öÁ¤Çϴµ¥ ¸¹Àº µµ¿òÀ» ÁÖ¾úÀ¸¸ç, °è¼ÓµÇ´Â ¹ö±×¿ÍÀÇ ½Î¿ò¿¡¼­µµ 
À¯¸Ó°¨°¢À» ÀÒÁö ¾Ê¾Ò´Ù. ¶Ç, ±×³à´Â À̹®¼­ÀÇ ÃʾÈÀ» ÀÐ°í ¼öÁ¤ÇØ ÁÖ¾úÀ¸¸ç Áß¿äÇÑ
Á¦¾ÈÀ» ÇØ ÁÖ¾ú´Ù. ÀÌ ¹®¼­°¡ »ç¶÷µé¿¡°Ô µµ¿òÀÌ µÇ¾ú´Ù¸é »ó´çºÎºÐ ±×³à ´öºÐÀÏ °ÍÀÌ´Ù.
°í¸¶¿ö, Elena!

¾ó¸¶ ±æÁö ¾ÊÀº ÀλýÀÌÁö¸¸ ³» »ý¾Ö¿¡¼­ Á¤¸» ¿î ÁÁ´Ù°í »ý°¢ÇÏ´Â °ÍÀº,
Àڱ⠽ð£À» Âɰ³¼­ ÀÌ·± »õ·Î¿î °ÍÀ» ¹è¿ì´Â ³²À» µ½°í ±× ÀÚü¸¦ ÁÁ¾ÆÇÏ´Â
»ç¶÷µéÀ» ¸¸³µ´Ù´Â °ÍÀÌ´Ù. ±×ºÐµéÀº ÀÚ½ÅÀÌ ÀÌ¹Ì ¾Æ´Â °ÍÀ» ¼³¸íÇØÁÖ¾úÀ¸¸ç
±× »Ó¸¸ ¾Æ´Ï¶ó Ã¥À» ºô·ÁÁÖ°í ÀÚ·á¿Í ¼³ºñ¸¦ °øÀ¯ÇØ ÁÖ¾ú´Ù. ³ª´Â ÀÌ·± ºÐµéÀ» ¸¹ÀÌ ¾Ë°í ÀÖÀ¸¸ç
±×ºÐµé¿¡°Ô °¨»çÀÇ ¶æÀ» ÀüÇϰíÀÚ ÇÑ´Ù.

Pablo Basterrechea´Â ³»°¡ ÀÎÅÍ³Ý Ãʺ¸ÀÚÀ϶§ ¸¹Àº ¹®¼­µéÀ» ºô·ÁÁÖ¾ú´Ù.
±×ÀÇ Ã¥À¸·Î ¾î¼Àºí¸®¸¦ °øºÎÇÏ°í ±¸Á¶Àû ÇÁ·Î±×·¡¹ÖÀ¸·Î ³ª¾Æ °¥ ¼ö ÀÖ¾ú´Ù.
°í¸¿³×, Pablo.

³»°¡ ´ëÇÐ ½ÅÀÔ»ý¶§ Pepe Mas¾¾°¡ ¸¹Àº µµ¿òÀ» ÁÖ¾ú´Ù. ±×´Â ÄÄÇ»ÅÍ ÇÁ·Î±×·¡¹ÖÀ»
°¡¸£Ä¡´Â ¹®À̾ú´Âµ¥, ³ª´Â °ð ±×ºÐÀÇ ¼­°¡¿¡ Ȧ·Á¹ö·È´Ù. ³»°¡ Ã¥À» Á¦¶§¿¡ Á¦´ë·Î
µ¹·ÁÁÙ °ÍÀ̶ó´Â º¸ÁõÀÌ ¾ø¾ú´Âµ¥µµ À̸§Á¶Â÷ ¹°¾îº¸Áö ¾Ê°í Á¶°Ç¾øÀÌ Ã¥À» ºô·ÁÁÖ¾ú´Ù.
±× ºÐÀÇ Ã¥ Áï, ComerÀÇ "Internetworking with TCP/IP, Volume 1"À» ¿©¸§ ³»³» 
º¸¸ç óÀ½À¸·Î TCP/IP¸¦ Á¢Çß´Ù. ÀÌ Ã¥Àº ³»°Ô ¸¹Àº ¿µÇâÀ» ¹ÌÃÆÀ¸¸ç ±× ¿©¸§ ÀÌÈÄ·Î TCP/IP´Â
ÁÖ ºÐ¾ß°¡ µÇ¾ú´Ù.

³»°¡ °¡Àå °¨»çµå·Á¾ß ÇÒ ºÐÀÌ ÀÖ´Ù¸é, ¾ËÆÄºª ¼ø¼­·Î ;-), Jos Manuel °ú Paco Moya
ÀÌ µÎ¸íÀÌ´Ù. ÀÌ µÎ ¸í¿¡°Ô ³ª´Â ±Ã±ÝÇÑ °ÍÀ» °¡Àå ¸¹ÀÌ ¹°¾ú´Ù.(C, C++, Linux, security, 
Web, OSs, signals & systems, electronics, ... ±×¿ÜÀÇ °Íµé ¸ðµÎ!) ³ªÀÇ °è¼ÓµÇ´Â
Áú¹®¿¡µµ ºÒ±¸ÇÏ°í ¾ðÁ¦³ª Ä£ÀýÇÏ°Ô ¾Ë·ÁÁÖ¾ú´Ù.³»°¡ GNU/Linux¸¦ ¾²´Â °Íµµ ±×µé ´öÀ̸ç
 Á¤¸»·Î °¨»çµå¸®´Â ºÐµéÀÌ´Ù. 

Igo Mascaraque ¿ª½Ã Ãʺ¸ ½ÃÀý ³ª¸¦ µµ¿Í ÁÖ°í Æ÷±âÇÏÁö ¾Êµµ·Ï ¿ë±â¸¦ ºÏµ¸¾Æ ÁÖ¾ú´Ù. 

Á¦ÀÏ Áß¿äÇÑ ºÎ¸ð´Ô²² °¨»çµå¸®°í ½Í´Ù. ¾ðÁ¦³ª ³»°Ô ÁÁÀº ±âȸ¸¦ Á̴ּÙ. Á¤¸»·Î °¨»çµå¸°´Ù.

³»°¡ óÀ½ ½Ã½ºÅÛ °ü¸®¸¦ µ¶ÇÐ ÇÒ¶§ root ÆÐ½º¿öµå¸¦ ³»°Ô ÁÙ Á¤µµ·Î ³ª¸¦ ¹Ï¾îÁØ
Joaqu Seoane¿¡°Ôµµ °¨»çµå¸°´Ù. ¶Ç, ¿ª½Ã À̰÷ DIT¿¡¼­ ³»°Ô ÁÁÀº ±âȸ¸¦ ¸¸µé¾îÁØ 
Santiago Pav¿¡°Ôµµ °¨»çµå¸°´Ù.

W. Richard Stevens¾¾ÀÇ Ã¥Àº ³»°Ô Á¤¸» °è½Ã¿Íµµ °°Àº Ã¥À̾ú´Ù.(ºñ½Ñ°Ô
ÈìÀ̱ä ÇÏÁö¸¸) ±× ºÐÀÌ È¤½Ã¶óµµ ÀÌ ±ÛÀ» º¸½Å´Ù¸é Á¤¸»·Î °¨»çµå¸®°í ½Í´Ù. ¶Ç, °è¼Ó
ÁýÇÊÇØ Áֽñ⸦ ºÎʵ台´Ù. ¿ì¸®¿¡°Ô ¸¹Àº µµ¿òÀÌ µÉ °ÍÀÌ´Ù.

³¡À¸·Î Richard Stallman, Linus Torvalds, Alan Cox, ±× ¿Ü¿¡, ¿ì¸®¿¡°Ô ÀÌ·± ÈǸ¢ÇÑ
¿î¿µÃ¼Á¦¸¦ ¾È°ÜÁØ Linux Ä¿³Î ¹× free software °³¹ßÀڵ鿡°Ô °¨»çµå¸°´Ù.

´©±º°¡ ÀØÀº°Í °°±ä ÇÏÁö¸¸ ..Á˼Û...³»°¡ ±× ºÐµé¿¡°Ô °¨»çÇØÇϰí ÀÖ´Ù´Â °ÍÀ» ¾Ë°í °è½Ã¸®¶ó
È®½ÅÇÑ´Ù. 

<sect>¿ªÀÚ ÇѸ¶µð<p>
º¸±âº¸´Ù ¸¸¸¸Ä¡ ¾Ê±º¿ä. ƯÈ÷ ¿ë¾î ¼±ÅÃÀÌ ¾î·Á¿ü½À´Ï´Ù. À߸øµÈ ºÎºÐÀÌ Àְųª ´Ù¸¥ ÇÏ°í ½ÍÀº
¸»¾¸ÀÌ ÀÖ´Ù¸é ¸ÞÀÏ ºÎʵ右´Ï´Ù. Á¶¼ÓÇÑ ½ÃÀÏ ³»¿¡ °³Á¤Çϵµ·Ï ³ë·ÂÇϰڽÀ´Ï´Ù. µµ¿òÀÌ 
µÇ¾ú±â¸¦ ¹Ù¶ó¸é¼­....

</article>




sponsored by andamiro
sponsored by cdnetworks
sponsored by HP

Valid XHTML 1.0! Valid CSS! powered by MoniWiki
last modified 2003-08-10 11:52:30
Processing time 0.0073 sec