เบฅเบฐเบเบปเบเบเบฒเบเปเบเบฐเบเปเบฒเปเบเบทเปเบญเบซเบฒเบงเบดเบเบตเปเบญเบญเบญเบเปเบฅเบเปเบเบตเปเบเบงเบเปเบฎเบปเบฒเบเปเบฒเบฅเบฑเบเปเบฎเบฑเบเบงเบฝเบเปเบกเปเบเบเบฒเบเบเบฑเบเบเบฐเบเบฒเบเบฒเบเบเปเบฒเบเบดเบเปเบฅเบฐเบเบฒเบเบเปเบฒเบเบงเบดเบเบฒเบเบฒเบเปเบเบฑเบเบเบธเปเบกเบซเบผเบฒเบเบญเบปเบเบเบฐเบเบญเบเบเบญเบเบญเบปเบเบเบฐเบเบญเบเบเบตเปเปเบเบฑเบเปเบเบปเปเบฒเบเบญเบเปเบฅเบฐเปเบซเบผเปเบเปเบเบตเบ. เบเบธเบเบเบฐเบชเบปเบเบเบญเบเบเบฒเบเบเบฝเบเบเบปเบเบเบตเปเปเบกเปเบเปเบเบทเปเบญเบญเบฐเบเบดเบเบฒเบเบเบฒเบเบเบฐเบเบดเบเบฑเบเบฅเบฐเบเบปเบ docker swarm clustering เบชเปเบฒเบฅเบฑเบเบชเบฐเบเบฒเบเบเบตเป staging เปเบเบเบเปเปเบกเบตเบเบฒเบเบฅเบปเบเบเบงเบเบเบฒเบเปเบฎเบฑเบเบงเบฝเบเบเบตเปเบชเปเบฒเบเบเบฑเปเบเบเบถเปเบเบเบญเบเบเบฐเบเบงเบเบเบฒเบเบเบญเบเบเบงเบเปเบฎเบปเบฒเปเบเปเบงเบฅเบฒเบเปเบฒเบเบฑเบ. เบเปเบฒเบเบฑเบเบเบฒเบเบเบตเปเบเปเบฒเบชเบฐเปเบซเบเบตเปเบซเปเบเบงเบฒเบกเบชเบปเบเปเบเบเบญเบเปเบเบปเปเบฒเปเบเปเบเบญเบญเบเปเบเบฑเบเบชเบญเบเบชเปเบงเบ. เบชเปเบงเบเบเปเบฒเบญเบดเบเบญเบฐเบเบดเบเบฒเบ CI / CD เบเปเบญเบเบเบตเปเบเบฐเปเบเป docker swarm, เปเบฅเบฐเบชเปเบงเบเบเบตเบชเบญเบเบญเบฐเบเบดเบเบฒเบเปเบเบดเบเบเบฐเบเบงเบเบเบฒเบเบเบฐเบเบดเบเบฑเบเบเบญเบเบกเบฑเบ. เบเบนเปโเบเบตเปโเบเปเปโเบชเบปเบโเปเบโเปเบโเบเบฒเบโเบญเปเบฒเบโเบเบฒเบโเบชเปเบงเบโเบเปเบฒโเบญเบดเบโเปเบเปโเบขเปเบฒเบโเบเบญเบโเปเบโเบชเบฒโเบกเบฒเบโเบเปเบฒเบโเปเบโเบเบตเปโเบชเบญเบโเปเบเปโเบขเปเบฒเบโเบเบญเบโเปเบ.
เบเบฒเบเบเบต I
เบเบฑเบเปเบเปเบเบเบตเบเบตเปเบซเปเบฒเบเปเบ, เบซเปเบฒเบเปเบ, เบกเบฑเบเบเปเบฒเปเบเบฑเบเบเปเบญเบเปเบเปเบเปเบฒเบเบปเบเบเบฐเบเบงเบเบเบฒเบ CI / CD เปเบงเปเบเบปเปเบฒเบเบตเปเบเบฐเปเบงเปเบเป. เบซเบเบถเปเบเปเบเปเบเบทเปเบญเบเปเบเบเปเปเปเบกเปเบเบเบฒเบเปเบเป Docker เบชเปเบฒโเบฅเบฑเบโเบเบฒเบโเบเปเบฒโเปเบเปโ เบญเบปเบโเบเบฐโเบเบญเบโเบเบตเปโเบเบฑเบโเบเบฐโเบเบฒโเบชเปเบฒโเบฅเบฑเบโเปเบซเบโเบเบปเบโเบเปเบฒโเบเบงเบโเบซเบเบถเปเบโ:
- เบชเปเบฒเบฅเบฑเบเบเบฒเบเบเปเบฒเปเบเบตเบเบเบฒเบเบเบตเปเปเบเบทเปเบญเบเบทเปเบเปเปเบฅเบฐเบซเบกเบฑเปเบเบเบปเบเบซเบผเบฒเบเบเบญเบเบญเบปเบเบเบฐเบเบญเบเปเบเบเบฒเบเบเบฐเบฅเบดเบ (เบเบฑเปเบเปเบกเปเบ, เปเบเบเบงเบฒเบกเปเบเบฑเบเบเบดเบ, เบเบงเบฒเบกเบเปเบญเบเบเบฒเบเบเปเปเปเบซเปเปเบเป virtualization)
- เบเบนเปเบเบฑเบเบเบฐเบเบฒเบเบฑเปเบเบเปเบฒเบเปเปเบเปเบญเบเบเบฒเบเปเบฎเบฑเบเบงเบฝเบเบเบฑเบ Docker (เปเบเบ, เปเบเปเบงเปเบฒเบกเบฑเบเปเบเบฑเบเปเบเบงเปเบ)
- เบญเบตเบเบเบฒเบกเบเบฒเบเบเบดเบเบฒเบฅเบฐเบเบฒเบญเบธเบเบปเบกเบเบฒเบเบเบญเบเบเบฒเบเบเบธเปเบกเบเบญเบ R&D
เปเบเบเบชเปเบฒเบเบเบทเปเบเบเบฒเบ, stack เปเบฅเบฐเบเบงเบฒเบกเบเปเบญเบเบเบฒเบเปเบเบทเปเบญเบเบเบปเปเบเปเบเบเบเบฐเบกเบฒเบเบชเปเบฒเบฅเบฑเบ MVP เปเบเปเบเบทเบเบเปเบฒเบชเบฐเปเบซเบเบตเบเบฑเปเบเบเปเปเปเบเบเบตเป:
- 4 เปเบเบตเบเปเบงเบต Intelยฎ X5650 เบเบฑเบ Debian (เปเบเบทเปเบญเบเบเบตเปเบกเบตเบเบฐเบชเบดเบเบเบดเบเบฒเบเบญเบตเบเบญเบฑเบเปเบถเปเบเปเบกเปเบเปเบเปเบฎเบฑเบเบเบฒเบเบเบฑเบเบเบฐเบเบฒเบขเปเบฒเบเปเบเบฑเบกเบเบตเป)
- เบเบฒเบเบเบฑเบเบเบฐเบเบฒเบญเบปเบเบเบฐเบเบญเบเบเบตเปเบเปเบฒเบซเบเบปเบเปเบญเบเปเบกเปเบเบเปเบฒเปเบเบตเบเบขเบนเปเปเบ C ++, Python3
- เปเบเบทเปเบญเบเบกเบทเบเบฒเบเบชเปเบงเบเบเบตเบชเบฒเบกเบเบปเปเบเบเปเบเบตเปเปเบเป: Kafka, Clickhouse, Airflow, Redis, Grafana, Postgresql, Mysql, โฆ
- เบเปเปเบชเปเบฒเบฅเบฑเบเบเบฒเบเบเปเปเบชเปเบฒเบเปเบฅเบฐเบเบฒเบเบเบปเบเบชเบญเบเบญเบปเบเบเบฐเบเบญเบเปเบเบเบเปเบฒเบเบซเบฒเบเบชเปเบฒเบฅเบฑเบเบเบฒเบ debug เปเบฅเบฐเบเบฒเบเบเปเบญเบ
เบซเบเบถเปเบเปเบเบเปเบฒเบเบฒเบกเบเปเบฒเบญเบดเบเบเบตเปเบเปเบญเบเปเบเปเบฎเบฑเบเบเบฒเบเปเบเปเปเบเปเบเบเบฑเปเบเบเบญเบเปเบเบทเปเบญเบเบเบปเปเบเปเบกเปเบเบงเบดเบเบตเบเบฒเบเบญเบปเบเบเบฐเบเบญเบเบเบตเปเบเปเบฒเบซเบเบปเบเปเบญเบเบเบฐเบเบทเบเบเปเบฒเปเบเปเบเปเปเบเบชเบฐเบเบฒเบเปเบงเบเบฅเปเบญเบกเปเบ (CI / CD).
เบเบงเบเปเบฎเบปเบฒเปเบเปเบเบฑเบเบชเบดเบเปเบเบเบตเปเบเบฐเบเบดเบเบเบฑเปเบเบญเบปเบเบเบฐเบเบญเบเบเบญเบเบเบฒเบเบชเปเบงเบเบเบตเบชเบฒเบกเบขเปเบฒเบเปเบเบฑเบเบฅเบฐเบเบปเบเปเบฅเบฐเบเบฑเบเบเบธเบเปเบซเปเปเบเบปเบฒเปเบเบปเปเบฒเปเบเบฑเบเบฅเบฐเบเบปเบ. เปเบญเบฑเบเบเบฅเบดเปเบเบเบฑเบเปเบเบเบเบณเบเบปเบเปเบญเบเบเบตเปเบเบฑเบเบเบฐเบเบฒเปเบ C++ เบซเบผเบท Python เบชเบฒเบกเบฒเบเบเบทเบเบเบณเปเบเปเปเบเบซเบผเบฒเบเบงเบดเบเบต. เปเบเบเบฑเบเบเบฒเบเบงเบเปเบเบปเบฒ, เบชเปเบฒเบฅเบฑเบเบเบฒเบเบเบปเบเบเบปเบงเบขเปเบฒเบ: เบเบฒเบเบชเปเบฒเบเบเบธเบเบฅเบฐเบเบปเบ, เบชเบปเปเบเบเบงเบเบกเบฑเบเปเบเบซเบฒเบเปเบญเบเปเบเบฑเบเบกเปเบฝเบเบเบญเบเบฎเบนเบเบเบฒเบเบเบตเปเบชเปเบฒเบเบเบถเปเบเปเบฅเบฐเบซเบผเบฑเบเบเบฒเบเบเบฑเปเบเบเบดเบเบเบฑเปเบเบกเบฑเบเบขเบนเปเปเบเปเบเบทเปเบญเบเปเบกเปเบเปเบฒเบ. เบเปเบงเบเปเบซเบเบเบปเบเบเบตเปเบเปเปเบฎเบนเปเบเบฑเบ, เบงเบดเบเบตเบเบฒเบเบญเบทเปเบเปเบเปเบเบทเบเปเบฅเบทเบญเบ, เบเบท: เบเบฒเบเบเปเบฒเปเบเป CI, เปเบเบฅเปเบเบตเปเบเบฐเบเบดเบเบฑเบเปเบเปเบเบญเบเปเบญเบฑเบเบเบฅเบดเปเบเบเบฑเบเบเบทเบเบฅเบงเบเบฅเบงเบก, เบชเบฐเบเบฒเบเปเบงเบเบฅเปเบญเบกเปเบเบเบเบฒเบ virtual เบเบทเบเบชเปเบฒเบเบเบทเปเบ, เปเบกเบเบนเบ py เบเบทเบเบเบดเบเบเบฑเปเบเบเบฒเบ requirement.txt, เปเบฅเบฐเบชเบดเปเบเบเบญเบกเบเบฑเบเบซเบกเบปเบเปเบซเบผเบปเปเบฒเบเบตเปเบเบทเบเบชเบปเปเบเบเปเบญเบกเบเบฑเบ configs, scripts เปเบฅเบฐ. เบชเบฐเบเบฒเบเปเบงเบเบฅเปเบญเบกเปเบญเบฑเบเบเบฅเบดเปเบเบเบฑเบเบเบตเปเบกเบฒเบเปเบญเบกเบเบฑเบเปเบเบทเปเบญเบเปเบกเปเบเปเบฒเบ. เบเปเปเปเบ, เปเบญเบฑเบเบเบฅเบดเปเบเบเบฑเบเบเบทเบเปเบเบตเบเบเบปเบงเปเบเบฑเบเบเบนเปเปเบเป virtual เปเบเบเบเปเปเบกเบตเบชเบดเบเบเบญเบเบเบนเปเปเบเบดเปเบเปเบเบเบฅเบฐเบเบปเบ.
Gitlab-CI เบเบทเบเปเบฅเบทเบญเบเปเบเบฑเบเบฅเบฐเบเบปเบ CI/CD. เบเปเปเบชเบปเปเบเบเบปเบเบญเบญเบเบกเบฒเปเบเบดเปเบเบเบทเบเบฑเปเบเบเบตเป:
เบเบฒเบกเปเบเบเบชเปเบฒเบ, gitlab-ci.yml เปเบเบดเปเบเปเบเบเบเบตเป
---
variables:
# ะผะธะฝะธะผะฐะปัะฝะฐั ะฒะตััะธั ะฆะะฃ ะฝะฐ ัะตัะฒะตัะฐั
, ะณะดะต ัะฐะทะฒะพัะฐัะธะฒะฐะตััั ะบะปะฐััะตั
CMAKE_CPUTYPE: "westmere"
DEBIAN: "MYREGISTRY:5000/debian:latest"
before_script:
- eval $(ssh-agent -s)
- ssh-add <(echo "$SSH_PRIVATE_KEY")
- mkdir -p ~/.ssh && echo -e "Host *ntStrictHostKeyChecking nonn" > ~/.ssh/config
stages:
- build
- testing
- deploy
debug.debian:
stage: build
image: $DEBIAN
script:
- cd builds/release && ./build.sh
paths:
- bin/
- builds/release/bin/
when: always
release.debian:
stage: build
image: $DEBIAN
script:
- cd builds/release && ./build.sh
paths:
- bin/
- builds/release/bin/
when: always
## testing stage
tests.codestyle:
stage: testing
image: $DEBIAN
dependencies:
- release.debian
script:
- /bin/bash run_tests.sh -t codestyle -b "${CI_COMMIT_REF_NAME}_codestyle"
tests.debug.debian:
stage: testing
image: $DEBIAN
dependencies:
- debug.debian
script:
- /bin/bash run_tests.sh -e codestyle/test_pylint.py -b "${CI_COMMIT_REF_NAME}_debian_debug"
artifacts:
paths:
- run_tests/username/
when: always
expire_in: 1 week
tests.release.debian:
stage: testing
image: $DEBIAN
dependencies:
- release.debian
script:
- /bin/bash run_tests.sh -e codestyle/test_pylint.py -b "${CI_COMMIT_REF_NAME}_debian_release"
artifacts:
paths:
- run_tests/username/
when: always
expire_in: 1 week
## staging stage
deploy_staging:
stage: deploy
environment: staging
image: $DEBIAN
dependencies:
- release.debian
script:
- cd scripts/deploy/ &&
python3 createconfig.py -s $CI_ENVIRONMENT_NAME &&
/bin/bash install_venv.sh -d -r ../../requirements.txt &&
python3 prepare_init.d.py &&
python3 deploy.py -s $CI_ENVIRONMENT_NAME
when: manual
เบกเบฑเบเปเบเบฑเบเบกเบนเบเบเปเบฒเบเบตเปเบชเบฑเบเปเบเบเบงเปเบฒเบเบฒเบเบเบฐเบเบญเบเปเบฅเบฐเบเบฒเบเบเบปเบเบชเบญเบเปเบกเปเบเบเปเบฒเปเบเบตเบเบขเบนเปเปเบเบฎเบนเบเบเบญเบเบกเบฑเบเปเบญเบ, เบเปเบญเบเบเบตเปเบเบธเบเบฅเบฐเบเบปเบเบเบตเปเบเปเบฒเปเบเบฑเบเบเบฑเบเบซเบกเบปเบเปเบเปเบเบทเบเบเบดเบเบเบฑเปเบเปเบฅเปเบงเปเบฅเบฐเบเบฒเบเบเบฑเปเบเบเปเบฒเบญเบทเปเบเป.
เปเบเบดเบเปเบกเปเบเบงเปเบฒเปเบเปเบฅเบฐเบชเบฐเบเบดเบเปเบซเบผเบปเปเบฒเบเบตเปเปเบเบซเบเปเบฒเบงเบฝเบเปเบกเปเบเบซเบเปเบฒเบชเบปเบเปเบเปเบเบฅเบฑเบเบชเบฐเบเบฐเบเบญเบเบเบปเบเปเบญเบ, เปเบเปเปเบเปเบเบญเบเบงเปเบฒเบเปเบญเบเบเบฐเบเปเปเปเบงเบปเปเบฒเบเปเบฝเบงเบเบฑเบเบเบงเบเบกเบฑเบ. เบเปเบฒเบญเบฐเบเบดเบเบฒเบเบเบญเบเบเบงเบเบกเบฑเบเปเบเปเบฅเบฐเบเบปเบเบเบฐเปเบเปเปเบงเบฅเบฒเบซเบผเบฒเบเปเบฅเบฐเบเบตเปเบเปเปเปเบกเปเบเบเบธเบเบเบฐเบชเบปเบเบเบญเบเบเบปเบเบเบงเบฒเบก. เบเปเบฒเบเบฐเปเบเบปเปเบฒเบเบฝเบเปเบเปเบเบฐเบเบถเบเบเบนเบเบเบงเบฒเบกเบชเบปเบเปเบเบเบญเบเบเปเบฒเบเบเปเปเบเบฑเบเบเบงเบฒเบกเบเบดเบเบเบตเปเบงเปเบฒเบเบฑเปเบเบเบญเบเบเบญเบเบเบฒเบเบเบดเบเบเบฑเปเบเบเบฐเบเบญเบเบเปเบงเบเบฅเปเบฒเบเบฑเบเบเบญเบ scripts เปเบเบซเบฒ:
- createconfig.py - เบชเปเบฒเบโเปเบเบฅโเป settings.ini เบเบตเปโเบกเบตโเบเบฒเบโเบเบฑเปเบโเบเปเบฒโเบญเบปเบโเบเบฐโเบเบญเบโเปเบโเบชเบฐโเบเบฒเบโเปเบงเบโเบฅเปเบญเบกโเบเปเบฒเบเปโเบชเปเบฒโเบฅเบฑเบโเบเบฒเบโเบเปเบฒโเปเบเปโเบเปเปโเบกเบฒ (Preproductionโ, เบเบฒเบโเบเบฐโเบฅเบดเบโ, เบเบฒเบโเบเบปเบโเบชเบญเบโ, ... )
- install_venv.sh - เบชเปเบฒเบเบชเบฐเบเบฒเบเปเบงเบเบฅเปเบญเบก virtual เบชเปเบฒเบฅเบฑเบเบญเบปเบเบเบฐเบเบญเบ py เปเบเปเบเปเบฅเบเบฐเบเปเบฅเบตเบชเบฐเปเบเบฒเบฐเปเบฅเบฐเบเบฑเบเบฅเบญเบเบกเบฑเบเปเบเบซเบฒเปเบเบทเปเบญเบเปเบกเปเบเปเบฒเบเบซเปเบฒเบเปเบเบชเบญเบเบซเบผเบตเบ
- เบเบฐเบเบฝเบก_init.d.py โ เบเบฐเบเบฝเบกเบชเบฐเบเบฃเบดเบเปเบฅเบตเปเบกเบเบปเปเบ-เบขเบธเบเบชเปเบฒเบฅเบฑเบเบญเบปเบเบเบฐเบเบญเบเปเบเบเบญเบตเบเปเบชเปเปเบกเปเปเบเบ
- deploy.py - decomposes เปเบฅเบฐ restarts เบญเบปเบเบเบฐเบเบญเบเปเบซเบกเป
เปเบงเบฅเบฒเบเปเบฒเบเปเบ. เบเบฑเปเบเบเบญเบเบเบญเบเบเบฑเปเบเบเบญเบเปเบเปเบเบทเบเบเบปเบเปเบเบเปเบเบเบเบฒเบเบเบฐเบฅเบดเบเบเปเบญเบเบเบฒเบเบเบฐเบฅเบดเบเปเบฅเบฐเบเบฒเบเบเบฐเบฅเบดเบ. เปเบเบตเปเบกเบเบฒเบเบชเบฐเบซเบเบฑเบเบชเบฐเบซเบเบนเบเบชเปเบฒเบฅเบฑเบเบเบฐเบฅเบดเบเบเบฐเบเบฑเบเปเบเบเบฒเบเปเบเบเบขเบฒเบเบญเบทเปเบ (CentOS). เปเบเปเปเบเบตเปเบก 5 เปเบเบตเบเปเบงเบตเบเบตเปเบกเบตเบเบฐเบฅเบฑเบ เปเบฅเบฐ เปเบเบตเบเปเบงเบตเบชเบฐเปเปเบทเบญเบเบซเบผเบฒเบเบชเบดเบเบญเบฑเบ. เปเบฅเบฐเบกเบฑเบเปเบเปเบเบฒเบเปเบเบฑเบเบเบงเบฒเบกเบซเบเบธเปเบเบเบฒเบเบซเบผเบฒเบเบเบทเปเบเบชเปเบฒเบฅเบฑเบเบเบฑเบเบเบฑเบเบเบฐเบเบฒเปเบฅเบฐเบเบนเปเบเบปเบเบชเบญเบเปเบเบทเปเบญเบเบปเบเบชเบญเบเบงเบฝเบเบเบฒเบเบเบญเบเบเบงเบเปเบเบปเบฒเปเบเบชเบฐเบเบฒเบเปเบงเบเบฅเปเบญเบกเบเบตเปเปเบเปเบเบดเบเบเบฑเบเบฅเบฑเบเบเบตเปเปเบฎเบฑเบเบงเบฝเบเบซเบผเบฒเบเบซเบผเบทเบซเบเปเบญเบ. เปเบเปเบงเบฅเบฒเบเบตเป, เบกเบฑเบเปเบเปเบเบฒเบเปเบเบฑเบเบเบตเปเบเบฑเบเปเบเบเบงเปเบฒเบกเบฑเบเปเบเบฑเบเปเบเบเปเปเปเบเปเบเบตเปเบเบฐเปเบฎเบฑเบเปเบเบเบเปเปเบกเบตเบฅเบฒเบง ...
เบเบฒเบเบเบต II
เบเบฑเปเบเบเบฑเปเบ, เบเบธเปเบกเบเบญเบเบเบงเบเปเบฎเบปเบฒเปเบกเปเบเบฅเบฐเบเบปเบเบเบตเปเบซเบเปเบฒเบเบฐเบเบฑเบเปเบเบเบญเบเบชเบญเบเบญเบปเบเบเบฐเบเบญเบเปเบเบเบเปเบฒเบเบซเบฒเบเบเบตเปเบเปเปเปเบเปเบญเบฐเบเบดเบเบฒเบเปเบเบ Dockerfiles. เบเปเบฒเบเบเบฝเบเปเบเปเบชเบฒเบกเบฒเบ configure เบกเบฑเบเบชเปเบฒเบฅเบฑเบ deployment เบเบฑเบเบชเบฐเบเบฒเบเปเบงเบเบฅเปเบญเบกเบชเบฐเปเบเบฒเบฐเปเบเบซเบเบถเปเบเปเบเบเบเบปเปเบงเปเบ. เปเปเบฒเบเบตเปเบเบญเบเบเบงเบเปเบฎเบปเบฒเปเบกเปเบเปเบเบทเปเบญเบเบณเปเบเปเบเบธเปเบกเปเบเบปเปเบฒเปเบเบชเบฐเบเบฒเบเปเบงเบเบฅเปเบญเบกเบเบฑเปเบเบเบญเบเปเบเบทเปเบญเบเบปเบเบชเบญเบเบเปเบญเบเบเบฒเบเบญเบญเบเบเบณเปเปเบฒเบเบเปเบญเบ.
เปเบเบเบฒเบเบเบดเบเบชเบฐเบเบต, เบชเบฒเบกเบฒเบเบกเบตเบซเบผเบฒเบเบเบธเปเบกเปเบฎเบฑเบเบงเบฝเบเบเปเบญเบกเปเบเบฑเบ: เบซเบผเบฒเบเปเบเบปเปเบฒเบเบตเปเบกเบตเบงเบฝเบเบเบฒเบเบขเบนเปเปเบเบฅเบฑเบเบชเปเบฒเปเบฅเบฑเบเบซเบผเบทเปเบเปเบเบฐเบชเปเบฒเปเบฅเบฑเบ. เบเบงเบฒเบกเบชเบฒเบกเบฒเบเบเบญเบเปเบเบทเปเบญเบเปเบกเปเบเปเบฒเบเปเบเบเบฒเบเบเปเบฒเบเบฑเบเบเบญเบเบเบงเบเปเบฎเบปเบฒเบญเบฐเบเบธเบเบฒเบเปเบซเปเบเบงเบเปเบฎเบปเบฒเบเปเบฒเปเบเบตเบเบเบฒเบเบซเบผเบฒเบเบเบธเปเบกเปเบเปเบเปเบฅเบฐเปเบเบทเปเบญเบเปเบกเปเบเปเบฒเบ. เปเบเปเบฅเบฐเบเบธเปเบกเบเบฑเปเบเบเบญเบเบเปเบญเบเปเบเบเบเปเบฝเบง (เบเปเบญเบเบเปเปเบกเบตเบเบธเบเบเบฑเบเบเบฑเบเปเบเบเบญเบ, เปเบเปเบฅเบเบฐเบเปเบฅเบต, เปเบฅเบฐเบญเบทเปเบเป).
เบเบฑเบเบเบฐเบเบฒเบเบญเบเบเบตเปเบกเบตเบเบธเบเบเปเบฒเบเบตเปเบชเบธเบเบเบญเบเบเบงเบเปเบฎเบปเบฒเปเบกเปเบเปเบงเบฅเบฒเบเบญเบเบเบงเบเปเบฎเบปเบฒ, เปเบฅเบฐเบเบงเบเปเบฎเบปเบฒเบเปเปเบกเบตเบกเบฑเบเบซเบผเบฒเบ.
เบชเปเบฒเบฅเบฑเบเบเบฒเบเปเบฅเบตเปเบกเบเบปเปเบเปเบงเบเบถเปเบ, เบเบงเบเปเบฎเบปเบฒเปเบฅเบทเบญเบ Docker Swarm เปเบเบทเปเบญเบเบเบฒเบเบเบงเบฒเบกเบเปเบฒเบเบเบฒเบเปเบฅเบฐเบเบงเบฒเบกเบเบทเบเบซเบเบธเปเบเบเบญเบเบชเบฐเบเบฒเบเบฑเบเบเบฐเบเบฐเบเปเบฒ. เบชเบดเปเบเบเปเบฒเบญเบดเบเบเบตเปเบเบงเบเปเบฎเบปเบฒเปเบฎเบฑเบเปเบกเปเบเบชเปเบฒเบเบเบนเปเบเบฑเบเบเบฒเบเปเบฅเบฐเบซเบผเบฒเบ nodes เปเบเปเบเบทเปเบญเบเปเบกเปเบเปเบฒเบเบซเปเบฒเบเปเบเบชเบญเบเบซเบผเบตเบ:
$ docker node ls
ID HOSTNAME STATUS AVAILABILITY MANAGER STATUS ENGINE VERSION
kilqc94pi2upzvabttikrfr5d nop-test-1 Ready Active 19.03.2
jilwe56pl2zvabupryuosdj78 nop-test-2 Ready Active 19.03.2
j5a4yz1kr2xke6b1ohoqlnbq5 * nop-test-3 Ready Active Leader 19.03.2
เบเปเปเปเบ, เบชเปเบฒเบเปเบเบทเบญเบเปเบฒเบ:
$ docker network create --driver overlay --subnet 10.10.10.0/24 nw_swarm
เบเปเปเปเบ, เบเบงเบเปเบฎเบปเบฒเปเบเบทเปเบญเบกเบเปเป Gitlab-CI เปเบฅเบฐ Swarm nodes เปเบเปเบเบทเปเบญเบเปเบเบเบญเบเบเบฒเบเบเบงเบเบเบธเบกเบซเปเบฒเบเปเบเบชเบญเบเบซเบผเบตเบเบเบญเบ nodes เบเบฒเบ CI: เบเบฒเบเบเบดเบเบเบฑเปเบเปเบเบขเบฑเปเบเบขเบทเบ, เบเบฒเบเบเบฑเปเบเบเปเบฒเบเบปเบงเปเบเบฅเบฑเบ, เปเบฅเบฐเบเบฒเบเบเบฑเปเบเบเปเบฒเบเปเบฅเบดเบเบฒเบ Docker เปเบเปเบเบทเปเบญเบเปเบกเปเบเปเบฒเบเบเบฒเบเบเบงเบเบเบธเบก. เบญเบฑเบเบเบตเป
เบเปเปเปเบ, เบเบงเบเปเบฎเบปเบฒเปเบเปเปเบเบตเปเบกเบงเบฝเบเบเบฒเบเบชเปเบฒเบ stack เปเบฅเบฐเบเบฒเบเบเปเบฒเบฅเบฒเบเบเบฑเบ .gitlab-ci .yml.
เบญเบตเบเบชเบญเบเบชเบฒเบกเบงเบฝเบเปเบเปเบเบทเบเปเบเบตเปเบกเปเบชเป .gitlab-ci .yml
## staging stage
deploy_staging:
stage: testing
before_script:
- echo "override global 'before_script'"
image: "REGISTRY:5000/docker:latest"
environment: staging
dependencies: []
variables:
DOCKER_CERT_PATH: "/certs"
DOCKER_HOST: tcp://10.50.173.107:2376
DOCKER_TLS_VERIFY: 1
CI_BIN_DEPENDENCIES_JOB: "release.centos.7"
script:
- mkdir -p $DOCKER_CERT_PATH
- echo "$TLSCACERT" > $DOCKER_CERT_PATH/ca.pem
- echo "$TLSCERT" > $DOCKER_CERT_PATH/cert.pem
- echo "$TLSKEY" > $DOCKER_CERT_PATH/key.pem
- docker stack deploy -c docker-compose.yml ${CI_ENVIRONMENT_NAME}_${CI_COMMIT_REF_NAME} --with-registry-auth
- rm -rf $DOCKER_CERT_PATH
when: manual
## stop staging stage
stop_staging:
stage: testing
before_script:
- echo "override global 'before_script'"
image: "REGISTRY:5000/docker:latest"
environment: staging
dependencies: []
variables:
DOCKER_CERT_PATH: "/certs"
DOCKER_HOST: tcp://10.50.173.107:2376
DOCKER_TLS_VERIFY: 1
script:
- mkdir -p $DOCKER_CERT_PATH
- echo "$TLSCACERT" > $DOCKER_CERT_PATH/ca.pem
- echo "$TLSCERT" > $DOCKER_CERT_PATH/cert.pem
- echo "$TLSKEY" > $DOCKER_CERT_PATH/key.pem
- docker stack rm ${CI_ENVIRONMENT_NAME}_${CI_COMMIT_REF_NAME}
# TODO: need check that stopped
when: manual
เบเบฒเบเบเปเปเบกเบนเบเบฅเบฐเบซเบฑเบเบเปเบฒเบเปเบเบดเบ, เบเปเบฒเบเบชเบฒเบกเบฒเบเปเบซเบฑเบเปเบเปเบงเปเบฒเบชเบญเบเบเบธเปเบก (deploy_staging, stop_staging) เปเบเปเบเบทเบเปเบเบตเปเบกเปเบชเป Pipelines, เบฎเบฝเบเบฎเปเบญเบเปเบซเปเบกเบตเบเบฒเบเบเบฐเบเบดเบเบฑเบเบเบนเปเบกเบท.
เบเบทเป stack เบเบปเบเบเบฑเบเบเบทเปเบชเบฒเบเบฒเปเบฅเบฐเบเบงเบฒเบกเปเบเบฑเบเปเบญเบเบฐเบฅเบฑเบเบเบตเปเบเบงเบเบเบฐเบเบฝเบเบเป. เบเบฒเบเบเปเบฅเบดเบเบฒเบเปเบ stack เปเบเปเบฎเบฑเบเบเบตเปเบขเบนเป ip เบเบตเปเปเบเบฑเบเปเบญเบเบฐเบฅเบฑเบ, เปเบฅเบฐเบเบญเบ, เปเบเปเบฅเบเบฐเบเปเบฅเบต, เปเบฅเบฐเบญเบทเปเบเป. เบเบฐเบเบทเบเปเบเบเบเปเบฝเบง, เปเบเปเบเบทเบเบฑเบเบเบฒเบ stack เบเบฑเบ stack (เปเบเบฒเบฐเบงเปเบฒเปเบเบฅเปเบเบฒเบเบเบฑเปเบเบเปเบฒเปเบกเปเบเบเบทเบเบฑเบเบชเปเบฒเบฅเบฑเบ stacks เบเบฑเบเบซเบกเบปเบ) - เบชเบดเปเบเบเบตเปเบเบงเบเปเบฎเบปเบฒเบเปเบญเบเบเบฒเบ. เบเบงเบเปเบฎเบปเบฒ deploy stack (cluster) เปเบเบเปเบเป docker-compose.yml, เปเบเบดเปเบเบญเบฐเบเบดเบเบฒเบเบเบธเปเบกเบเบญเบเบเบงเบเปเบฎเบปเบฒ.
docker-compose.yml
---
version: '3'
services:
userprop:
image: redis:alpine
deploy:
replicas: 1
placement:
constraints: [node.id == kilqc94pi2upzvabttikrfr5d]
restart_policy:
condition: none
networks:
nw_swarm:
celery_bcd:
image: redis:alpine
deploy:
replicas: 1
placement:
constraints: [node.id == kilqc94pi2upzvabttikrfr5d]
restart_policy:
condition: none
networks:
nw_swarm:
schedulerdb:
image: mariadb:latest
environment:
MYSQL_ALLOW_EMPTY_PASSWORD: 'yes'
MYSQL_DATABASE: schedulerdb
MYSQL_USER: ****
MYSQL_PASSWORD: ****
command: ['--character-set-server=utf8mb4', '--collation-server=utf8mb4_unicode_ci', '--explicit_defaults_for_timestamp=1']
deploy:
replicas: 1
placement:
constraints: [node.id == kilqc94pi2upzvabttikrfr5d]
restart_policy:
condition: none
networks:
nw_swarm:
celerydb:
image: mariadb:latest
environment:
MYSQL_ALLOW_EMPTY_PASSWORD: 'yes'
MYSQL_DATABASE: celerydb
MYSQL_USER: ****
MYSQL_PASSWORD: ****
deploy:
replicas: 1
placement:
constraints: [node.id == kilqc94pi2upzvabttikrfr5d]
restart_policy:
condition: none
networks:
nw_swarm:
cluster:
image: $CENTOS7
environment:
- CENTOS
- CI_ENVIRONMENT_NAME
- CI_API_V4_URL
- CI_REPOSITORY_URL
- CI_PROJECT_ID
- CI_PROJECT_URL
- CI_PROJECT_PATH
- CI_PROJECT_NAME
- CI_COMMIT_REF_NAME
- CI_BIN_DEPENDENCIES_JOB
command: >
sudo -u myusername -H /bin/bash -c ". /etc/profile &&
mkdir -p /storage1/$CI_COMMIT_REF_NAME/$CI_PROJECT_NAME &&
cd /storage1/$CI_COMMIT_REF_NAME/$CI_PROJECT_NAME &&
git clone -b $CI_COMMIT_REF_NAME $CI_REPOSITORY_URL . &&
curl $CI_API_V4_URL/projects/$CI_PROJECT_ID/jobs/artifacts/$CI_COMMIT_REF_NAME/download?job=$CI_BIN_DEPENDENCIES_JOB -o artifacts.zip &&
unzip artifacts.zip ;
cd /storage1/$CI_COMMIT_REF_NAME/$CI_PROJECT_NAME/scripts/deploy/ &&
python3 createconfig.py -s $CI_ENVIRONMENT_NAME &&
/bin/bash install_venv.sh -d -r ../../requirements.txt &&
python3 prepare_init.d.py &&
python3 deploy.py -s $CI_ENVIRONMENT_NAME"
deploy:
replicas: 1
placement:
constraints: [node.id == kilqc94pi2upzvabttikrfr5d]
restart_policy:
condition: none
tty: true
stdin_open: true
networks:
nw_swarm:
networks:
nw_swarm:
external: true
เปเบเบเบตเปเบเบตเปเบเปเบฒเบเบชเบฒเบกเบฒเบเปเบซเบฑเบเปเบเปเบงเปเบฒเบญเบปเบเบเบฐเบเบญเบเปเบกเปเบเปเบเบทเปเบญเบกเบเปเปเปเบเบเปเบเบทเบญเบเปเบฒเบเบเบฝเบง (nw_swarm) เปเบฅเบฐเบกเบตเปเบซเปเบเบฑเบเปเบฅเบฐเบเบฑเบ.
เบญเบปเบเบเบฐเบเบญเบเบเบญเบเบฅเบฐเบเบปเบ (เบญเบตเบเปเบชเป redis, mysql) เบเบทเบเปเบเบเบญเบญเบเบเบฒเบเบชเบฐเบเบธเบเปเบเบตเบเบปเปเบงเปเบเบเบญเบเบญเบปเบเบเบฐเบเบญเบเบเบตเปเบเปเบฒเบซเบเบปเบเปเบญเบ (เปเบเปเบเบเบเบฒเบเปเบฅเบฐ custom เปเบกเปเบเปเบเปเบเบญเบญเบเปเบเบฑเบเบเปเบฅเบดเบเบฒเบ). เบเบฑเปเบเบเบญเบเบเบฒเบเบเบดเบเบเบฑเปเบเบเบญเบเบเบธเปเบกเบเบญเบเบเบงเบเปเบฎเบปเบฒเปเบเบดเปเบเบเบทเบงเปเบฒเบเบฒเบเบเปเบฒเบเบเบญเบ CMD เปเบเบปเปเบฒเปเบเปเบเบฎเบนเบเบเบฒเบเบเบตเปเบกเบตเบเบฒเบเบเบฑเปเบเบเปเบฒเบเบฐเบซเบเบฒเบเปเบซเบเปเบญเบฑเบเบซเบเบถเปเบเบเบญเบเบเบงเบเปเบฎเบปเบฒเปเบฅเบฐเปเบเบเบเบปเปเบงเปเบเปเบฅเปเบง, เบเบฒเบเบเบฐเบเบดเบเบฑเบเบเปเปเปเบเบเบเปเบฒเบเบเบฒเบเบเบฒเบเบเบฐเบเบดเบเบฑเบเบเบตเปเปเบเปเบญเบฐเบเบดเบเบฒเบเปเบงเปเปเบเบเบฒเบ I. เบเปเบฒเบเบฐเปเบเบปเปเบฒเบเบฐเปเบเบฑเปเบเปเบซเปเปเบซเบฑเบเบเบงเบฒเบกเปเบเบเบเปเบฒเบ:
- git clone... - เปเบเปโเบฎเบฑเบโเปเบเบฅโเปโเบเบตเปโเบเปเบฒโเปเบเบฑเบโเปเบเบทเปเบญโเบเปเบฒโเปเบเป (createconfig.pyโ, install_venv.shโ, เปเบฅเบฐโเบญเบทเปเบเปโ)
- curl... && unzip... - เบเบฒเบงโเบโเปโเปเบซเบฅเบโเปเบฅเบฐ unzip เบเบฒเบโเบเปเปโเบชเปเบฒเบ artifacts (เบญเบธโเบเบฐโเบเบญเบโเบเบฒเบโเบชเบฑเบโเบฅเบงเบกโ)
เบกเบตเบเบฝเบเปเบเปเบซเบเบถเปเบเบเบฑเบเบซเบฒเบเบตเปเบเบฑเบเบเปเปเปเบเปเบญเบฐเบเบดเบเบฒเบ: เบญเบปเบเบเบฐเบเบญเบเบเบตเปเบกเบตเบเบฒเบเปเบเปเบเบญเบเปเบงเบฑเบเปเบเบเปเปเบกเปเบเบเปเปเบชเบฒเบกเบฒเบเปเบเบปเปเบฒเปเบเบดเบเปเบเปเบเบฒเบเบเบปเบงเบเปเบญเบเปเบงเบฑเบเบเบญเบเบเบฑเบเบเบฑเบเบเบฐเบเบฒ. เบเบงเบเปเบฎเบปเบฒเปเบเปเปเบเบเบฑเบเบซเบฒเบเบตเปเปเบเบเปเบเป reverse proxy, เบเบฑเปเบเบเบฑเปเบ:
เปเบ .gitlab-ci.yml, เบซเบผเบฑเบเบเบฒเบ deploy the cluster stack, we add line of deploy the balancer (เบเบถเปเบ, เปเบกเบทเปเบญ commits, เบเบฝเบเปเบเปเบเบฑเบเบเบธเบเบเบฒเบเบเบฑเปเบเบเปเบฒเบเบญเบเบกเบฑเบ (เบชเปเบฒเบเปเบเบฅเปเบเบฒเบเบเบฑเปเบเบเปเบฒ nginx เปเบซเบกเปเบเบฒเบกเปเบกเปเปเบเบ: /etc/nginx/conf. d/${CI_COMMIT_REF_NAME}.conf) - เปเบเบดเปเบเบฅเบฐเบซเบฑเบ docker-compose-nginx.yml)
- docker stack deploy -c docker-compose-nginx.yml ${CI_ENVIRONMENT_NAME} --with-registry-auth
docker-compose-nginx.yml
---
version: '3'
services:
nginx:
image: nginx:latest
environment:
CI_COMMIT_REF_NAME: ${CI_COMMIT_REF_NAME}
NGINX_CONFIG: |-
server {
listen 8080;
server_name staging_${CI_COMMIT_REF_NAME}_cluster.dev;
location / {
proxy_pass http://staging_${CI_COMMIT_REF_NAME}_cluster:8080;
}
}
server {
listen 5555;
server_name staging_${CI_COMMIT_REF_NAME}_cluster.dev;
location / {
proxy_pass http://staging_${CI_COMMIT_REF_NAME}_cluster:5555;
}
}
volumes:
- /tmp/staging/nginx:/etc/nginx/conf.d
command:
/bin/bash -c "echo -e "$$NGINX_CONFIG" > /etc/nginx/conf.d/${CI_COMMIT_REF_NAME}.conf;
nginx -g "daemon off;";
/etc/init.d/nginx reload"
ports:
- 8080:8080
- 5555:5555
- 3000:3000
- 443:443
- 80:80
deploy:
replicas: 1
placement:
constraints: [node.id == kilqc94pi2upzvabttikrfr5d]
restart_policy:
condition: none
networks:
nw_swarm:
networks:
nw_swarm:
external: true
เปเบเบเบญเบกเบเบดเบงเปเบเบตเบเบฑเบเบเบฐเบเบฒ, เบเบฑเบเบเบธเบ /etc/hosts; เบเปเบฒเบเบปเบ url เบเบฑเบ nginx:
10.50.173.106 staging_BRANCH-1831_cluster.dev
เบเบฑเปเบเบเบฑเปเบ, เบเบฒเบเบเบฑเบเบงเบฒเบเบเบธเปเบกเบเบฑเปเบเบเบญเบเบเบตเปเปเบเบเบเปเบฝเบงเปเบเปเบเบทเบเบเบฐเบเบดเบเบฑเบเปเบฅเบฐเปเบเบเบฑเบเบเบธเบเบฑเบเบเบฑเบเบเบฑเบเบเบฐเบเบฒเบชเบฒเบกเบฒเบเบเปเบฒเปเบเบตเบเบเบฒเบเปเบซเปเปเบเบปเบฒเปเบเบปเปเบฒเปเบเบเปเบฒเบเบงเบเบเบตเปเบเบฝเบเบเปเปเบเบทเปเบญเบเบงเบเบเบฒเปเบเบดเปเบเบงเบฝเบเบเบฒเบเบเบญเบเปเบเบปเบฒเปเบเบปเปเบฒ.
เปเบเบโเบเบฒเบโเปเบโเบญเบฐโเบเบฒโเบเบปเบโ:
- เปเบเบเบญเบปเบเบเบฐเบเบญเบเบเบญเบเบเบงเบเปเบฎเบปเบฒเปเบเบฑเบเบเบฒเบเบเปเบฅเบดเบเบฒเบ
- เบกเบตเบชเปเบฒเบฅเบฑเบเปเบเปเบฅเบฐ Dockerfile
- เบเบงเบเบเบปเบเปเบเบเบเบตเปเปเบซเบผเบเปเปเบญเบเบฅเบปเบเปเบเบเบญเบฑเบเบเบฐเปเบเบกเบฑเบเปเบ stack
- เบฅเบฐเบเบธ nodes เปเบเบเบฎเบนเบเปเบเบเบเบทเป (เปเบเบเบเบตเปเบเบฐเปเบเป id เปเบเบเบปเบเบเบงเบฒเบก)
- เปเบเบตเปเบกเบเบฒเบเบเบงเบเบชเบญเบเบงเปเบฒ stack เปเบเปเบเบทเบเบเปเบฒเบฅเบฒเบ
- ...
เบเบญเบเปเบเบเบดเปเบชเบเบชเบณเบฅเบฑเบ
เปเบซเบผเปเบเบเปเปเบกเบนเบ: www.habr.com