เทคนิคสถาปัตยกรรม

วิธีการทำซ้ำและเพิ่มหน่วย

เป็นแนวทางที่ทำซ้ำและเพิ่มขึ้นซึ่งประกอบด้วยห้าขั้นตอนหลักที่ช่วยในการสร้างโซลูชันสำหรับผู้สมัคร โซลูชันสำหรับผู้สมัครนี้สามารถปรับปรุงเพิ่มเติมได้โดยการทำซ้ำขั้นตอนเหล่านี้และสุดท้ายสร้างการออกแบบสถาปัตยกรรมที่เหมาะกับการใช้งานของเรามากที่สุด ในตอนท้ายของกระบวนการเราสามารถตรวจสอบและสื่อสารสถาปัตยกรรมของเรากับผู้ที่สนใจทั้งหมดได้

เป็นเพียงแนวทางหนึ่งที่เป็นไปได้ มีแนวทางที่เป็นทางการอื่น ๆ อีกมากมายที่กำหนดตรวจสอบและสื่อสารสถาปัตยกรรมของคุณ

ระบุเป้าหมายสถาปัตยกรรม

ระบุเป้าหมายสถาปัตยกรรมที่สร้างสถาปัตยกรรมและกระบวนการออกแบบ วัตถุประสงค์ที่กำหนดไว้อย่างไม่มีที่ติจะเน้นที่สถาปัตยกรรมแก้ปัญหาที่เหมาะสมในการออกแบบและช่วยในการพิจารณาว่าเมื่อใดที่เฟสปัจจุบันเสร็จสมบูรณ์และพร้อมที่จะก้าวไปสู่เฟสถัดไป

ขั้นตอนนี้ประกอบด้วยกิจกรรมต่อไปนี้ -

  • ระบุเป้าหมายสถาปัตยกรรมของคุณตั้งแต่เริ่มต้น
  • ระบุผู้บริโภคสถาปัตยกรรมของเรา
  • ระบุข้อ จำกัด

ตัวอย่างของกิจกรรมสถาปัตยกรรม ได้แก่ การสร้างต้นแบบเพื่อรับข้อเสนอแนะเกี่ยวกับ UI การประมวลผลคำสั่งซื้อสำหรับเว็บแอปพลิเคชันการสร้างแอปพลิเคชันการติดตามใบสั่งซื้อของลูกค้าและการออกแบบการพิสูจน์ตัวตนและสถาปัตยกรรมการอนุญาตสำหรับแอปพลิเคชันเพื่อดำเนินการตรวจสอบความปลอดภัย

สถานการณ์สำคัญ

ขั้นตอนนี้ให้ความสำคัญกับการออกแบบที่สำคัญที่สุด สถานการณ์คือคำอธิบายที่ครอบคลุมและครอบคลุมเกี่ยวกับการโต้ตอบของผู้ใช้กับระบบ

สถานการณ์สำคัญคือสถานการณ์ที่ถือเป็นสถานการณ์ที่สำคัญที่สุดสำหรับความสำเร็จของแอปพลิเคชันของคุณ ช่วยในการตัดสินใจเกี่ยวกับสถาปัตยกรรม เป้าหมายคือการบรรลุความสมดุลระหว่างวัตถุประสงค์ของผู้ใช้ธุรกิจและระบบ ตัวอย่างเช่นการพิสูจน์ตัวตนผู้ใช้เป็นสถานการณ์ที่สำคัญเนื่องจากเป็นจุดตัดของแอตทริบิวต์คุณภาพ (ความปลอดภัย) ที่มีฟังก์ชันการทำงานที่สำคัญ (วิธีที่ผู้ใช้เข้าสู่ระบบของคุณ)

ภาพรวมแอปพลิเคชัน

สร้างภาพรวมของแอปพลิเคชันซึ่งทำให้สถาปัตยกรรมสัมผัสได้มากขึ้นเชื่อมต่อกับข้อ จำกัด และการตัดสินใจในโลกแห่งความเป็นจริง ประกอบด้วยกิจกรรมดังต่อไปนี้ -

ระบุประเภทแอปพลิเคชัน

ระบุประเภทแอปพลิเคชันไม่ว่าจะเป็นแอปพลิเคชันบนมือถือไคลเอนต์ที่หลากหลายแอปพลิเคชันอินเทอร์เน็ตที่สมบูรณ์บริการเว็บแอปพลิเคชันหรือการรวมกันของประเภทเหล่านี้

ระบุข้อ จำกัด ในการปรับใช้

เลือกโทโพโลยีการปรับใช้ที่เหมาะสมและแก้ไขข้อขัดแย้งระหว่างแอปพลิเคชันและโครงสร้างพื้นฐานเป้าหมาย

ระบุรูปแบบการออกแบบสถาปัตยกรรมที่สำคัญ

ระบุรูปแบบการออกแบบสถาปัตยกรรมที่สำคัญเช่นไคลเอนต์ / เซิร์ฟเวอร์, เลเยอร์, ​​บัสข้อความ, การออกแบบที่ขับเคลื่อนด้วยโดเมนเป็นต้นเพื่อปรับปรุงการแบ่งพาร์ติชันและส่งเสริมการนำการออกแบบมาใช้ใหม่โดยการให้วิธีแก้ปัญหาที่เกิดขึ้นบ่อยๆ การใช้งานมักจะใช้รูปแบบผสมผสานกัน

ระบุเทคโนโลยีที่เกี่ยวข้อง

ระบุเทคโนโลยีที่เกี่ยวข้องโดยพิจารณาจากประเภทของแอปพลิเคชันที่เรากำลังพัฒนาตัวเลือกที่เราต้องการสำหรับโทโพโลยีการปรับใช้แอปพลิเคชันและรูปแบบสถาปัตยกรรม การเลือกใช้เทคโนโลยีจะถูกกำหนดโดยนโยบายขององค์กรข้อ จำกัด ของโครงสร้างพื้นฐานทักษะทรัพยากรและอื่น ๆ

ประเด็นสำคัญหรือจุดสำคัญ

ในขณะออกแบบแอปพลิเคชันฮอตสปอตเป็นโซนที่เกิดข้อผิดพลาดบ่อยที่สุด ระบุประเด็นสำคัญตามคุณลักษณะด้านคุณภาพและข้อกังวลด้านการตัดขวาง ปัญหาที่อาจเกิดขึ้น ได้แก่ การปรากฏตัวของเทคโนโลยีใหม่และข้อกำหนดทางธุรกิจที่สำคัญ

แอตทริบิวต์คุณภาพเป็นคุณลักษณะโดยรวมของสถาปัตยกรรมของคุณที่มีผลต่อพฤติกรรมรันไทม์การออกแบบระบบและประสบการณ์ของผู้ใช้ ข้อกังวลในการตัดขวางเป็นคุณสมบัติของการออกแบบของเราที่อาจนำไปใช้กับทุกชั้นส่วนประกอบและชั้นต่างๆ

สิ่งเหล่านี้เป็นส่วนที่เกิดความผิดพลาดในการออกแบบที่มีผลกระทบสูงบ่อยที่สุด ตัวอย่างของข้อกังวลในการตัดขวาง ได้แก่ การพิสูจน์ตัวตนและการอนุญาตการสื่อสารการจัดการการกำหนดค่าการจัดการข้อยกเว้นและการตรวจสอบความถูกต้องเป็นต้น

โซลูชั่นสำหรับผู้สมัคร

หลังจากกำหนดคีย์ฮอตสปอตแล้วให้สร้างสถาปัตยกรรมพื้นฐานเริ่มต้นหรือการออกแบบระดับสูงอันดับแรกจากนั้นเริ่มกรอกรายละเอียดเพื่อสร้างสถาปัตยกรรมผู้สมัคร

สถาปัตยกรรมของผู้สมัครรวมถึงประเภทของแอปพลิเคชันสถาปัตยกรรมการปรับใช้รูปแบบสถาปัตยกรรมทางเลือกเทคโนโลยีคุณลักษณะด้านคุณภาพและข้อกังวลในการตัดขวาง หากสถาปัตยกรรมของผู้สมัครเป็นการปรับปรุงก็สามารถกลายเป็นพื้นฐานที่สามารถสร้างและทดสอบสถาปัตยกรรมผู้สมัครใหม่ได้

ตรวจสอบการออกแบบโซลูชันของผู้สมัครกับสถานการณ์สำคัญและข้อกำหนดที่ได้กำหนดไว้แล้วก่อนที่จะทำตามวงจรซ้ำและปรับปรุงการออกแบบ

เราอาจใช้สไปค์ทางสถาปัตยกรรมเพื่อค้นหาพื้นที่เฉพาะของการออกแบบหรือเพื่อตรวจสอบแนวคิดใหม่ ๆ สไปค์ทางสถาปัตยกรรมเป็นต้นแบบการออกแบบซึ่งกำหนดความเป็นไปได้ของเส้นทางการออกแบบเฉพาะลดความเสี่ยงและกำหนดความเป็นไปได้ของแนวทางต่างๆอย่างรวดเร็ว ทดสอบการเพิ่มขึ้นอย่างรวดเร็วทางสถาปัตยกรรมกับสถานการณ์สำคัญและฮอตสปอต

รีวิวสถาปัตยกรรม

การทบทวนสถาปัตยกรรมเป็นงานที่สำคัญที่สุดเพื่อลดต้นทุนที่ผิดพลาดและค้นหาและแก้ไขปัญหาทางสถาปัตยกรรมโดยเร็วที่สุด เป็นวิธีที่ดีและคุ้มค่าในการลดต้นทุนโครงการและโอกาสที่โครงการจะล้มเหลว

  • ทบทวนสถาปัตยกรรมบ่อยครั้งในเหตุการณ์สำคัญของโครงการและเพื่อตอบสนองต่อการเปลี่ยนแปลงทางสถาปัตยกรรมที่สำคัญอื่น ๆ

  • วัตถุประสงค์หลักของการทบทวนสถาปัตยกรรมคือการกำหนดความเป็นไปได้ของสถาปัตยกรรมพื้นฐานและสถาปัตยกรรมของผู้สมัครซึ่งตรวจสอบสถาปัตยกรรมอย่างถูกต้อง

  • เชื่อมโยงข้อกำหนดด้านการใช้งานและคุณลักษณะด้านคุณภาพเข้ากับโซลูชันทางเทคนิคที่เสนอ นอกจากนี้ยังช่วยระบุปัญหาและรับรู้พื้นที่ที่ต้องปรับปรุง

การประเมินตามสถานการณ์เป็นวิธีการที่โดดเด่นในการตรวจสอบการออกแบบสถาปัตยกรรมซึ่งมุ่งเน้นไปที่สถานการณ์ที่สำคัญที่สุดจากมุมมองทางธุรกิจและมีผลกระทบมากที่สุดต่อสถาปัตยกรรมต่อไปนี้เป็นวิธีการทบทวนทั่วไป -

วิธีการวิเคราะห์สถาปัตยกรรมซอฟต์แวร์ (SAAM)

เดิมถูกออกแบบมาเพื่อประเมินความสามารถในการปรับเปลี่ยน แต่ต่อมาได้ถูกขยายออกไปสำหรับการตรวจสอบสถาปัตยกรรมที่เกี่ยวข้องกับคุณลักษณะด้านคุณภาพ

วิธีการวิเคราะห์การแลกเปลี่ยนทางสถาปัตยกรรม (ATAM)

เป็น SAAM เวอร์ชันที่ได้รับการขัดเกลาและได้รับการปรับปรุงซึ่งจะตรวจสอบการตัดสินใจทางสถาปัตยกรรมตามข้อกำหนดคุณลักษณะด้านคุณภาพและความพึงพอใจของเป้าหมายด้านคุณภาพ

การทบทวนการออกแบบที่ใช้งานอยู่ (ADR)

เหมาะที่สุดสำหรับสถาปัตยกรรมที่ยังไม่สมบูรณ์หรืออยู่ระหว่างดำเนินการซึ่งจะเน้นไปที่ชุดของปัญหาหรือแต่ละส่วนของสถาปัตยกรรมในแต่ละครั้งมากกว่าการตรวจสอบทั่วไป

บทวิจารณ์ที่ใช้งานอยู่ของการออกแบบระดับกลาง (ARID)

มันรวมแง่มุม ADR ของการตรวจสอบสถาปัตยกรรมที่กำลังดำเนินการโดยมุ่งเน้นไปที่ชุดของปัญหาและแนวทาง ATAM และ SAAM ของการทบทวนตามสถานการณ์โดยเน้นที่คุณลักษณะด้านคุณภาพ

วิธีการวิเคราะห์ต้นทุนผลประโยชน์ (CBAM)

มุ่งเน้นไปที่การวิเคราะห์ต้นทุนผลประโยชน์และผลกระทบของกำหนดการของการตัดสินใจทางสถาปัตยกรรม

Architecture Level Modifiability Analysis (ALMA)

ประมาณการความสามารถในการปรับเปลี่ยนสถาปัตยกรรมสำหรับระบบสารสนเทศทางธุรกิจ (BIS)

วิธีการประเมินสถาปัตยกรรมครอบครัว (FAAM)

โดยประมาณสถาปัตยกรรมตระกูลระบบสารสนเทศสำหรับการทำงานร่วมกันและความสามารถในการขยาย

การสื่อสารการออกแบบสถาปัตยกรรม

หลังจากเสร็จสิ้นการออกแบบสถาปัตยกรรมเราต้องสื่อสารการออกแบบกับผู้มีส่วนได้ส่วนเสียอื่น ๆ ซึ่งรวมถึงทีมพัฒนาผู้ดูแลระบบผู้ปฏิบัติงานเจ้าของธุรกิจและผู้ที่สนใจอื่น ๆ

มีหลายวิธีที่รู้จักกันดีในการอธิบายสถาปัตยกรรมให้กับผู้อื่นดังต่อไปนี้: -

4 + 1 รุ่น

แนวทางนี้ใช้ห้ามุมมองของสถาปัตยกรรมที่สมบูรณ์ สี่มุมมอง (ไฟล์logical view, ที่ process view, ที่ physical view, และ development view) อธิบายสถาปัตยกรรมจากแนวทางต่างๆ มุมมองที่ห้าแสดงสถานการณ์และกรณีการใช้งานสำหรับซอฟต์แวร์ ช่วยให้ผู้มีส่วนได้ส่วนเสียเห็นคุณลักษณะของสถาปัตยกรรมที่พวกเขาสนใจโดยเฉพาะ

ภาษาคำอธิบายสถาปัตยกรรม (ADL)

แนวทางนี้ใช้เพื่ออธิบายสถาปัตยกรรมซอฟต์แวร์ก่อนการติดตั้งระบบ กล่าวถึงข้อกังวลต่อไปนี้ - พฤติกรรมโปรโตคอลและตัวเชื่อมต่อ

ข้อได้เปรียบหลักของ ADL คือเราสามารถวิเคราะห์สถาปัตยกรรมเพื่อความสมบูรณ์ความสม่ำเสมอความคลุมเครือและประสิทธิภาพก่อนที่จะเริ่มใช้การออกแบบอย่างเป็นทางการ

การสร้างแบบจำลองที่คล่องตัว

แนวทางนี้เป็นไปตามแนวคิดที่ว่า“ เนื้อหาสำคัญกว่าการนำเสนอ” ช่วยให้มั่นใจได้ว่าแบบจำลองที่สร้างขึ้นนั้นเรียบง่ายและเข้าใจง่ายถูกต้องเพียงพอมีรายละเอียดและสอดคล้องกัน

เอกสารรุ่น Agile กำหนดเป้าหมายลูกค้าเฉพาะและตอบสนองความพยายามในการทำงานของลูกค้ารายนั้น ความเรียบง่ายของเอกสารช่วยให้มั่นใจได้ว่ามีการมีส่วนร่วมของผู้มีส่วนได้ส่วนเสียในการสร้างแบบจำลองของสิ่งประดิษฐ์

IEEE 1471

IEEE 1471 เป็นชื่อย่อของมาตรฐานที่รู้จักกันอย่างเป็นทางการในชื่อ ANSI / IEEE 1471-2000“ แนวทางปฏิบัติที่แนะนำสำหรับคำอธิบายสถาปัตยกรรมของ Software-Intensive Systems” IEEE 1471 ปรับปรุงเนื้อหาของคำอธิบายสถาปัตยกรรมโดยเฉพาะโดยให้ความหมายที่เฉพาะเจาะจงกับบริบทมุมมองและมุมมอง

ภาษาการสร้างแบบจำลองแบบรวม (UML)

แนวทางนี้แสดงถึงสามมุมมองของโมเดลระบบ functional requirements view (ข้อกำหนดการทำงานของระบบจากมุมมองของผู้ใช้รวมถึงกรณีการใช้งาน); the static structural view(วัตถุคุณลักษณะความสัมพันธ์และการดำเนินการรวมทั้งคลาสไดอะแกรม); และdynamic behavior view (การทำงานร่วมกันระหว่างอ็อบเจ็กต์และการเปลี่ยนแปลงสถานะภายในของอ็อบเจ็กต์รวมถึงลำดับกิจกรรมและไดอะแกรมสถานะ)