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

You are not allowed to 'edit'


Multicast over TCP/IP HOWTO

Multicast over TCP/IP HOWTO

Juan-Mariano de Goyeneche jmseyas@dit.upm.es

v1.0, 20 March 1998 ±èÇöÇÊ khp@kldp.org v0.9, 10 July 2000
ÀÌ ¹®¼­¿¡¼­´Â TCP/IP ³×Æ®¿÷¿¡¼­ ¸ÖƼij½ºÆ®¿Í °ü·ÃµÈ Àü¹ÝÀûÀÎ »çÇ×À» ¼³¸íÇÑ´Ù. µû¶ó¼­ »ó´çºÎºÐ ¸®´ª½º¿¡ ±¹ÇѵǴ ³»¿ëÀÌ ¾Æ´Ï´Ù. (¾ÆÁ÷..GNU/¸®´ª½º¸¦ ¾²Áö ¾ÊÀ» °æ¿ì¿¡¸¸) ¸ÖƼij½ºÆ®´Â Áö±Ý±îÁöµµ È°¹ßÈ÷ ¿¬±¸ÁßÀÎ ºÐ¾ßÀÌ´Ù. µû¶ó¼­ ÀÌ ±ÛÀÇ ÀÛ¼º ½ÃÁ¡¿¡¼­´Â Ç¥ÁØ¾È ´ëºÎºÐÀÌ ÃʾÈ(draft)ÀÏ »ÓÀÌ´Ù. ÀÌÁ¡ ¿°µÎ¿¡ µÎ°í ÀÐÀ¸½Ã±â ¹Ù¶õ´Ù.

1. ¼Ò°³

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

1.1 ¸ÖƼij½ºÆ®(Multicast)¶õ ¹«¾ùÀΰ¡?

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

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

1.2 À¯´Ïij½ºÆ®(Unicast)ÀÇ ¹®Á¦Á¡

ºê·Îµå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)¿¡¼­ ¶ó¿ìÆÃÇÑ´Ù. Ä¿³Î¿¡ ¶ó¿ìÆà °æ·Î¸¦ ¾Ë·ÁÁÖ´Â ¶ó¿ìÆà ¾Ë°í¸®Áò¿¡ Â÷ÀÌÁ¡ÀÌ ÀÖÀ» °ÍÀÌ´Ù.

2. ¸ÖƼij½ºÆ®

2.1 Multicast ÁÖ¼Ò

IP ÁÖ¼Ò´Â 32ºñÆ® Áß¿¡¼­ »óÀ§ ºñÆ®µé¿¡ ÀÇÇؼ­ Ŭ·¡½º(class)·Î ºÐ·ùµÈ´Ù.

     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
             +-+-+-+-+-+--------------------+

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

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

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

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

ÀÌ Æ¯¼ö ±×·ìµéÀº ¸ðµÎ 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À» ÂüÁ¶ÇÒ °Í).

2.2 ÀûÀÀ ´Ü°è(Levels of Conformance)

È£½ºÆ®°¡ ¸¸Á·ÇؾßÇÏ´Â ¸ÖƼij½ºÆ® ±Ô°Ý¿¡´Â ¼¼ °¡Áö ÀûÀÀ ´Ü°è°¡ ÀÖ´Ù.

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

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

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

2.3 ¸ÖƼij½ºÆ® µ¥ÀÌÅͱ׷¥ Àü¼Û

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

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

TTL.

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

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

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

´ÙÀ½ ¸®½ºÆ®¿¡ TTL¹®ÅÎÄ¡¿Í ±×¿¡ ÇØ´çµÇ´Â ¹üÀ§°¡ Ç¥½ÃµÇ¾î ÀÖ´Ù.

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

"»çÀÌÆ®(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ÁÖ¼Ò°¡ ÀÌ °ü¸®¿ë ¹üÀ§Á¦ÇÑÀ» À§ÇØ ¿¹¾àµÇ¾î ÀÖ´Ù.

·çÇÁ¹é(Loopback)

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

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

ÀÎÅÍÆäÀ̽º ¼±ÅÃ

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

2.4 ¸ÖƼij½ºÆ® µ¥ÀÌÅͱ׷¥ ¼ö½Å

¸ÖƼij½ºÆ® ±×·ì Âü¿©(Join)

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

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

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

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

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

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

¸ÖƼij½ºÆ® Group Å»Åð

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

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

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

IP ¸ÖƼij½ºÆ® ÁÖ¼Ò¿¡¼­ Ethernet/FDDI ÁÖ¼Ò·ÎÀÇ »ç»ó (mapping)

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¸¦ ÂüÁ¶Ç϶ó.

3. Ä¿³Î ¿ä±¸ »çÇ×°ú ¼³Á¤

Linux´Â ´ç¿¬È÷(¼³¸¶ ÀǽÉÀ»?) ¿ÏÀüÇÑ Level 2 ¸ÖƼij½ºÆ®¸¦ Áö¿øÇÑ´Ù. ¸ðµç ¼Û¼ö½Å ¿ä±¸»çÇ×À» ¸¸Á·ÇÏ¸ç ¸ÖƼ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¸¦ ÅëÇؼ­ È®ÀÎÇØ º¼ ¼ö ÀÖ´Ù.

4. The MBone.

ÀåÁ¡°ú ÇÔ²² ´ÜÁ¡µµ ÀÖ´Â ±â¼úÀÌ´Ù. ³ªÀÇ »ç°ßÀÌÁö¸¸, ÀåÁ¡Àº ºÐ¸íÇÏ´Ù´Â Á¡ÀÌ´Ù. ÁÖµÈ ´ÜÁ¡Àº ¾ÆÁ÷ ¼ö¹éÀÇ È£½ºÆ®µé, ƯÈ÷ ¶ó¿ìÅ͵éÀÌ ¾ÆÁ÷ Áö¿øÇÏÁö ¾Ê°í ÀÖ´Ù´Â Á¡ÀÌ´Ù. °á°úÀûÀ¸·Î ¸ÖƼij½ºÆ®¸¦ »ç¿ëÇÏ´Â »ç¶÷µéÀº »õ·Î¿î Àåºñ¸¦ ±¸ÀÔÇÏ°í ¿î¿µÃ¼Á¦¸¦ ¼öÁ¤Çϸç ÀÚ½ÅÀÇ Àå¼Ò¿¡ ¸ÖƼ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¿¡ °üÇÑ ´õ ÀÚ¼¼ÇÑ ÀÚ·á´Â ´ÙÀ½À» Âü°íÇ϶ó. http://www.mediadesign.co.at/newmedia/more/mbone-faq.html

5. ¸ÖƼij½ºÆ® ÀÀ¿ëÇÁ·Î±×·¥µé

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

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

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

À½¼º ȸÀÇ(Audio Conference)

¿µ»ó ȸÀÇ(Video Conference)

±âŸ À¯Æ¿¸®Æ¼

ȸÀÇ µµ±¸(Session Tools)

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

6. ¸ÖƼij½ºÆ® ÇÁ·Î±×·¡¹Ö

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

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

setsockopt()/getsockopt() ÇÔ¼öÀÇ ¼±¾ðÀÌ´Ù.


      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);

ù ¹ø° º¯¼ö 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´Â ´ÙÀ½°ú °°´Ù.

      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

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

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

6.1 IP_MULTICAST_LOOP.

ÇÁ·Î±×·¡¸Ó¶ó¸é, µ¥ÀÌÅ͸¦ È£½ºÆ®·Î ·çÇÁ¹é ½Ãų °ÍÀÎÁö °áÁ¤ÇؾßÇÑ´Ù. ¸¸ÀÏ, ÇÁ·Î¼¼½º°¡ ¿©·¯ °³À̰ųª µ¥ÀÌÅ͸¦ ¸®½º´×"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)

6.2 IP_MULTICAST_TTL.

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

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

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

6.3 IP_MULTICAST_IF.

ÀϹÝÀûÀ¸·Î ½Ã½ºÅÛ °ü¸®ÀÚ´Â ±âº» ÀÎÅÍÆäÀ̽º¸¦ ÁöÁ¤Çϸç, ¸ÖƼ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½ºÆ®´Â ±âº» ÀÎÅÍÆäÀ̽º¸¦ ÅëÇØ ÀÌ·ç¾îÁø´Ù.

6.4 IP_ADD_MEMBERSHIP.

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

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


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

ÁÖÀÇ : ÀÌ ±¸Á¶Ã¼ÀÇ "¹°¸®Àû" Á¤ÀÇ´Â À§ÀÇ ÆÄÀÏ¿¡ ¸í½ÃµÇ¾î ÀÖ´Ù. ÇÏÁö¸¸, ÄÚµåÀÇ À̽ļºÀ» À§Çؼ­ <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ÀÌ´Ù.

6.5 IP_DROP_MEMBERSHIP.

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

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)

7. ¸ÖƼij½ºÆ® ³»ºÎ

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

7.1 IGMP.

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 ¸Þ½ÃÁö´Â ´ÙÀ½ ±¸Á¶¸¦ °¡Áø´Ù.

      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                         |
     +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+

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½ºÆ® µ¥ÀÌÅͱ׷¥À» ¹Þ´Â´Ù´Â °ÍÀ» ±â¾ïÇ϶ó.

7.2 IGMP version 1.

¶ó¿ìÅÍ´Â ÁÖ±âÀûÀ¸·Î(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·Î ±¸ºÐÇÑ´Ù.

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

7.3 IGMP ¹öÀü 2.

»ó±â ³»¿ë¿¡ ´ëÇÑ Ãß°¡ »çÇ× Áß Áß¿äÇÑ °Í ÇÑ°¡Áö´Â ±×·ì ÀÌÅ» ¸Þ½ÃÁö(ŸÀÔ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)°¡ µÇ°í ´Ù¸¥ ¶ó¿ìÅʹ ŸÀ̸Ӹ¦ ¼³Á¤ÇÑ´Ù. ³·Àº ¹øÈ£ÀÇ ¶ó¿ìÅÍ°¡ ¾î¶² ÀÌÀ¯·Î Á¦´ë·Î ÀÛµ¿ÇÏÁö ¸øÇϸé ŸÀ̸Ӱ¡ ¸¸·áµÈ ÈÄ ´Ù½Ã ÁúÀÇÀÚ¸¦ ¼³Á¤ÇÑ´Ù.

7.4 Ä¿³Î °ü·Ã »çÇ×

ÀÌ Àý¿¡¼­´Â ¸®´ª½º Ä¿³Î¿¡¼­ ¸ÖƼ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() Áß¿¡¼­)


  #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

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


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

¸µÅ© °èÃþÀÇ(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) ¿¡¼­ ´ÙÀ½°ú °°ÀÌ Á¤ÀÇÇÏ°í ÀÖ´Ù.


  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 */
  };

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


  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)*/
  };

ÀÌ ±¸Á¶Ã¼¿¡¼­ 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¿¡¼­ ´ÙÀ½°ú °°ÀÌ Á¤ÀÇÇÏ°í ÀÖ´Ù. :


  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;
  };

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


  #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

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


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

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

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


  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    */
  };

ÀÌ»óÀÇ Á¤º¸¸¦ °¡Áö°í, 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() ¿¡¼­ ¸¸µç´Ù.

8. ¶ó¿ìÆà Á¤Ã¥°ú Æ÷¿öµù ±â¼ú

º°·Î ÁÁÁö ¾ÊÀº ¾Ë°í¸®ÁòÀº ¸ÖƼ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 µéÀÌ ÀÖ´Â °÷¿¡ °°ÀÌ ÀÖÀ» °ÍÀ̸ç, »ó±âÇÑ ±â¼ú°ú Á¤Ã¥µé¿¡ ´ëÇÑ ¾à°£ ÀÚ¼¼ÇÑ ³»¿ëÀ» ´ã°íÀÖ´Ù.

9. ¸ÖƼij½ºÆ® Æ®·£½ºÆ÷Æ® ÇÁ·ÎÅäÄÝ

Áö±Ý±îÁö 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½ºÆ® ÇÁ·ÎÅäÄÝ°£ÀÇ ½Å·Ú¼ººñ±³´Â http://www.tascnets.com/mist/doc/mcpCompare.htmlÀ» Âü°íÇ϶ó.

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

¿©±âµµ ÁÁÀº Á¤º¸°¡ ¸¹´Ù. 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. ¿¡µµ ½Ç·ÁÀÖ´Ù.

10. Âü°í ÀÚ·á

10.1 RFC ¹®¼­

  • RFC 1112 "Host Extensions for IP Multicasting". Steve Deering. August 1989.
  • RFC 2236 "Internet Group Management Protocol, version 2". W.Fenner. November 1997.
  • RFC 1458 "Requirements for Multicast Protocols". Braudes, R and Zabele, S. May 1993.
  • RFC 1469 "IP Multicast over Token-Ring Local Area Networks". T. Pusateri. June 1993.
  • RFC 1390 "Transmission of IP and ARP over FDDI Networks". D. Katz. January 1993.
  • RFC 1583 "OSPF Version 2". John Moy. March 1994.
  • RFC 1584 "Multicast Extensions to OSPF". John Moy. March 1994.
  • RFC 1585 "MOSPF: Analysis and Experience". John Moy. March 1994.
  • RFC 1812 "Requirements for IP version 4 Routers". Fred Baker, Editor. June 1995
  • 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.
  • 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.

10.2 ÀÎÅÍ³Ý ÃʾÈ(draft)

  • "Introduction to IP Multicast Routing". draft-ietf-mboned-intro- multicast- 03.txt. T. Maufer, C. Semeria. July 1997.
  • "Administratively Scoped IP Multicast". draft-ietf-mboned-admin-ip-space-03.txt. D. Meyer. June 10, 1997.

10.3 À¥ ÆäÀÌÁö

10.4 Âü°í ¼­Àû

  • "TCP/IP Illustrated: Volume 1 The Protocols". Stevens, W. Richard. Addison Wesley Publishing Company, Reading MA, 1994
  • "TCP/IP Illustrated: Volume 2, The Implementation". Wright, Gary and W. Richard Stevens. Addison Wesley Publishing Company, Reading MA, 1995
  • "UNIX Network Programming Volume 1. Networking APIs: Sockets and XTI". Stevens, W. Richard. Second Edition, Prentice Hall, Inc. 1998.
  • "Internetworking with TCP/IP Volume 1 Principles, Protocols, and Architecture". Comer, Douglas E. Second Edition, Prentice Hall, Inc. Englewood Cliffs, New Jersey, 1991

11. ÀúÀ۱ǰú Ã¥ÀÓ ÇÑ°è °íÁö

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 linux-howto@sunsite.unc.edu¿¡°Ô ¹®ÀÇÇÏ¸é µÈ´Ù.

12. °¨»çÀÇ ±Û

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

¿ì¼±, 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 °³¹ßÀڵ鿡°Ô °¨»çµå¸°´Ù.

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

13. ¿ªÀÚ ÇѸ¶µð

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


ID
Password
Join
A good memory does not equal pale ink.


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.0019 sec