Tiến trình CI/CD trong phần mềm và thực tế áp dụng cho ngành Network.


Trong kỹ thuật phần mềm, tiến trình CI/CD làm cho quá trình phát triển phần mềm nhanh hơn, thời gian release (ra đời) một sản phẩm được rút ngắn rất nhiều, nâng cao hiệu năng làm việc của developer. 

Vậy kỹ thuật CI/CD process là gì

CI viết tắt bởi Continuous Integration và CD viết tắt bởi Continuous delivery.

Liên tục tích hợp (CI) là quá trình diễn ra một cách liên tục không đứt quản trong phần việc develop --> testing --> build --> deploy. 

Liên tục chuyển giao(CD) là quá trình ra đời sản phầm một cách liên tục theo từng phiên bản của phần mềm. (versioning) làm phần mềm dần hoàn thiện hơn cho tới bản release chính thức.

Quá trình liên tục tích hợp(CD), cần có các thành phần : 

1. Nơi chứa source code của nhà phát triển có thể là các phần mềm như: github, gutlab, bitbucket, ....

2. Tiến trình testing phần mềm : chạy các unit test cũng như các thông số quét mã nguồn để tìm các lỗi bảo mật, lỗi code lặp lại, ..v.v.. 

3. Môi trường build sản phẩm;  là môi trường mà khi ra đời một sản phẩm phần mềm, sản phẩm đó chạy trên môi trường đó, ví dụ như môi trường Windows, Linux, iOS và Android.

4. Môi trường triển khai sản phẩm; 

    + Môi trường develop - môi trường dành cho nhà phát triển, 

    + Môi trường qc - môi trường dành cho bộ phận kiểm thử phần mềm, 

    + Môi trường staging - môi trường dành cho khách hàng; người thuê viết phần mềm 

    + Môi trường production - môi trường dành cho công đồng người dùng

What are the differences between continuous integration, continuous delivery, and continuous deployment? | Atlassian CI/CD

Khái niệm Continuous trong kỹ thuật này là tính liên tục của quá trình và xảy ra một các tự động. 

Để tối ưu quá trình làm việc của một developer thì khi developer merge code lên nhánh ấn định sẵn (ví dụ nhánh develop) thì tiến trình test và build xảy ra ngay tức thì và tự động. 

Nếu build và deploy thành công thì ta có một phiên bản phầm mềm ngay lúc đó (version). Các version được tạo ra và tăng lên tương ứng với qúa trình pháp triển phầm mềm của các developer. 

Bốn thành phần trên được liên kết với nhau một cách tự động; ví dụ áp dụng kỹ thuật webhook từ bitbucket trigger lên  Jenkins CI/CD để chạy, quá trình chạy phân ra các giai đoạn như: Pre-Build, Build và Post Build. 

Áp dụng tiến trình CI/CD trong network:

Sự phát triển mạnh mẽ của ngành network đòi hỏi áp dụng kỹ thuật mới cho các Network Engineer. Các Network Engineer ngày nay đòi hỏi làm viêc như một developer, Network Engineer không cần thiết phải xuống tận nơi thiết bị để cấu hình, và Network Engineer có thể cấu hình cùng một lúc nhiều thiết bị khác nhau thông qua bộ CI/CD này. 

Tiến trình CI/CD pipeline trong network xảy ra như sau: 

    1. Network Engineer đẩy một cấu hình lên git repository. (nơi chưa source code)

    2. Repository kiểm tra syntax và sự hợp lệ của cấu hình. 

    3. CI/CD sẽ chuẩn bị môi trường để test và build. Trong network sẽ test và build dựa trên Ansible-playbook. 

    4. Nhận thông báo build thành công hay thất bại trả về khi cấu hình được chạy. 


Kết luận

Nếu so sánh tiến trình CI/CD trong ngành kỹ thuật mạng và CI/CD trong kỹ thuật phần mềm thì hầu như giống nhau, chỉ khác nhau kỹ thuật mạng dùng bộ ansible để deploy lên các thiết bị mạng, trong khi kỹ thuật phầm mềm dùng các công cụ phù hợp với ngôn ngữ phần mềm để test và deployment. 

* developer : nhân viên phát triển phần mềm

* develop : phát triển phần mềm.

* testing: quá trình kiểm thử phần mềm.

* build : xây dựng một phần mềm.

* deploy: triển khai phần mềm. 

* source code : mã nguồn phần mềm.

* merge code: quá trình tích hợp một sự thay đổi mã code vào nhánh chính 


Nhận xét

Bài đăng phổ biến từ blog này

Cách sử dụng sys.argv trong python.

Trang web medium.com chết, vì sao ?

Thiết kế một RESTful API bằng python và flask.