VCS Là Gì, VCS Tập Trung và VCS Phân Tán Khác Nhau Như Thế Nào

Chúng tôi rất vui mừng chia sẻ kiến thức sâu sắc về từ khóa Vcs la gi để tối ưu hóa nội dung trang web và tiếp thị trực tuyến. Bài viết cung cấp phương pháp tìm kiếm, phân tích từ khóa và chiến lược hiệu quả. Cảm ơn sự quan tâm và hãy tiếp tục theo dõi để cập nhật kiến thức mới.

Trước lúc tìm hiểu về Git bạn cần phải nắm vững về thuật ngữ Version Control System (VCS).

Bạn Đang Xem: VCS Là Gì, VCS Tập Trung và VCS Phân Tán Khác Nhau Như Thế Nào

VCS Là Gì

VCS viết tắt của Version Control System là một loại phần mềm giúp tất cả chúng ta quản lý sự thay đổi trong source code của dự án theo thời kì một cách dễ dàng và thuận tiện.

VCS lưu trữ mọi sự thay đổi trong source code của dự án trong một cơ sở tài liệu đặc biệt quan trọng. Tất cả chúng ta có thể dễ ràng truy vấn ra được sự thay đổi của source code trong một file tại một thời khắc bất kỳ. Và nếu cần tất cả chúng ta có thể dễ dàng đảo ngược source code trong file trở về một thời khắc trước đó.

Lưu ý: Hai thuật ngữ VCS (Version Control System) và SCM (Source Code Management) được sử dụng thay thế lẫn nhau.

Tại Sao Cần Sử Dụng VCS

VCS đặc biệt quan trọng hữu dụng trong các dự án lớn yên cầu sự tham gia của nhiều lập trình viên. Ví dụ tại cùng một thời khắc, tất cả chúng ta cần phát triển thêm nhiều feature (tính năng) mới cho phần mềm. Và mỗi thành viên trong team được phân công để phát triển một feature. Khi có hai thành viên cùng hoàn thành xong hai feature riêng biệt cùng lúc thì khi đó việc merge (gộp) code lại sở hữu thể sẽ gây nên ra conflict (xung đột) vì hai người này còn có thể sửa đổi cùng một đoạn code trên cùng một file.

Xem Thêm : Quy định về cam kết tín dụng của nhà thầu trong đấu thầu

Lúc này sử dụng VCS tất cả chúng ta có thể dễ dàng kiểm tra được sự thay đổi nào tới từ ai và cho feature nào.

VCS Phân Tán và VCS Tập Trung

Dự Theo phong cách thiết kế thì VCS được chia thành hai kiểu khác nhau đó là VCS tập trung (centralized) và VCS phân tán (distributed).

Với những VCS dạng tập trung thì source code của dự án sẽ tiến hành lưu trữ trên một kho tập trụng (hay kho trung tâm) trên một sever. Mỗi lập trình viên muốn tạo ra sự thay đổi cho source code lưu trữ trong kho trung tâm trung (centralized repository) thì họ cần phải thực hiện một công việc trước đó là update source code trên máy tính của họ với kho tập trung trước sau đó mới được thay đổi.

Cùng tham khảo ví dụ sau đây để bạn cũng có thể nắm vững sự khác biệt giữa hai kiểu VCS tập trung và VCS phân tán.

Trong dự ánh đang sẵn có bốn anh A, B, C và D cùng làm và source code dự án này được quản lý bởi một phần mềm VCS tập trung tên là Subversion (hay SVN).

Vào 08:00:00 ngày hôm nay lập trình viên A lên đơn vị mở máy tính ra và update code trên máy tính của anh ta để đồng bộ với code lưu trữ trên kho tập trung. Sau đó anh A khai mạc code để fix một lỗi mà anh ta tìm thấy ngày hôm qua. Anh A code rất nhanh nên chỉ có thể mất 15 phút để sửa lỗi và để sửa lỗi này A đã phải thay đổi nội dung của 50 file khác nhau trong source code.

Xem Thêm : Độ sâu màu 8 bit hoặc 10 bit, 12 bit,… là gì ? Điều này ảnh hưởng gì đến khả năng hiển thị của màn hình laptop ? Leave a comment

Và sau đó anh này đấy (push) code mới của anh ta lên kho tập trung. Do chưa xuất hiện ai thay đổi code trên kho tập trung nên thay đổi của anh ta được thông qua và code trên kho tập trung được update.

Vào lúc 08:30:00 ba anh B, C và D lên đơn vị và mở máy tính để tiếp tục code 3 feature khác nhau và cũng tương đối quan trọng của dự án.

Lúc 08:50:00 khi anh B tạo một phiên bản mới cho source code của mình và với VCS dạng tập trung thì điều này buộc anh phải update code trên máy của anh ta với kho tập trung trên server trước lúc có thể tạo ra version mới. Tuy nhiên khi update code trên kho thì anh này gặp phải lỗi xung đột nội dung do anh ta đã thay đổi 10 file mà anh A đã thay đổi lúc 08:15:00 và đấy lên kho tập trung.

Lúc 09:15:00 khi anh C và anh D cũng muốn tạo một phiên bản mới cho source code và cũng gặp phải lỗi tương tự như anh B do đã sửa các file mà anh A đã và đang sửa trước đó.

Như vậy để giải quyết và xử lý xung đột thì từng B, C và D lúc này mỗi người cũng phải xem lại thay đổi source code của mình và của anh A để tránh xoá nhầm code tạo thêm bug mới.

Trái lại với VCS dạng phân tán thì mỗi lập trình viên sẽ có được riêng một kho (repository) của mình và có thể tự do phát triển khác feature và tạo version mới (hay đúng hơn là một commit) mà không nhất thiết phải đồng bộ với kho trên server. Điều này sẽ giúp lập trình viên tập trung vào việc hoàn thành feature hay fix bug mà không cần lo về việc phải liên tục update code trên máy tính của họ với code trên server để giảm thiểu xung đột. Việc xử lý xung đột (nếu có) sẽ tiến hành thực hiện một lần duy nhất.

You May Also Like

About the Author: v1000