CI/CD

박성운·2022년 8월 25일
0

직속적 통합(continuous integration)/ 지속적 배포(continueous deployment)

매번 새벌자가 코드를 수정하고 빌드와테스트를 하고 배포까지 한다면 상당히 많은 시간이 소요된다. 하지만 git에 올리는 것 만으로도 누군가가 빌드와 테스트, 배포까지 해준다면 시간을 단축할 수 있을 것이다.

CI?
CI는 산단히 요약하자면 빌드/테스트 자도화 과정이다. CI는 개발자를 위한 자동화 프로세스인 지속적인 통합(Continuous Integration)을 의미한다. CI를 성공적으로 구현할 경우 애플리케이션에 대한 새로운 코드 변경 사한이 정기적으로 빌드 및 테스트되어 공유 리포지토리에 통합도므로 여러 명의 개발자가 동시에 애플리케이션 새발고 ㅏ관련된 코드 작업을 할 격우 서로 충돌할 수 있는 문제를 해결할 수 있다.

지속적 통합의 실행은 소스/ 버전 관리 시스템에 대한 변경사항을 정기적으로 커밋하여 모든 사람에게 동일 작업 기반을 제공하는 것으로 시작한다. 커밋할 때마다 빌드와 일련의 자동 테스트가 이루어져 동작을 확인하고 변경으로 인해 문제가 생기는 부분이 없도록 보장한다.

CD?
CD는 배포 자동화 과정이다. CD는 지속적인 서비스 제공(continuous Delivery) 또는 지속걱인 배포(Continuous Deployment)를 의미하며 이 두 용어는 상호 교환적으로 사용된다. 두 사지 의미 모두 파이프라인의 추가 당계에 대한 자동화를 뜻하지만 때로는 얼마난 많은 자도화가 이루어지고 있는지를 설명하기 위해 별도로 사용되기도 한다.

지속적 배포는 빌드, 테스트 및 배포 단계를 자동화하는 DevOps 방식을 논리적 극한까지 끌어 올립니다. 코드 변경이 파이프라인의 이전 단계를 모두 통과하면 수동 개입 없이 해당 변 사항이 프로덕션에 자도으로 배포된다. 지속적 배포를 채택하면 품질 저하 없이 최대한 빨리 사용자에게 새로운 기능을 제공할 수 있습니다.

지속적인 배포로 간단한 코드 변경이 정기적으로 마스터에 커밋되고, 자도화된 빌드 및 테스트 프로세스를 거치며 다양한 사전 프로덕션 환경으로 승격되며, 문제가 발견되지 않으면 최종걱으로 배포된다.

과정
1. 개발자들이 개발하여 feature 브랜치에 코드를 push 한다.
2. git push를 통해 trigger되어 CI서버에서 알아서 Build,Test,Lint를 실행하고 결과를 전송한다.
3. 개발자들은 결과를 전송받고 에러가 난 부분이 있다면 에러부분을 수정하고 코드를 master 브랜치에 merge한다.
4. master 브랜치에 코드를 merge하고 Build, Test가 정상적으로 수행이 되었다면 CI 서버에서 알아서 Deploy 과정을 수행한다.

CI/CD 중에서 나는 Jenkins를 사용한다.

0개의 댓글