Pha kiến trúc phần mềm

GS John Vu21/09/2023 10:00
Pha kiến trúc phần mềm

Một sinh viên hỏi: “Khác biệt gì giữa pha kiến trúc và pha thiết kế? Em bị lẫn lộn vì vòng đời phần mềm chỉ nhắc tới yêu cầu, thiết kế, viết mã và kiểm thử. Cái gì xảy ra trong pha thiết kế? Kiến trúc làm gì trong pha này? Xin thầy giải thích.”

Đáp: Về căn bản, pha kiến trúc là mức trừu tượng cao nhất của hệ thống phần mềm và pha thiết kế là mức thấp hơn hội tụ vào các chi tiết như mô đun và cấu phần. Kiến trúc là việc phân bổ các yêu cầu hệ thống (phần cứng, phần mềm, giao diện, v.v.) cho các cấu phần hệ thống cũng như giao diện giữa các cấu phần này. Thiết kế thường giải quyết với việc lập chức năng cho từng cấu phần một cách chi tiết hơn. Chẳng hạn, khi bạn xây ngôi nhà bạn cần kiến trúc sư để thiết kế mọi cấu phần của ngôi nhà như nền móng, trụ nhà, mái và tường nhưng bạn không cần kiến trúc sư để thiết kế bếp chi tiết hay phòng ngủ trong nhà. Những chi tiết này thường được trao cho công nhân xây dựng và người trang trí nội thất.

Khi bạn xây dựng một hệ thống phần mềm lớn và phức tạp, bạn cần phân chia hệ thống thành các cấu phần nhỏ hơn để dễ thực hiện hơn. Pha kiến trúc là bước bản chất để chắc các cấu phần được xác định và tương tác giữa chúng được nhận diện rõ ràng. Đôi khi mọi người coi pha kiến trúc là pha “thiết kế mức cao” và thiết kế là pha “thiết kế chi tiết”. Vòng đời thác đổ coi cả hai pha này đều là “thiết kế” để giữ cho nó đơn giản và dễ dàng hơn cho sinh viên học.

Vì phần lớn các dự án trong trường đều nhỏ và đơn giản nơi phần cứng và tương tác với phần mềm đã được biết, sinh viên không quan tâm tới phần cứng có thể bắt đầu từ pha thiết kế phần mềm. Tuy nhiên trong công nghiệp, phần lớn dự án phần mềm đều lớn và phức tạp và bạn cần biết mọi cấu phần của toàn thể hệ thống (cả phần cứng và phần mềm) cho nên bạn phải học về kiến trúc phần mềm cho tốt để xây dựng hệ thống có chất lượng.

Trong pha kiến trúc, bạn phải nhận diện hoàn cảnh và phạm vi của dự án bằng việc thiết lập biên giới dựa trên yêu cầu của khách hàng. Bạn cần xác định cả cách nhìn chức năng cũng như phi chức năng và mọi ràng buộc. Bạn cần nhận diện mọi cấu phần như cách nhìn qui trình, cách nhìn logic, cách nhìn vật lí, cách nhìn giao diện, cách nhìn kết cấu nền, cách nhìn vận hành và cách nhìn an ninh cho hệ thống phần mềm đầy đủ.

Phần lớn những người phát triển phần mềm thường chú ý tới các chức năng của hệ thống nhưng không chú ý tới cách nhìn phi chức năng (thuộc tính chất lượng). Bởi vì phần lớn các cách nhìn phi chức năng không được xác định rõ, dự án thường lâm vào vấn đề về sau vì đây là những điều khách hàng mong đợi nhưng hiếm khi nhắc tới trong các yêu cầu. Đây là chỗ những người phát triển có kinh nghiệm đang làm tốt hơn những người không có kinh nghiệm vì họ học nhiều năm làm việc bằng việc biết cái gì để hỏi khách hàng. Khách hàng có thể nói: “Hệ thống phải chạy nhanh “, đó là yêu cầu phi chức năng nhưng điều đó là quá mông lung.

Người phát triển có kinh nghiệm biết cách hỏi khách hàng về những chi tiết đặc biệt hơn để chắc yêu cầu này là đo được và kiểm thử được. (Ông muốn nhanh như thế nào? Ông ngụ ý gì bởi nhanh? Bao nhiêu giây? v.v.) Họ biết rằng để đạt tới sự thoả mãn của khách hàng họ cần chắc rằng tất cả các cách nhìn phi chức năng đều được xác định. Những điều này bao gồm các đặc trưng khi chạy như hiệu năng, tính đổi qui mô, tính sẵn có và tính an ninh v.v. Đó là lí do tại sao các kĩ sư yêu cầu là quan trọng thế trong hệ thống lớn hơn và phức tạp để xác định các yêu cầu phi chức năng này.

Bởi vì phần lớn các yêu cầu phi chức năng đều là vấn đề hệ thống, pha kiến trúc phải nhận diện chúng cũng như xác định tương tác giữa chúng kiểu như khi xây nhà kiến trúc sư phải tính toán sức mạnh của móng và tất cả các cột giữ cho ngôi nhà đứng tại chỗ. Chẳng hạn, nhà lớn hơn yêu cầu nền móng tốt hơn và nhiều cột để đỡ trọng lượng của ngôi nhà. Bởi lí do này pha kiến trúc là quan trọng trong các hệ thống lớn. Khi mọi yêu cầu chức năng và phi chức năng được xác định, bước tiếp là hội tụ vào cách từng cấu phần được thực hiện. Trong pha này, kiến trúc sư phần mềm quyết định về công nghệ nào được dùng, cấu phần nào được xây dựng trong nhà, cấu phần nào được mua từ nhà cung cấp, cấu phần nào có thể được khoán ngoài.

Họ phải ra quyết định dựa trên các yếu tố như chi phí, cấp phép, quan hệ với nhà cung cấp, tính tương hợp, tính liên tác, sự hỗ trợ và môi trường người dùng v.v. Những quyết định này là sống còn cho thành công của dự án bởi vì chúng là rủi ro mà phải giải quyết. Kiến trúc sư phần mềm phải giảm rủi ro chỗ có độ phức tạp hay bất định cao bằng việc tiến hành phân tích bù trừ để quản lí rủi ro và phải chắc dự án có thể được thực hiện bên trong chi phí và lịch biểu. Mọi quyết định đều phải được kiểm điểm và đánh giá bởi kiến trúc sư, người lãnh đạo tổ, người quản lí dự án và khách hàng.

Vấn đề chính với hệ thống phần mềm lớn và phức tạp là ở chỗ khó cho mọi người hiểu làm sao những cấu phần này làm việc cùng nhau. Đó là lí do tại sao kiến trúc sư phần mềm phải dùng công cụ như các biểu đồ theo ngôn ngữ mô hình hoá thống nhất – Unified Modeling Language (UML) để truyền đạt kiến trúc cho người khác. Kiểm điểm của kiến trúc sư là chỗ mà tổ dự án, tổ hỗ trợ (đảm bảo chất lượng phần mềm SQA và quản lí cấu hình phần mềm SCM, chuyên gia cơ sở dữ liệu, chuyên gia an ninh v.v.) cũng như cấp quản lí và khách hàng phải tham gia vào để hiểu cách toàn thể hệ thống sẽ làm việc.

Kiến trúc sư phần mềm phải chắc rằng kiến trúc được xác định là được hiểu bởi mọi người tham gia. Tất nhiên, tổ phát triển phải hiểu chúng vì họ sẽ phải thiết kế và thực hiện từng cấu phần nhưng tổ hỗ trợ cũng phải biết rõ kiến trúc. Người quản lí cấu hình phải đặt tuyến cơ sở để đảm bảo rằng mọi thay đổi đều trong kiểm soát. Đảm bảo chất lượng phải kiểm điểm mọi cấu phần kiến trúc và phải chắc rằng chúng tuân thủ theo chuẩn và thủ tục. Chuyên gia an ninh phải chắc rằng kiến trúc đã lấy các bước cần thiết để đảm bảo tính toàn vẹn của hệ thống v.v.

Nếu kiến trúc được chấp thuận, bước tiếp là phân công các thành viên tổ bắt đầu qui trình thiết kế cho từng cấu phần. Mặc dầu kiến trúc sư không tham gia vào trong thiết kế và viết mã cho các nhiệm vụ, nhưng người đó phải tích cực giúp các thành viên tổ để chắc rằng họ đang làm nó đúng bên trong kiến trúc đã xác định. Về căn bản pha kiến trúc là quan trọng nhất trong dự án phần mềm lớn. Nếu nó được làm tốt, sẽ có ít vấn đề về sau nhưng nếu nó không được xác định tốt, cơ hội để dự án thất bại có thể rất cao.

Một kiến trúc được xác định kém sẽ dẫn tới thiết kế dở và thiết kế dở sẽ dẫn tới dự án thất bại và đó là lí do tại sao nhiều dự án phần mềm thất bại. Chúng không bao giờ thất bại vì việc viết mã nhưng bởi vì thiết kế dở và kiến trúc được xác định nghèo nàn. Đó là lí do tại sao tôi nghĩ kĩ nghệ phần mềm bao quát mọi pha của phát triển phần mềm là được cần cho mọi sinh viên phần mềm.


Gửi bình luận
(0) Bình luận
1

Nhu cầu cấp bách

Tuần trước, tôi đã viết về vài “khu vực nóng” trong thị trường công nghệ và tôi tin nền di động sẽ là một trong chúng trong vài năm tới.
2

Phần mềm di động

Phát triển ứng dụng di động là qui trình qua đó phần mềm được phát triển cho điện thoại di động hay thiết bị cầm tay tương tự.
3

Kinh nghiệm của kỹ sư phần mềm

“Em đã làm năm việc trong ba năm. Chẳng có gì để tự hào nhưng hồi tưởng lại, em đã học được bài học tốt và đó là lí do tại sao em quay lại thăm thầy.”
4

Lời khuyên từ bạn bè

Năm ngoái, một sinh viên năm thứ nhất nói với tôi trong ngày đầu tiên lên lớp: “Thầy nói cứ như là bố mẹ em nói, học, học và học nữa. Cuộc sống KHÔNG chỉ là học tập và là sinh viên đại học, em KHÔNG cần những lời khuyên có vẻ như của bố mẹ thế.”
5

Khu vực nào sẽ nóng

Tuần trước, một sinh viên năm thứ nhất ở Trung Quốc hỏi tôi: “Công nghệ thông tin là lĩnh vực lớn với nhiều miền đặc biệt. Em nên tập trung vào miền nào để khi em tốt nghiệp trong bốn năm nữa kể từ bây giờ, em sẽ có khả năng có việc làm tốt? Nếu em muốn làm việc ở Mĩ hay châu Âu tôi cần làm gì khác nữa?”

Dự báo cho năm 2014 - Vẫn còn nguyên giá trị

Chúng ta đang sống trong thế giới thay đổi nhanh chóng nơi công nghệ chi phối mọi thứ. Khi công nghệ thay đổi, nó tạo ra nhiều thách thức cho cả công ti và công nhân.

Vòng đời kiểm thử phần mềm

Một sinh viên viết cho tôi: “Trường em đang dạy vòng đời phát triển phần mềm nhưng bạn em nhắc rằng có vòng đời kiểm thử phần mềm mà em không thể tìm được nó trong sách giáo khoa. Nó là gì? Thầy có thể giúp em được không?”

Thư cho sinh viên đại học: Cần được chuẩn bị

Là sinh viên đại học, các bạn cần biết rằng vào đại học chỉ mới là bắt đầu; tốt nghiệp được là một thành tựu, nhưng bằng cấp không tương đương với thành công nếu bạn không thể tìm được việc làm liên quan tới điều bạn đã học.

Học về khoa học dữ liệu

“Em mê mải bài báo của thầy về dữ liệu lớn và muốn học thêm về nó. Là một sinh viên năm thứ nhất trong quản lí hệ thông tin, em không biết đây có phải là lĩnh vực đúng để học hay em phải chuyển sang khoa học máy tính?"

Phụ nữ trong công nghệ thông tin

"Em hiện đang học Quản lí hệ thông tin (ISM) nơi phần lớn các sinh viên đều là nam và họ bảo em rằng việc quản lí CNTT khó cho phụ nữ. Thầy nghĩ gì? Xin thầy lời khuyên.”

Big Data trong doanh nghiệp bán lẻ

Trong nhiều năm, những người chủ cửa hàng bao giờ cũng hỏi: “Trong số hàng nghìn người vào cửa hàng của tôi, ai là khách hàng tốt. Và họ sẵn lòng trả bao nhiêu tiền?”

Big data trong xét tuyển vào đại học

Tôi mới đọc một bài báo thú vị rằng một số đại học đang dùng công nghệ Big Data trong việc xét tuyển vào trường của họ.

Muốn học lấy bằng thạc sĩ

Một người mẹ viết cho tôi: “Câu hỏi của tôi là: Để hoàn thành chương trình thạc sĩ phải mất bao lâu? Kiểu việc làm nào nó có thể có được với bằng thạc sĩ? Nó có thể kiếm được bao nhiêu, nếu nó làm việc ở Mĩ?”

Làm chủ ai -  Sách dành cho người muốn tìm hiểu về trí tuệ nhân tạo

Kể từ khi ChatGPT ra mắt, dường như ngày nào chúng ta cũng nghe nhắc đến AI và cách nó làm thay đổi thế giới xung quanh. Vậy rốt cuộc những công cụ này hoạt động ra sao? Và một người bình thường có thể sử dụng AI như thế nào? Quyển sách này sẽ giúp bạn trả lời những câu hỏi đó.

Một số sự kiện về cách tiếp cận Agile

Blog GS John VU - GS John Vu - 30/05/2026 12:00
Một sinh viên hỏi tôi: “Nếu Agile là cách tiếp cận tốt để phát triển phần mềm thì tại sao chúng ta phải học cách tiếp cận khác?”

Anthropic ra mắt "trợ lý AI ngành luật", thu hút hơn 20.000 người đăng ký

Kỹ năng - Lại Dịu - 30/05/2026 11:00
Anthropic đang biến Claude thành “trợ lý pháp lý AI” có thể kết nối trực tiếp với các phần mềm luật chuyên dụng, làm nóng thêm cuộc đua AI trong ngành pháp lý.

“Thần kinh doanh” Kazuo Inamori: Nếu không tài năng, cần biết 1 con đường “lợi hại” này để làm giàu

Suy ngẫm - Kim Linh - 30/05/2026 10:00
Theo tỷ phú Nhật Bản Inamori Kazuo, muốn trở thành một người giàu có và thành công cần có sự kiên nhẫn phi thường trong công việc.

Từ chiếc máy tính cũ, nam sinh Bách khoa thắng lớn với “Tiệm phở anh Hai”

Truyền cảm hứng - Mỹ Hà - 30/05/2026 09:00
Từ chiếc máy tính cũ và những dự án trò chơi âm thầm suốt nhiều năm, nam sinh Đại học Bách khoa Hà Nội tạo nên “cơn sốt” với “Tiệm phở anh Hai”, đồng thời thắng lớn hai giải thưởng.

Làm chủ ai -  Sách dành cho người muốn tìm hiểu về trí tuệ nhân tạo

Từ sách - Phim - Thu An - 30/05/2026 08:00
Kể từ khi ChatGPT ra mắt, dường như ngày nào chúng ta cũng nghe nhắc đến AI và cách nó làm thay đổi thế giới xung quanh. Vậy rốt cuộc những công cụ này hoạt động ra sao? Và một người bình thường có thể sử dụng AI như thế nào? Quyển sách này sẽ giúp bạn trả lời những câu hỏi đó.

Hệ thống giáo dục mới

Blog GS John VU - GS John Vu - 29/05/2026 12:00
Tôi để ba tuần giảng dạy ở Trung Quốc.

Lời khuyên cho tất cả những ai hay dùng ChatGPT tìm kiếm thông tin

Kỹ năng - Nhật Hạ - 29/05/2026 11:00
Để tận dụng AI hiệu quả mà vẫn an toàn, người dùng nên lưu ý một số điều dưới đây.

6 cách giúp bạn tăng cường từ trường cá nhân nhanh nhất, càng thực hiện đều may mắn đổ về càng nhiều

Suy ngẫm - Diêu Dương - 29/05/2026 10:00
Muốn gặp người tốt, cơ hội đẹp và chuyện thuận lợi hơn. Hãy bắt đầu bằng việc chỉnh lại từ trường cá nhân của chính mình. Sáu thói quen sau đây dễ làm, chi phí gần như bằng không nhưng hiệu quả thì thấy rõ từng ngày.

Hà Nội, một gia đình chi hơn 2 tỷ đồng làm “nhà di động” xuyên Việt 3-5 lần/năm

Phong cách sống - Mộc Khải - 29/05/2026 09:00
Năm 2022, khi mô hình du lịch bằng "nhà di động" còn khá mới ở Việt Nam, anh Nguyễn Ngọc Thắng (Hà Nội) đã bắt đầu tự cải tạo một chiếc xe 16 chỗ thành “nhà di động” đầu tiên của gia đình.

Không khóc giữa nhân gian

Tủ sách - FN - 29/05/2026 08:00
Đau khổ vốn không trừ một ai, và nó có trăm hình vạn trạng: một sự mất mát, cảm giác cô độc giữa đám đông, hay đơn giản là nỗi thất vọng khi không đạt được thứ mà mình mong chờ. Vậy phải làm sao để ta hết khổ? Đau khổ có thực sự đáng sợ như người ta vẫn nghĩ? Hay chúng ta vẫn có thể nhìn đau khổ dưới một góc độ bao dung hơn?

Phần mềm di động

Blog GS John VU - GS John Vu - 28/05/2026 12:00
Phát triển ứng dụng di động là qui trình qua đó phần mềm được phát triển cho điện thoại di động hay thiết bị cầm tay tương tự.

WhatsApp biến phòng chat AI thành khu vực "bất khả xâm phạm", Mark Zuckerberg muốn đọc cũng phải bó tay!

Kỹ năng - Anh Phương - 28/05/2026 11:00
Với chế độ ẩn danh sắp ra mắt trên WhatsApp, CEO Mark Zuckerberg khẳng định đây là sản phẩm AI lớn đầu tiên trên thế giới hoàn toàn không lưu trữ lịch sử hội thoại trên máy chủ nhằm bảo vệ quyền riêng tư tuyệt đối cho người dùng.

Bậc thầy EQ luôn mang theo 8 chữ: Chính Lưu Bị cũng ‘giắt túi’ để tránh tai hoạ

Suy ngẫm - Diệu Đan - 28/05/2026 10:00
Khi đối mặt với những lời khiêu khích và lăng mạ, ông điềm đạm, không tranh hơn thua. Khi đối mặt với những lợi nhuận nhỏ và những cám dỗ, ông bình tĩnh không tranh hơn thiệt. Ấy chính là cách đối đãi của bậc cao thủ!

“Thế hệ dâu tây”: Đi làm mệt quá thì nghỉ, việc khó quá không làm nữa là xong

Phong cách sống - Ngọc Linh - 28/05/2026 09:00
Khả năng chịu khổ và vượt khó “bằng 0”.

Minh triết từ nỗi bất an: Cái nhìn sáng suốt về sự bất định của đời sống

Từ sách - Phim - Minh Hằng - 28/05/2026 08:00
Giữa một thế giới đầy rẫy những biến động khó lường, "Minh triết từ nỗi bất an" nhắc nhở chúng ta rằng điểm tựa vững chắc, kiên cố nhất của một con người không bao giờ nằm ở một thế giới vật chất bên ngoài, mà ở ngay khả năng dũng cảm hòa mình vào dòng chảy của hiện tại, bởi vì ngay trong chính sự vô định đó, bạn sẽ tìm thấy sự tự do đích thực của tâm hồn.
HẠT GIỐNG TÂM HỒN
2019 Bản quyền thuộc về hatgiongtamhon.com.vn. Phát triển bởi ONECMS