CI/CD Advance
Last updated
Was this helpful?
Last updated
Was this helpful?
์ง๋ฌธ์ด ์์ผ๋ฉด duo chat์ ์ด์ฉํ์. ๋ฉ๋ด๊ฐ ์ฐพ๊ธฐ ์ด๋ ต๋ค. ์๋น์ค์ ๋ฐ๋ผ์ ์์์๋ ์๋ค.
.gitlab-ci.yml
์์ฑ (gitlab-ci.yaml
์ ๋์ํ์ง์์)
stage
job
stage๋ tagging system๊ณผ ๋น์ทํ๋ค. ๋ชจ๋ ๊ฒ์ Job์ผ๋ก ์์ง์ด์ง๋ง stage๋ job์ ๊ทธ๋ฃนํ ์ํค๋ ์ญํ ์ ํ๋ค.
before_script: script์ ์ ์คํ๋๋ค. ๊ทธ๋ฆฌ๊ณ script์ ๊ฐ์ shell์์ ์คํ๋๋ค.
script : runner์ ์ํด์ ์คํ๋๋ค. exitcode๋ ์ฌ๊ธฐ์์ ๋ฆฌํด๋๋ค.
after_script : Runs in a separate shell after the before_script / script statements. (๋ค๋ฅธ ์์์ ์คํ๋๋ค. ) , exitcode ์ ๋ํด์๋ ์๊ดํ์ง ์๋๋ค.
test์ ์ฝ๋ ์ถ๊ฐ
stage ์์๋๋ก ์คํ๋๋ค.
Jobs in the next stage will start after all jobs in the previous stage have completed successfully
๋ค์ ๋จ๊ณ์ ์์ ์ ์ด์ ๋จ๊ณ์ ๋ชจ๋ ์์ ์ด ์ฑ๊ณต์ ์ผ๋ก ์๋ฃ๋ ํ ์์๋ฉ๋๋ค.
SSH
Shell
Virtual Box
Parallels
Docker
Docker Autoscaler (Beta)
Docker Machine
Kubernetes
Custom
tag๋ฅผ ์ด์ฉํด์ runner๋ฅผ ์ ํํ ์ ์๋ค.
need๋ฅผ ์ฌ์ฉํ์ฌ ํน์ ์์ ๋ค์์ ์คํ์ ํ ์ ์๋ค.
๊ฒฝ์ฐ์ ๋ฐ๋ผ์ stage๋ฅผ ๋์์ ์คํํ๊ณ ์ถ์์ ์๋ค.
๋๊ฐ์ ์ก์ด ๋ค๋ฅธ์ก์ ๊ธฐ๋ค๋ฆฌ์ง ์๊ณ ๋์์ ์คํ๋๋ค.
stage์ถ๊ฐํ๊ณ ๋ค์ ์ฝ๋๋ฅผ ์ถ๊ฐํด๋ณด์.
์ฌ๊ธฐ์์ ๋ณด๋ฉด ๋ณผ์ ์๋ค.
์๋ณตํ์.
๋ฒ์ ์ ๋ฐ๋ผ์ ๋ค๋ฅด์ง๋ง ๊ธฐ์กด์๋ need๋ ๋ค๋ฅธ stage์ job์ ์ ์ฉํ ์ ์์์ต๋๋ค.
์ด์ ๋ ๊ฐ์ stage์์๋ need๊ฐ ์ ์ฉ๋จ. Allows โneedsโ keyword to be used in the same stage
ํ์ดํ๋ผ์ธ์ ์ข๋ ํจ๊ณผ์ ์ผ๋ก ๋ง๋ค์ ์์ต๋๋ค.
์คํ์์๋ฅผ ์ข๋ ๋ช ํํ๊ฒ ์ ํ ์ ์์ต๋๋ค.
Available in (All tiers; 14.2+)
To cache, a GitLab Runner will take the content you cached and store it in GCP Cloud Storage
Pipeline starts.
job A runs.
before_script is executed.
script is executed.
after_script is executed.
cache runs and the vendor/ directory is zipped into cache.zip. This file is then saved in the directory based on the runnerโs setting and the cache: key.
job B runs.
The cache is extracted (if found).
before_script is executed.
script is executed.
Pipeline finishes.
์์ ๊ฐ์ ๋ค์ด๋ก๋ํ ์ฝํ ์ธ ๊ณต์ : ์ฝ๋์ ์ฌ๋ฌ ๋ธ๋์น์์ ์ํํ ์๋ ์์ต๋๋ค. ์ฝ๋ ์ข ์์ฑ ์ ์ฅ(๋ค์์ ๋ค์ด๋ก๋ํ ๋๊น์ง ๊ธฐ๋ค๋ฆด ํ์ ์์) ํ์ดํ๋ผ์ธ ์๋ ํฅ์
hello.txt๋ฅผ ๋ค์์์ ์ด ๋ฐ์์ ์ฒ๋ฆฌํ ์ ์๋ค.
hello world ๊ฐ ์ฐํ๋๊ฑธ ๋ณผ์ ์๋ค. ํ์ผ์ ๊ฐ์ ธ์๋ค๋ ๋ป์ด๋ค.
์ข๋ ์๋ฏธ์๋ ์ํ์ ํด๋ณด์. ruby๋ฅผ ๋น๋๋ฅผ ๋จผ์ ํด์ ๊ทธ๊ฑธ ์บ์ํด๋๊ณ ๋ค์์์ ์์ ๊ฐ์ ธ์์ ์ฌ์ฉํ ์ ์๋ค.
์ข๋ ์๋ฏธ์๋ ์ํ์ ํด๋ณด์. ruby๋ฅผ ๋น๋๋ฅผ ๋จผ์ ํด์ ๊ทธ๊ฑธ ์บ์ํด๋๊ณ ๋ค์์์ ์์ ๊ฐ์ ธ์์ ์ฌ์ฉํ ์ ์๋ค.
npm๋ ๋ง์ฐฌ๊ฐ์ง์ด๋ค. ์ฒ์๋ถํฐ ๋ค ์ค์นํ์ง ์๊ณ ์ค์น๋ ํ์ผ๋ค์ ๋ค์ด๋ฐ์ํ ์ฌ์ฉํ๋ฉด ๋น๋ ์๊ฐ์ ์ค์ผ์ ์๋ค.
We need to find a way to configure the pipeline so that even when the unit test job fails, subsequent jobs still execute.
๋จ์ ํ ์คํธ ์์ ์ด ์คํจํ๋๋ผ๋ ํ์ ์์ ์ด ๊ณ์ ์คํ๋๋๋ก ํ์ดํ๋ผ์ธ์ ๊ตฌ์ฑํ๋ ๋ฐฉ๋ฒ
allow_failure: true
- failing job is logged in the pipeline as failed, but does not prevent subsequent jobs from executing
allow_failure ๋ฅผ ์ฌ์ฉํ๋ฉด๋๋ค.
์คํฌ๋ฆฝํธ exit 1
์ ์คํจ๋ฅผ ๋ฆฌํดํ๋ค.
stage์ deploy๋ฅผ ์ถ๊ฐํ๋ค.allow_failure: true
๊ฐ ์์ผ๋ฉด deploy๋ ์คํ๋์ง ์๋๋ค.
๋ง๋ ์กฐ๊ฑด์๋ง ์คํ์ด ๋๋ค.
When is a Job NOT created in a Pipeline?
A job is not included in a pipeline if:
None of the rules defined for the job evaluate to true
A rule evaluates to true, but has clause of when: never
No rules are defined but a when: never clause is specified
๋ค์๊ณผ ๊ฐ์ ๊ฒฝ์ฐ ์์ ์ ํ์ดํ๋ผ์ธ์ ํฌํจ๋์ง ์์ต๋๋ค:
์์ ์ ๋ํด ์ ์๋ ๊ท์น ์ค ์ด๋ ๊ฒ๋ ์ฐธ์ผ๋ก ํ๊ฐ๋์ง ์์ต๋๋ค.
๊ท์น์ด ์ฐธ์ผ๋ก ํ๊ฐ๋์ง๋ง when: never
์ ์ด ์์ต๋๋ค.
๊ท์น์ด ์ ์๋์ด ์์ง ์์ง๋ง when: never
์ ์ด ์ง์ ๋์ด ์์ต๋๋ค.
๋๊ฐ์ ๊ฒฝ์ฐ์๋ job์ด ์คํ๋์ง ์๋๋ค.
when: on_success : ์ด์ ์์ ์ด ์ฑ๊ณตํ๋ค๊ณ ๊ฐ์ ํ์ฌ ์์ ์ ์คํํ๋๋ก ์ง์ํฉ๋๋ค. ์ด์ค์ ์ค๋ฉด ๊ธฐ์กด if๋ ์ด๋๊ฒ๋ ๋ง์กฑํ์ง ์์๋ ์ฌ๊ธฐ๊น์ง ์ค๊ฒ ๋๋ค.
์๋์ผ๋ก ์คํํ๊ณ ์ถ์ผ๋ฉด when: manual
์ ์ถ๊ฐํ๋ฉด ๋๋ค.
ํ๋ฉด์์ ์คํ๋ฒํผ์ด ๋์ค๋ฏ๋ก ๊ทธ๊ฑธ ๋๋ฅด๋ฉด๋๋ค.
If $CI_PIPELINE_SOURCE is set to merge_request_event or schedule, the job is executed
CI_PIPELINE_SOURCE๊ฐ merge_request_event ๋๋ ์ค์ผ์ค๋ก ์ค์ ๋ ๊ฒฝ์ฐ ์์ ์ด ์คํ๋ฉ๋๋ค.
If used as when: delayed, start_in is also required.
๊ฒฝ๋ก์ค์ ํ์ผ์ด ๋ฐ๊ท๋ฉด ์คํ๋๋๋ก ํ ์ ์๋ค.
์ ๋ด์ฉ์ ๋๊ฐ์ ๊ฒฝ๋ก์ ํ์ผ์ด ํ๋๋ผ๋ ๋ฐ๊ท๋ฉด ์คํ๋๋ค. AND๋ฅผ ์คํํ๋ ค๋ฉด ์๋์ ๊ฐ์ด ํ๋ฉด๋๋ค.
The order of precedence for variables is (from highest to lowest): ๋ณ์์ ์ฐ์ ์์๋ (๋์ ๊ฒ๋ถํฐ ๋ฎ์ ๊ฒ) ์ ๋๋ค
CICD pipeline Trigger variables, scheduled pipeline variables, and manual pipeline run variables.
Project-level variables or protected variables.
Group-level variables or protected variables.
Instance-level variables or protected variables.
Inherited environment variables.
YAML-defined job-level variables.
YAML-defined global variables.
Deployment variables.
Predefined environment variables.
artifacts์ ๋ค์ด๋ก๋ํ ์ ์์ต๋๋ค.
SAST๋ Static Application Security Testing์ ์ฝ์์ด๋ค.
add test stage
Now that we have SAST lets add a few more security templates to our project to confirm that our code is secure
SAST๋ฅผ ํ์ฑํํ์ฌ ํ์ดํ๋ผ์ธ์ ๋ฐ๋ชจํ ํ ๋ณด์ ํ์์ ๋ ๋ง์ ์ค์บ๋๋ก ์์ฒด ํ์ดํ๋ผ์ธ์ ์คํํ๊ณ ์์ผ๋ฉฐ ์ด๋ฅผ ํ์ดํ๋ผ์ธ๊ณผ ํตํฉํ๊ธฐ๋ฅผ ์ํ๋ค๋ ์ฌ์ค์ ์๋ ค์ค๋๋ค. ์ด๋ฅผ ์ํ ๊ฐ์ฅ ์ข์ ๋ฐฉ๋ฒ์ ํ์ ํ์ดํ๋ผ์ธ์ ์ค์ ํ๋ ๊ฒ์ด๋ผ๊ณ ๊ฒฐ์ ํฉ๋๋ค.
์ ์ฒด ์ฝ๋๋ฅผ ์ ๋ฐ์ดํธํ์.
new stage ์ถ๊ฐ
extra-security ์ถ๊ฐ. trigger๋ฅผ ์ฌ์ฉํ๊ณ include๋ฅผ ์ฌ์ฉํ๋ค.
create folder and file
security-pipeline/security.gitlab-ci.yml
์ด๋ค ํ์ดํ๋ผ์ธ์ด๋ผ๋ ์ถ๊ฐํด์ ์ฌ์ฉํ ์ ์๋ค.
Two types:
Parent-child
ํ์ดํ๋ผ์ธ์ด ๊ฐ์ ํ๋ก์ ํธ์ ์กด์ฌ
๋ถ๋ชจ ํ์ดํ๋ผ์ธ๊ณผ ๋์ผํ ํ๋ก์ ํธ, ์ฐธ์กฐ ๋ฐ ์ปค๋ฐ SHA์์ ์คํ๋ฉ๋๋ค.
๊ธฐ๋ณธ์ ์ผ๋ก ํ์ดํ๋ผ์ธ์ด ์คํ๋๋ ์ฐธ์กฐ์ ์ ์ฒด ์ํ์ ์ง์ ์ ์ธ ์ํฅ์ ๋ฏธ์น์ง ์์ต๋๋ค(์์ ํ์ดํ๋ผ์ธ์ ํธ๋ฆฌ๊ฑฐํ ๋ strategy:depend
๋ฅผ ์ฌ์ฉํ์ง ์๋ ํ).
์ค์ฒฉ๋ ๋ ๋ฒจ 2๊ฐ๋ก ์ ํ
Multi-project
ํ์ดํ๋ผ์ธ์ ์ฌ๋ฌ ํ๋ก์ ํธ์ ์กด์ฌํฉ๋๋ค.
์ ์คํธ๋ฆผ(ํธ๋ฆฌ๊ฑฐ๋ง) ํ์ดํ๋ผ์ธ์ ๋ค์ด์คํธ๋ฆผ(ํธ๋ฆฌ๊ฑฐ๋ง) ํ์ดํ๋ผ์ธ์ ๋ํ ์ ์ด ๊ถํ์ด ๋ง์ง ์์ต๋๋ค.
์คํ ์ค์ธ ํ๋ก์ ํธ์ ์ ์ฒด ์ฐธ์กฐ ์ํ์๋ ์ํฅ์ ์ฃผ์ง๋ง ํธ๋ฆฌ๊ฑฐ ํ์ดํ๋ผ์ธ์ ์ฐธ์กฐ ์ํ์๋ ์ํฅ์ ๋ฏธ์น์ง ์์ต๋๋ค.
๋ ๋ฆฝ์ ์ด๋ฏ๋ก ์ค์ฒฉ ์ ํ์ด ์์ต๋๋ค.
Allows you to get creative and make dynamic changes to the current results of your pipelines ์ฐฝ์๋ ฅ์ ๋ฐํํ์ฌ ํ์ดํ๋ผ์ธ์ ํ์ฌ ๊ฒฐ๊ณผ๋ฅผ ๋์ ์ผ๋ก ๋ณ๊ฒฝํ ์ ์์ต๋๋ค.
stage๊ฐ ์์ฑ์ด ๋๋ค. ๊ทธ๋ฆฌ๊ณ job์ด ์์ฑ์ด ๋๋ค.
build๊ฐ ์๋๋๋ test๊ฐ ์คํ๋๋ค. job dependencies๊ฐ ์๊ฒผ๊ณ dependency๊ฐ ์๋๊ฒ์ ๋ณผ์ ์๋ค.
allow_failure: true
์๋ ๊ฒฝ์ฐ
allow_failure: true
์๋ ๊ฒฝ์ฐ