หลักการสำคัญ

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

รูปแบบสถาปัตยกรรม

architectural styleหรือเรียกอีกอย่างว่า architectural patternคือชุดของหลักการที่กำหนดรูปแบบแอปพลิเคชัน เป็นการกำหนดกรอบนามธรรมสำหรับครอบครัวของระบบในแง่ของรูปแบบของโครงสร้างองค์กร

รูปแบบสถาปัตยกรรมมีหน้าที่ -

  • ให้คำศัพท์เกี่ยวกับส่วนประกอบและตัวเชื่อมต่อพร้อมกฎว่าจะรวมกันได้อย่างไร

  • ปรับปรุงการแบ่งพาร์ติชันและอนุญาตให้ใช้การออกแบบซ้ำได้โดยให้แนวทางแก้ไขปัญหาที่เกิดขึ้นบ่อยครั้ง

  • อธิบายวิธีการกำหนดค่าชุดส่วนประกอบ (โมดูลที่มีอินเทอร์เฟซที่กำหนดไว้อย่างดีใช้ซ้ำได้และเปลี่ยนได้) และตัวเชื่อมต่อ (การเชื่อมโยงการสื่อสารระหว่างโมดูล)

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

  • ชุดของประเภทส่วนประกอบที่ทำหน้าที่ตามที่ระบบต้องการ

  • ชุดตัวเชื่อมต่อ (การเรียกรูทีนย่อยการเรียกโพรซีเดอร์ระยะไกลสตรีมข้อมูลและซ็อกเก็ต) ที่เปิดใช้งานการสื่อสารการประสานงานและความร่วมมือระหว่างส่วนประกอบต่างๆ

  • ข้อ จำกัด เชิงความหมายซึ่งกำหนดวิธีรวมส่วนประกอบเพื่อสร้างระบบ

  • เค้าโครงทอพอโลยีของส่วนประกอบที่ระบุความสัมพันธ์ระหว่างรันไทม์

การออกแบบสถาปัตยกรรมทั่วไป

ตารางต่อไปนี้แสดงรูปแบบสถาปัตยกรรมที่สามารถจัดระเบียบตามพื้นที่โฟกัสหลัก -

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

ประเภทของสถาปัตยกรรม

มีสถาปัตยกรรมสี่ประเภทจากมุมมองขององค์กรและโดยรวมแล้วสถาปัตยกรรมเหล่านี้เรียกว่า enterprise architecture.

  • Business architecture - กำหนดกลยุทธ์ของธุรกิจการกำกับดูแลองค์กรและกระบวนการทางธุรกิจที่สำคัญภายในองค์กรและมุ่งเน้นไปที่การวิเคราะห์และออกแบบกระบวนการทางธุรกิจ

  • Application (software) architecture - ทำหน้าที่เป็นพิมพ์เขียวสำหรับระบบแอปพลิเคชันแต่ละระบบการโต้ตอบและความสัมพันธ์กับกระบวนการทางธุรกิจขององค์กร

  • Information architecture - กำหนดสินทรัพย์ข้อมูลเชิงตรรกะและทางกายภาพและทรัพยากรการจัดการข้อมูล

  • Information technology (IT) architecture - กำหนดโครงสร้างฮาร์ดแวร์และซอฟต์แวร์ที่ประกอบเป็นระบบข้อมูลโดยรวมขององค์กร

กระบวนการออกแบบสถาปัตยกรรม

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

  • ข้อกำหนดที่ผลิตโดยงานวิเคราะห์

  • สถาปัตยกรรมฮาร์ดแวร์ (สถาปนิกซอฟต์แวร์จะให้ข้อกำหนดแก่สถาปนิกระบบซึ่งเป็นผู้กำหนดค่าสถาปัตยกรรมฮาร์ดแวร์)

ผลลัพธ์หรือผลลัพธ์ของกระบวนการออกแบบสถาปัตยกรรมคือ architectural description. ขั้นตอนการออกแบบสถาปัตยกรรมพื้นฐานประกอบด้วยขั้นตอนต่อไปนี้ -

ทำความเข้าใจกับปัญหา

  • นี่เป็นขั้นตอนที่สำคัญที่สุดเนื่องจากมีผลต่อคุณภาพของการออกแบบที่ตามมา

  • หากไม่มีความเข้าใจที่ชัดเจนเกี่ยวกับปัญหาก็จะไม่สามารถสร้างวิธีแก้ปัญหาที่มีประสิทธิภาพได้

  • โครงการซอฟต์แวร์และผลิตภัณฑ์จำนวนมากถือว่าล้มเหลวเนื่องจากไม่ได้แก้ปัญหาทางธุรกิจที่ถูกต้องหรือมีผลตอบแทนจากการลงทุน (ROI) ที่เป็นที่รู้จัก

ระบุองค์ประกอบการออกแบบและความสัมพันธ์

  • ในขั้นตอนนี้สร้างพื้นฐานสำหรับการกำหนดขอบเขตและบริบทของระบบ

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

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

ประเมินการออกแบบสถาปัตยกรรม

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

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

  • หากแอตทริบิวต์คุณภาพโดยประมาณทั้งหมดเป็นไปตามมาตรฐานที่กำหนดกระบวนการออกแบบสถาปัตยกรรมจะเสร็จสิ้น

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

พลิกโฉมการออกแบบสถาปัตยกรรม

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

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

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

  • การออกแบบจะได้รับการประเมินอีกครั้งและกระบวนการเดียวกันจะทำซ้ำหลาย ๆ ครั้งหากจำเป็นและแม้กระทั่งดำเนินการซ้ำ

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

หลักการสถาปัตยกรรมที่สำคัญ

ต่อไปนี้เป็นหลักการสำคัญที่ต้องพิจารณาในขณะออกแบบสถาปัตยกรรม -

สร้างเพื่อเปลี่ยนแปลงแทนที่จะสร้างเป็นสุดท้าย

พิจารณาว่าแอปพลิเคชันอาจต้องเปลี่ยนแปลงอย่างไรเมื่อเวลาผ่านไปเพื่อตอบสนองความต้องการและความท้าทายใหม่ ๆ และสร้างความยืดหยุ่นเพื่อรองรับสิ่งนี้

ลดความเสี่ยงและโมเดลในการวิเคราะห์

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

ใช้โมเดลและการแสดงภาพเป็นเครื่องมือการสื่อสารและการทำงานร่วมกัน

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

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

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

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

หลักการออกแบบที่สำคัญ

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

การแยกความกังวล

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

หลักการความรับผิดชอบเดียว

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

หลักการของความรู้น้อยที่สุด

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

ลดการออกแบบขนาดใหญ่ล่วงหน้า

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

อย่าทำซ้ำฟังก์ชันการทำงาน

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

ชอบองค์ประกอบมากกว่าการสืบทอดในขณะที่ใช้ฟังก์ชันการทำงานซ้ำ

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

ระบุส่วนประกอบและจัดกลุ่มใน Logical Layers

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

กำหนดโปรโตคอลการสื่อสารระหว่างเลเยอร์

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

กำหนดรูปแบบข้อมูลสำหรับเลเยอร์

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

ส่วนประกอบของบริการระบบควรเป็นนามธรรม

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

การออกแบบข้อยกเว้นและกลไกการจัดการข้อยกเว้น

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

หลักการตั้งชื่อ

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