CI는 Countinuous Integration 즉, 지속적인 통합이라는 의미이다.
지속적인 통합이란, 어플리케이션의 새로운 코드 변경 사항이 정기적으로 빌드 및 테스트 되어 공유 레포지토리에 통합하는 것을 의미한다.
: 지속적으로 서비스해야하는 어플리케이션이나 현재 개발 중인 어플리케이션은 기능 추가 시마다 commit등 날려 레파지토리에 버전 업데이트를 하는데 다수의 개발자가 한 팀으로 작업할 경우 이 공유 레파지토리에 수많은 commit들이 쌓이게 된다. 이런 상황에 자동화 된 빌드&테스트는 원천 소스코드의 충돌 등을 방어할 수 있다.
: 아키텍처 모델로 MSA는 작은 기능별로 서비스를 잘게 쪼개어 개발하는 형태를 의미.
MSA 환경에서는 대부분 Agile(소규모 기능 단위로 빠르게 개발 & 적용을 반복하는 개발방법론)방법론이 적용되기 때문에, 기능 추가가 매우 빈번하게 발생한다. 작은 micro service의 긴밀한 동작 테스트도 중요해진다. 그러한 상황에서 CI의 적용은 기능충돌방지 등의 장점을 제공한다.
CD는 Continuous Delivery 혹은 Continuous Deploymen 두 용어 모두의 축약어이다.
지속적인 서비스 제공 혹은 지속적인 배포라는 의미이다.
Continuous Delivery는 공유 레포지토리로 자동으로 Release하는 것이다.
Continuous Deployment는 Production 레벨까지 자동으로 deploy하는 것을 의미한다.
Git과 직접 연동이 되기 때문에 workflow 작성 및 관리가 쉽다.
다양한 플러그인을 제공해줌.
초기에는 러닝커브가 있을 수 있음.
public repository는 무료로 제공되며, private이라면 500MB 2000분이 무료로 제공됨
https://docs.github.com/ko/actions
아직까지도 제일 많이 사용하는 도구이며, 커뮤니티가 활발하다.
오픈소스이고 무료이다.
서버를 직접 호스팅 하고 관리해야 하기 때문에 서버 비용은 별도.
마찬가지로 다양한 플러그인을 제공해준다.
초기 설정에 시간이 걸릴 수 있으며, 지속적인 관리가 필요하다.
https://jenkins.io/
GitLab 플랫폼에서 자동화 빌드, 테스트 및 배포 파이프라인을 제공한다.
사용이 간편하고 배포 설정이 쉽다.
다른 플랫폼에 비해 플러그인이 적다.
https://about.gitlab.com/
참고
https://artist-developer.tistory.com/24
https://zsunn.tistory.com/entry/CICD-%EA%B0%9C%EB%B0%9C%EC%9E%90%EB%A5%BC-%EC%9C%84%ED%95%9C-CICD-%EB%8F%84%EA%B5%AC%EC%9D%98-%EC%A2%85%EB%A5%98
https://seosh817.tistory.com/104