Skip to content

Latest commit

 

History

History
353 lines (250 loc) · 15.7 KB

README.md

File metadata and controls

353 lines (250 loc) · 15.7 KB

OTUS HW microservices

ДЗ по модулю "Введение в Kubernetes #1"

  • Добавил файлы с Deployment-манифестами приложений (ui, post, comment, mongo)
  • Установил K8s на двух нодах при помощи утилиты kubeadm
  • Описал установку кластера K8s с помощью terraform и ansible

Для сборки:

  • перейти в каталог kubernetes, выполнить

    make

Для проверки:

  • подключиться по ssh к master инстансу K8s, выполнить:

    kubectl get nodes

    [!NOTE]
    все ноды должны быть в соостоянии READY

    kubectl get po

    [!NOTE]
    все поды с приложениями должны быть в соостоянии Running


ДЗ по модулю "Применение системы логирования в инфраструктуре на основе Docker"

  • Обновил код в директории /src репозитория кодом обновленным кодом с функционалом логирования
  • С помощью yc cli создал инстанс в облаке
  • С помощью docker-machine инициализировал на инстансе докер хост систему
  • Собрал и запушил образы микросервисов в DockerHub
  • Добавил образ fluentd
  • Развернул систему логирования на стеке EFK
  • Настроил сбор структурированных логов, добавив фильтр для парсинга json-логов, приходящих от сервиса post
  • Настроил сбор неструктурированных логов, добавив фильтр для парсинга json-логов, приходящих от сервиса ui
  • Заменил регулярное выражение для парсинга json-логов, приходящих от сервиса ui, на grok-шаблоны
  • Составил конфигурацию Fluentd так, чтобы разбирались все форматы логов сервиса ui
  • Добавил Zipkin в систему логирования

Для сборки:

  • перейти в каталог logging, выполнить

    make

    [!NOTE]
    не забываем переключаться на удаленный докер демон в Yandex Cloud:
    eval $(docker-machine env docker-host)

Для проверки:


ДЗ по модулю "Введение в мониторинг. Модели и принципы работы систем мониторинга"

  • С помощью yc cli создал инстанс в облаке (команды обернул в скрипты)
  • С помощью docker-machine инициализировал на инстансе докер хост систему (команды обернул в скрипты)
  • Собрал образы микросервисов, Prometheus
  • Развернул на инстансе Prometheus и Node exporter
  • Запушил образы микросервисов и Prometheus в DockerHub
  • Написал Makefile для автоматизации действий (полная сборка проекта + отдельно push в DockerHub)
  • Добавил в Prometheus мониторинг MongoDB с использованием экспортера (версия образа последняя стабильная)
  • Добавил в Prometheus мониторинг сервисов comment, post, ui с помощью blackbox exporter (версия образа последняя стабильная)

    [!WARNING]
    НЕ удалять из файла prometheus.yaml комментарий # Target to probe with http on port 9292.
    по нему sed'ом в Makefile идет поиск IP VM для замены на актуальны при пересоздании VM

Для сборки:

  • перейти в каталог monitoring, выполнить

    make

    [!NOTE]
    не забываем переключаться на удаленный докер демон в Yandex Cloud:
    eval $(docker-machine env docker-host)

Для отправки образов в DockerHub:

  • перейти в каталог monitoring, выполнить

    make push

Для проверки:


ДЗ по модулю "Сетевое взаимодействие Docker контейнеров. Docker Compose. Тестирование образов"

  • Познакомился с сетями в Docker, с утилитой docker-compose.
  • Собрал образы приложения reddit с помощью docker-compose.
  • Запустил приложение reddit с помощью docker-compose.
  • Изменил docker-compose.yml под кейс с множеством сетей, сетевых алиасов.
  • Параметровал с помощью переменных окружений:
    • порт публикации сервиса ui
    • версии сервисов
    • имя проекта
    • имя пользователя
  • Параметризованные параметры записал в отдельный файл
  • Имя проекта формируется из имени каталога, откуда запускается docker-compose. Первая часть имени контейнера (до первого "-") - это имя проекта. Вторая часть имени контейнера (до второго "-") - это название сервиса из docker-compose.yml. Изменить имя можно одним из следующих способов (в таком случае изменится только первая часть имени контейнера):
    • при запуске docker-compose добавить флаг --project-name / -p и указать имя проекта либо задать переменную окружения COMPOSE_PROJECT_NAME
    • в docker-compose.yml использовать параметр name (переменная верхнего уровня) Также полностью изменить имя контейнера можно, задав параметр container_name, в docker-compose.yml.
  • Создал docker-compose.override.yml для reddit проекта, который позволяет:
    • изменять код каждого из приложений, не выполняя сборку образа
    • запускать puma для руби приложений в дебаг режиме с двумя воркерами (флаги --debug и -w 2)

    [!WARNING]
    НО!!! при использовании docker-machine volumes с локальной машины не монтируются на удаленную.

Для сборки:

  • перейти в каталог docker-monolith

  • поднять инстанс, запустив скрипт:

    bash infra_create.sh
  • запустить docker-machine на удаленном хосте:

    bash env_init.sh
  • переключиться на удаленный докер демон в Yandex Cloud:

    eval $(docker-machine env docker-host)
  • перейти в каталог src, выполнить

    docker compose up -d

Для проверки:


ДЗ по модулю "Docker образы. Микросервисы"

  • Создал новую структуру приложения из трех компонентов

  • Создал сеть для контейнеров

  • Собрал приложение:

    • post-py - сервис отвечающий за написание постов
    • comment - сервис отвечающий за написание комментариев
    • ui - веб-интерфейс, работающий с другими сервисами
  • Реализовал запуск контейнеров с другими сетевыми алиасами

  • Собрал все образы на основе Alpine Linux

  • Уменьшил размер всех образов

  • Подключил volume к контейнеру с БД

Для сборки:

  • перейти в каталог docker-monolith

  • поднять инстанс, запустив скрипт:

    bash infra_create.sh
  • подставить IP адрес созданной VM в скрипт env_init.sh и запустить его:

    bash env_init.sh
  • переключиться на удаленный докер демон в Yandex Cloud:

    eval $(docker-machine env docker-host)
  • Если установлена утилита Make, выполнить команду:

    make
  • Если утилита Make не установлена:

    • скачать НЕ последний образ MongoDB:

      docker pull mongo:5.0
    • перейти в каталог src

    • собрать образы с нашими сервисами:

      docker build -t cmero/post:1.0 ./post-py
      docker build -t cmero/comment:1.0 ./comment
      docker build -t cmero/ui:1.0 ./ui
    • создать сеть и том для приложения и запустить контейнеры:

      docker network create reddit
      docker volume create reddit_db
      docker run -d --network=reddit --network-alias=post_db --network-alias=comment_db -v reddit_db:/data/db mongo:5.0
      docker run -d --network=reddit --network-alias=post cmero/post:1.0
      docker run -d --network=reddit --network-alias=comment cmero/comment:1.0
      docker run -d --network=reddit -p 9292:9292 cmero/ui:1.0
  • Для запуска контейнеров с другими сетевыми алиасами:

    make run_2

    либо

    docker run -d --network=reddit --network-alias=post_db2 --network-alias=comment_db2 mongo:5.0
    docker run -d --network=reddit --network-alias=post2 -e POST_DATABASE_HOST=post_db2 cmero/post:1.0
    docker run -d --network=reddit --network-alias=comment2 -e COMMENT_DATABASE_HOST=comment_db2 cmero/comment:1.0
    docker run -d --network=reddit -p 9292:9292 -e POST_SERVICE_HOST=post2 -e COMMENT_SERVICE_HOST=comment2 cmero/ui:1.0

Для проверки:


ДЗ по модулю "Docker контейнеры. Docker под капотом"

  • Установил docker, docker-compose, docker-machine
  • Создал свой docker image
  • Описал различия между контейнером и образом
  • С помощью yc cli создал ВМ в облаке (команды обернул в скрипты)
  • С помощью docker-machine инициализировал на инстансе докер хост систему (команды обернул в скрипты)
  • Собрал образ reddit на инстансе, запустил контейнер на его оснве
  • Загрузил образ на docker hub
  • Запустил контейнер на основе образа из docker hub на локальной машине

Для сборки:

  • перейти в каталог docker-monolith

  • поднять инстанс, запустив скрипт:

    bash infra_create.sh
  • подставить IP адрес созданной VM в скрипт env_init.sh и запустить его:

    bash env_init.sh
  • переключиться на удаленный докер демон в Yandex Cloud:

    eval $(docker-machine env docker-host)
  • собрать образ на удаленном хосте:

    docker build -t reddit:latest .

    [!WARNING]
    точка в конце обязательна, она указывает на путь до Docker-контекста

  • запустить контейнер на удаленном хосте:

    docker run --name reddit -d --network=host reddit:latest

Для проверки:

Задание со *

  • Все файлы находятся в каталоге docker-monolith/infra
  • Реализовал поднятие инстансов с помощью Terraform (на основе образа ubuntu-1604-lts), их количество задается переменной
  • Динамический инвентори генерируется с помощью Terraform
  • Написал 2 плейбука Ansible для установки Docker и запуска там образа приложения
  • Создал Packer-шаблон (packer.json), содержащий описание VM с установленным Docker

Для сборки:

  • перейти в каталог docker-monolith/infra

  • поднять инстанс, выполнив команды:

    terraform init
    terraform plan
    terraform apply
  • запустить плейбук Ansible для установки Docker (если используется образ без установленного Docker):

    ansible-playbook install_docker.yml
  • запустить плейбук Ansible для запуска на инстансе образа приложения:

    ansible-playbook start_container.yml

Для сборки Packer-образа выполнить команду:

  • выполнить сборку образов:

    packer build -var-file=variables.json packer.json

Note

в variables.tf добавил переменную docker_image_id с ID образа, созданного Packer'ом