ÄÜÅÙÃ÷»ó¼¼º¸±â

µµ¸ÞÀÎ ÁÖµµ ¼³°è
µµ¸ÞÀÎ ÁÖµµ ¼³°è
  • ÀúÀÚ<¿¡¸¯ ¿¡¹Ý½º> Àú/<À̴뿱> ¿ª
  • ÃâÆÇ»çÀ§Å°ºÏ½º
  • ÃâÆÇÀÏ2022-12-28
  • µî·ÏÀÏ2023-03-02
º¸À¯ 1, ´ëÃâ 0, ¿¹¾à 0, ´©Àû´ëÃâ 4, ´©Àû¿¹¾à 1

Ã¥¼Ò°³

¼ÒÇÁÆ®¿þ¾îÀÇ º¹À⼺À» ´Ù½º·Á¶ó!

¼ÒÇÁÆ®¿þ¾îÀÇ º¹À⼺Àº µµ¸ÞÀο¡¼­ ±âÀÎÇÏ°í, ±×·¯ÇÑ º¹À⼺À» ¾î¶»°Ô ´Ù·ç´À³Ä°¡ ÇÁ·ÎÁ§Æ®ÀÇ ¼ºÆи¦ Á¿ìÇÑ´Ù. µµ¸ÞÀΠÁÖµµ ¼³°è(Domain-Driven Design)´Â º¹ÀâÇÑ ¿ä°ÇÀ» Áö´Ñ ¼ÒÇÁÆ®¿þ¾î¸¦ °³¹ßÇϴ Á¢±Ù¹ýÀÇ Çϳª´Ù. µµ¸ÞÀΠÁÖµµ ¼³°è¿¡¼­´Â ¼ÒÇÁÆ®¿þ¾î ÇÁ·ÎÁ§Æ®°¡ Çٽɠµµ¸ÞÀΰú µµ¸ÞÀΠ·ÎÁ÷¿¡ ÁýÁßÇÏ°í, º¹ÀâÇÑ ¼³°è´Â ¸ðµ¨À» ±â¹ÝÀ¸·Î ÇؾߠÇѴٴ ÀüÁ¦¿¡¼­ Ãâ¹ßÇØ À¯¿ëÇÑ ¼ÒÇÁÆ®¿þ¾î¸¦ °³¹ßÇϴ Çè³­ÇÑ ¿©Á¤¿¡¼­ Áß¿äÇÑ ¼³°è °áÁ¤À̳ª Àü·«Àû »ç°í¿Í ¾È¸ñÀÌ ÇÊ¿äÇÒ ¶§¸¶´Ù ±¸½ÉÁ¡ ¿ªÇÒÀ» ÇÒ °ÍÀÌ´Ù.

ÀúÀÚÀΠ¿¡¸¯ ¿¡¹Ý½ºÀÇ ¿À·£ °æÇè°ú ÅëÂû·ÂÀÌ ºüÁü¾øÀÌ ´ã±ä ¡ºµµ¸ÞÀΠÁÖµµ ¼³°è¡»´Â º¹ÀâÇÑ ¼ÒÇÁÆ®¿þ¾î¸¦ °³¹ßÇϴ ÇÁ·ÎÁ§Æ®¿¡¼­ ÀÇ»ç°áÁ¤ÀÇ ±â¹ÝÀÌ µÇ´Â Æ²°ú ¼³°è ³íÀÇ¿¡ »ç¿ëÇÒ ¼ö Àִ ¾îÈÖ¸¦ Á¦°øÇÑ´Ù. ´Ü¼øÈ÷ ¼³°è³ª ÇÁ·Î¼¼½º¿¡ °üÇѠåÀ» ³Ê¸Ó ¡ºµµ¸ÞÀΠÁÖµµ ¼³°è¡»´Â ±× ÀÌ»óÀÇ ½Ç¿ëÀûÀÌ°í ÇÕ¸®ÀûÀΠÁ¢±Ù¹ý°ú ¼³°è ¹× ¸ðµ¨¸µ ±â¹ý, ¿ì¼ö ½Çõ¹ýÀ» µ¶ÀÚ¿¡°Ô Á¦½ÃÇÑ´Ù. ¡ºµµ¸ÞÀΠÁÖµµ ¼³°è¡»´Â ºñ´Ü ¼ÒÇÁÆ®¿þ¾î °³¹ßÀÚ¸¸ÀÌ ¾Æ´Ï¶ó ¼ÒÇÁÆ®¿þ¾î ÇÁ·ÎÁ§Æ®¿¡ Âü¿©Çϴ ¸ðµç À̵éÀÌ º¹À⼺À̶ó´Â µµÀü°úÁ¦¸¦ ´Ù½º·Á¼­ ¼ÒÇÁÆ®¿þ¾î ÇÁ·ÎÁ§Æ®¸¦ ¿Ã¹Ù¸¥ ±æ·Î À̲ø¾î ³ª°¡´Â µ¥ µµ¿òµÉ °ÍÀÌ´Ù.

¸ñÂ÷

¢Ã 01ºÎ  µ¿ÀÛÇϴ µµ¸ÞÀΠ¸ðµ¨ ¸¸µé±â
µµ¸ÞÀΠÁÖµµ ¼³°è¿¡¼­ÀÇ ¸ðµ¨ÀÇ À¯¿ë¼º
¼ÒÇÁÆ®¿þ¾îÀÇ º»Áú

01Àå   Áö½Ä Å½±¸
È¿°úÀûÀΠ¸ðµ¨¸µÀÇ ¿ä¼Ò
Áö½Ä Å½±¸
Áö¼ÓÀûÀΠÇнÀ
Áö½ÄÀ̠dzºÎÇÑ ¼³°è
½ÉÃþ ¸ðµ¨

02Àå   ÀÇ»ç¼ÒÅë°ú ¾ð¾î »ç¿ë
UBIQUITOUS LANGUAGE (º¸Æí ¾ð¾î)
Å©°Ô ¼Ò¸®³»¾î ¸ðµ¨¸µÇϱâ
ÇÑ ÆÀ, ÇÑ ¾ð¾î
¹®¼­¿Í ´ÙÀ̾î±×·¥
- ±Û·Î ¾´ ¼³°è ¹®¼­
- ½ÇÇà °¡´ÉÇÑ ±â¹Ý
¼³¸íÀ» À§ÇÑ ¸ðµ¨

03Àå   ¸ðµ¨°ú ±¸ÇöÀÇ ¿¬°è
MODEL-DRIVEN DESIGN (¸ðµ¨ ÁÖµµ ¼³°è)
¸ðµ¨¸µ Æз¯´ÙÀÓ°ú µµ±¸ Áö¿ø
³»ºÎ µå·¯³»±â: ¿Ö ¸ðµ¨ÀÌ »ç¿ëÀÚ¿¡°Ô Áß¿äÇÑ°¡
HANDS-ON MODELER (½ÇõÀû ¸ðµ¨·¯)

¢Ã 02ºÎ   ¸ðµ¨ ÁÖµµ ¼³°èÀÇ ±âº» ¿ä¼Ò

04Àå   µµ¸ÞÀÎÀÇ °Ý¸®
LAYERED ARCHITECTURE (°èÃþÇü ¾ÆÅ°ÅØó)
- °èÃþ °£ °ü°è ¼³Á¤
- ¾ÆÅ°ÅØó ÇÁ·¹ÀÓ¿öÅ©
µµ¸ÞÀΠ°èÃþÀº ¸ðµ¨ÀÌ »ì¾Æ°¡´Â °÷
SMART UI(Áö´ÉÇü UI) "¾ÈƼ ÆÐÅÏ"
´Ù¸¥ Á¾·ùÀÇ °Ý¸®

05Àå   ¼ÒÇÁÆ®¿þ¾î¿¡¼­ Ç¥ÇöµÇ´Â ¸ðµ¨
¿¬°ü°ü°è
ENTITY (¿£Æ¼Æ¼, ÂüÁ¶°´Ã¼¶ó°íµµ ÇÔ)
- ENTITY ¸ðµ¨¸µ
- ½Äº° ¿¬»êÀÇ ¼³°è
VALUE OBJECT (°ª °´Ã¼)
- VALUE OBJECTÀÇ ¼³°è
- VALUE OBJECT¸¦ Æ÷ÇÔÇÑ ¿¬°ü°ü°è ¼³°è
SERVICE(¼­ºñ½º)
- SERVICE¿Í °Ý¸®µÈ µµ¸ÞÀΠ°èÃþ
- ±¸¼º ´ÜÀ§
- SERVICE¿¡ Á¢±ÙÇϱâ
MODULE(¸ðµâ, ÆÐÅ°Áö¶ó°íµµ ÇÔ)
- ±â¹ÎÇÑ MODULE
- ÀÎÇÁ¶ó½ºÆ®·°Ã³ ÁÖµµ ÆÐÅ°ÁöÈ­ÀÇ ÇÔÁ¤
¸ðµ¨¸µ Æз¯´ÙÀÓ
- °´Ã¼ Æз¯´ÙÀÓÀÌ Áö¹èÀûÀΠÀÌÀ¯
- °´Ã¼ ¼¼°è¿¡¼­ °´Ã¼°¡ ¾Æ´Ñ °Íµé
- Æз¯´ÙÀÓÀ̠ȥÀçÇÒ ¶§ MODEL-DRIVEN DESIGN °í¼öÇϱâ

06Àå   µµ¸ÞÀΠ°´Ã¼ÀÇ »ý¸íÁÖ±â
AGGREGATE (ÁýÇÕ)
FACTORY (ÆÑÅ͸®)
- FACTORY¿Í FACTORYÀÇ À§Ä¡ ¼±Á¤
- »ý¼ºÀÚ¸¸À¸·Î ÃæºÐÇÑ °æ¿ì
- ÀÎÅÍÆäÀ̽º ¼³°è
- ºÒº¯½Ä ·ÎÁ÷ÀÇ À§Ä¡
- ENTITY FACTORY¿Í VALUE OBJECT FACTORY
- ÀúÀåµÈ °´Ã¼ÀÇ À籸¼º
REPOSITORY (¸®ÆÄÁöÅ͸®)
- REPOSITORY¿¡ ÁúÀÇÇϱâ
- Å¬¶óÀ̾ðÆ® Äڵ尡 REPOSITORY ±¸ÇöÀ» ¹«½ÃÇÑ´Ù (°³¹ßÀڴ ±×·¸Áö ¾ÊÁö¸¸)
- REPOSITORY ±¸Çö
- ÇÁ·¹ÀÓ¿öÅ©ÀÇ È°¿ë
- FACTORY¿ÍÀÇ °ü°è
°ü°èÇü µ¥ÀÌÅͺ£À̽º¸¦ À§ÇÑ °´Ã¼ ¼³°è

07Àå   ¾ð¾îÀÇ »ç¿ë(È®Àå ¿¹Á¦)
È­¹° ÇؿýºÅÛ ¼Ò°³
µµ¸ÞÀΠ°Ý¸®: ÀÀ¿ë ±â´É ¼Ò°³
ENTITY¿Í VALUE OBJECTÀÇ ±¸ºÐ
- ¿ªÇÒ°ú ±× ¹ÛÀÇ ¼Ó¼º
ÇØ¿î µµ¸ÞÀÎÀÇ ¿¬°ü°ü°è ¼³°è
AGGREGATEÀÇ °æ°è
REPOSITORYÀÇ ¼±Á¤
½Ã³ª¸®¿À ¿¬½À
- ¿¹Á¦ ¾ÖÇø®ÄÉÀ̼Ǡ±â´É: È­¹°ÀÇ ¸ñÀûÁö º¯°æ
- ¿¹Á¦ ¾ÖÇø®ÄÉÀ̼Ǡ±â´É: ¹Ýº¹ ¾÷¹«
°´Ã¼ »ý¼º
- Cargo¿¡ ´ëÇÑ FACTORY¿Í »ý¼ºÀÚ
- Handling Event Ãß°¡
¸®ÆÑÅ͸µÇÒ ½Ã°£: Cargo AGGREGATEÀÇ ¼³°è ´ë¾È
ÇØ¿î ¸ðµ¨ÀÇ MODULE
»õ·Î¿î ±â´É µµÀÔ: ÇÒ´ç·® °Ë»ç
- µÎ ½Ã½ºÅÛÀÇ ¿¬°è
- ¸ðµ¨ °­È­: ¾÷¹« ºÐ¾ß ³ª´©±â
- ¼º´É ÃÖÀûÈ­
ÃÖÁ¾ °ËÅä

¢Ã 03ºÎ   ´õ ½ÉÃþÀûÀΠÅëÂû·ÂÀ» ÇâÇÑ ¸®ÆÑÅ͸µ
¸®ÆÑÅ͸µ ¼öÁØ
½ÉÃþ ¸ðµ¨
½ÉÃþ ¸ðµ¨/À¯¿¬ÇÑ ¼³°è
¹ß°ß °úÁ¤

08Àå   µµ¾à
µµ¾à¿¡ °üÇÑ ÀÏÈ­
- ±¦ÂúÀº ¸ðµ¨À̱â´Â ÇÏÁö¸¸¡¦¡¦
- µµ¾à
- ´õ ½ÉÃþÀûÀΠ¸ðµ¨
- ³ÃÁ¤ÇÑ °áÁ¤
- °á¸»
±âȸ
±âº»¿¡ ÁýÁßÇ϶ó
Èıâ : ¿¬ÀÌÀº »õ·Î¿î ÅëÂû·ÂÀÇ ÃâÇö

09Àå   ¾Ï½ÃÀûÀΠ°³³äÀ» ¸íÈ®ÇÏ°Ô
°³³ä ÆÄÇìÄ¡±â
- ¾ð¾î¿¡ ±Í ±â¿ï¿©¶ó
- ¾î»öÇÑ ºÎºÐÀ» Á¶»çÇ϶ó
- ¸ð¼øÁ¡¿¡ ´ëÇØ ±íÀÌ °í¹ÎÇ϶ó
- ¼­ÀûÀ» Âü°íÇ϶ó
- ½ÃµµÇÏ°í ¶Ç ½ÃµµÇ϶ó
´Ù¼Ò ºÒ¸íÈ®ÇÑ °³³äÀÇ ¸ðµ¨¸µ
- ¸í½ÃÀûÀΠÁ¦¾àÁ¶°Ç
- µµ¸ÞÀΠ°´Ã¼·Î¼­ÀÇ ÇÁ·Î¼¼½º
SPECIFICATION (¸í¼¼)
- SPECIFICATIONÀÇ Àû¿ë°ú ±¸Çö

10Àå   À¯¿¬ÇÑ ¼³°è
INTENTION-REVEALING INTERFACE (Àǵµ¸¦ µå·¯³»´Â ÀÎÅÍÆäÀ̽º)
SIDE -EFFECT-FREE FUNCTION (ºÎ¼öÈ¿°ú°¡ ¾ø´Â ÇÔ¼ö)
ASSERTION (´ÜÁ¤)
CONCEPTUAL CONTOUR (°³³äÀû À±°û)
STANDALONE CLASS (µ¶¸³Çü Å¬·¡½º)
CLOSURE OF OPERATION (¿¬»êÀÇ ´ÝÈû)
¼±¾ðÀû ¼³°è
- µµ¸ÞÀΠƯȭ ¾ð¾î
¼±¾ðÀûÀΠÇü½ÄÀÇ ¼³°è
- SPECIFICATIONÀ» ¼±¾ðÀûÀΠÇü½ÄÀ¸·Î È®ÀåÇϱâ
¹ÞÀ½°¢
- ¼­ºê µµ¸ÞÀÎÀ¸·Î ºÐÇÒÇ϶ó
- °¡´ÉÇÏ´Ù¸é Á¤¸³µÈ Á¤ÇüÈ­¸¦ È°¿ëÇ϶ó

11Àå   ºÐ¼® ÆÐÅÏÀÇ Àû¿ë

12Àå   ¸ðµ¨°ú µðÀÚÀΠÆÐÅÏÀÇ ¿¬°á
STRATEGY (POLICY¶ó°íµµ ÇÔ)
COMPOSITE (º¹ÇÕü)
±×·¸´Ù¸é FLYWEIGHT´Â?

13Àå   ´õ ½ÉÃþÀûÀΠÅëÂû·ÂÀ» ÇâÇÑ ¸®ÆÑÅ͸µ
½ÃÀÛ
Á¶»çÆÀ
¼±Çà ±â¼ú
°³¹ßÀÚ¸¦ À§ÇÑ ¼³°è
ŸÀ̹Ö
À§±â¸¦ ±âȸ·Î

¢Ã 04ºÎ   Àü·«Àû ¼³°è

14Àå   ¸ðµ¨ÀÇ ¹«°á¼º À¯Áö
BOUNDED CONTEXT (Á¦ÇѵȠÄÁÅؽºÆ®)
- BOUNDED CONTEXT ¾ÈÀÇ ±Õ¿­ ÀνÄ
CONTINUOUS INTEGRATION (Áö¼ÓÀûÀΠÅëÇÕ)
CONTEXT MAP (ÄÁÅؽºÆ® ¸Ê)
- CONTEXT °æ°è¿¡¼­ÀÇ Å×½ºÆ®
- CONTEXT MAPÀÇ Á¶Á÷È­¿Í ¹®¼­È­
BOUNDED CONTEXT °£ÀÇ °ü°è
SHARED KERNEL (°øÀ¯ Ä¿³Î)
CUSTOMER/SUPPLIER DEVELOPMENTTEAM (°í°´/°ø±ÞÀÚ °³¹ß ÆÀ)
CONFORMIST (ÁؼöÀÚ)
ANTICORRUPTION LAYER (¿À·ù ¹æ? °èÃþ)
- ANTICORRUPTION LAYERÀÇ ÀÎÅÍÆäÀ̽º ¼³°è
- ANTICORRUPTION LAYERÀÇ ±¸Çö
- ±³ÈÆÀûÀΠÀ̾߱â
SEPARATE WAYS (°¢ÀÚÀÇ ±æ)
OPEN HOST SERVICE (°ø°³ È£½ºÆ® ¼­ºñ½º)
PUBLISHED LANGUAGE (°øÇ¥µÈ ¾ð¾î)
ÄÚ³¢¸® ÅëÀÏÇϱâ
¸ðµ¨ÀÇ ÄÁÅؽºÆ® Àü·« ¼±ÅÃ
- ÆÀ ÀÇ»ç°áÁ¤ ¶Ç´Â ±× ÀÌ»ó
- ¿ì¸® ÀÚ½ÅÀ» ÄÁÅؽºÆ®¿¡ ¹èÄ¡Çϱâ
- °æ°èÀÇ º¯Çü
- º¯°æÇÒ ¼ö ¾ø´Ù´Â »ç½ÇÀ» ÀÎÁ¤Çϱâ: ¿ÜºÎ ½Ã½ºÅÛÀÇ ¹¦»ç
- ¿ÜºÎ ½Ã½ºÅÛ°úÀÇ °ü°è
- ¼³°è ÁßÀΠ½Ã½ºÅÛ
- °³º° ¸ðµ¨ÀǠƯ¼öÇÑ ¿ä±¸»çÇ× ÃæÁ·Çϱâ
- ¹èÄ¡
- Å¸ÇùÁ¡
- ÇÁ·ÎÁ§Æ®°¡ À̹̠ÁøÇà ÁßÀÏ ¶§
º¯Çü
- CONTEXT º´ÇÕ: SEPARATE WAYS ¡æ SHARED KERNEL
- CONTEXT º´ÇÕ: SHARED KERNEL ¡æ CONTINUOUS INTEGRATION
- ·¹°Å½Ã ½Ã½ºÅÛÀÇ ´Ü°èÀû Æó±â
- OPEN HOST SERVICE ¡æ PUBLISHED LANGUAGE

15Àå   µð½ºÆ¿·¹À̼Ç
CORE DOMAIN (Çٽɠµµ¸ÞÀÎ)
- CORE ¼±ÅÃ
- ´©°¡ ±× ÀÏÀ» ÇÒ °ÍÀΰ¡?
µð½ºÆ¿·¹À̼ÇÀÇ ´Ü°èÀû È®´ë
GENERIC SUBDOMAIN (ÀϹݠÇÏÀ§ µµ¸ÞÀÎ)
- ÀϹÝÈ­°¡ Àç»ç¿ë °¡´ÉÇϴٴ Àǹ̴ ¾Æ´Ï´Ù
- ÇÁ·ÎÁ§Æ® À§Çè °ü¸®
DOMAIN VISION STATEMENT (µµ¸ÞÀΠºñÀü ¼±¾ð¹®)
HIGHLIGHTED CORE (°­Á¶µÈ ÇÙ½É)
- µð½ºÆ¿·¹À̼Ǡ¹®¼­
- Ç¥½ÃµÈ CORE
- ÇÁ·Î¼¼½º µµ±¸·Î¼­ÀÇ µð½ºÆ¿·¹À̼Ǡ¹®¼­
COHESIVE MECHANISM (ÀÀÁý·Â Àִ ¸ÞÄ¿´ÏÁò)
- GENERIC SUBDOMAIN°ú COHESIVE MECHANISM
- MECHANISMÀÌ CORE DOMAINÀÇ ÀϺÎÀΠ°æ¿ì
¼±¾ðÀû Çü½ÄÀÇ µð½ºÆ¿·¹À̼Ç
SEGREGATED CORE (ºÐ¸®µÈ ÇÙ½É)
- SEGREGATED CORE¸¦ ¸¸µå´Â µ¥ µå´Â ºñ¿ë
- ¹ßÀüÇϴ ÆÀÀÇ ÀÇ»ç°áÁ¤
ABSTRACT CORE (Ãß»óÈ­µÈ ÇÙ½É)
½ÉÃþ ¸ðµ¨ÀÇ µð½ºÆ¿·¹À̼Ç
¸®ÆÑÅ͸µÀÇ ´ë»ó ¼±ÅÃ

16Àå   ´ë±Ô¸ð ±¸Á¶
EVOLVING ORDER (¹ßÀüÇϴ Áú¼­)
SYSTEM METAPHOR (½Ã½ºÅÛ ÀºÀ¯)
- "¹Ì¼÷ÇÑ ÀºÀ¯"¿Í ±×°ÍÀÌ ÇÊ¿ä ¾ø´Â ÀÌÀ¯
RESPONSIBILITY LAYER (Ã¥ÀÓ °èÃþ)
- ÀûÀýÇÑ °èÃþÀÇ ¼±ÅÃ
KNOWLEDGE LEVEL (Áö½Ä ¼öÁØ)
PLUGGABLE COMPONENT FRAMEWORK (ÂøÅ»½Ä ÄÄÆ÷³ÍÆ® ÇÁ·¹ÀÓ¿öÅ©)
±¸Á¶´Â ¾ó¸¶³ª Á¦¾à¼ºÀ» Áö³à¾ß Çϴ°¡?
Àß ¸Â¾Æ¶³¾îÁö´Â ±¸Á¶¸¦ ÇâÇÑ ¸®ÆÑÅ͸µ
- ÃÖ¼ÒÁÖÀÇ
- ÀÇ»ç¼ÒÅë°ú ÀÚ±â ÈÆ·Ã
- À籸Á¶È­°¡ À¯¿¬ÇÑ ¼³°è¸¦ ³º´Â´Ù
- µð½ºÆ¿·¹À̼ÇÀº ºÎÇϸ¦ ÁÙÀδÙ

17Àå   Àü·«ÀÇ Á¾ÇÕ
´ë±Ô¸ð ±¸Á¶¿Í BOUNDED CONTEXT¿ÍÀÇ °áÇÕ
´ë±Ô¸ð ±¸Á¶¿Í µð½ºÆ¿·¹À̼ǰúÀÇ °áÇÕ
Æò°¡ ¸ÕÀú
´©°¡ Àü·«À» ¼¼¿ì´Â°¡?
- ¾ÖÇø®ÄÉÀ̼Ǡ°³¹ß¿¡¼­ Ã¢¹ßÇϴ ±¸Á¶
- °í°´(¾ÖÇø®ÄÉÀ̼Ǡ°³¹ßÆÀ) Áß½ÉÀÇ ¾ÆÅ°ÅØó ÆÀ
Àü·«Àû ¼³°è °áÁ¤À» À§ÇÑ 6°¡Áö Çʼö ¿ä¼Ò
- ±â¼ú ÇÁ·¹ÀÓ¿öÅ©µµ ¸¶Âù°¡Áö´Ù
- Á¾ÇÕ°èȹÀ» Á¶½ÉÇ϶ó

¢Ã °á·Ð

¸ÎÀ½¸»
¾ÕÀ» ³»´Ùº¸¸ç

ºÎ·Ï   À̠å¿¡ Æ÷ÇԵȠÆÐÅÏÀÇ »ç¿ë¹ý
ÆÐÅÏ À̸§

¿ë¾î ¼³¸í
Âü°í ¹®Çå
»çÁø ÇùÂù
ã¾Æº¸±â