Упражнение. Настройка среды

Завершено

В этом упражнении вы настроите предварительно настроенную среду с помощью Load Balancer и создадите диаграммы для мониторинга работоспособности Load Balancer.

Это необязательное упражнение. Для его выполнения необходим доступ к подписке Azure, в которой можно создавать ресурсы Azure. Если у вас нет подписки Azure, создайте бесплатную учетную запись, прежде чем приступить к работе.

Настройка среды

  1. Войдите на портал Azure.

  2. В строке меню в правой верхней части страницы выберите Cloud Shell.

  3. Выберите Bash.

  4. Выполните следующую команду, чтобы скачать скрипты, используемые для этого упражнения.

    git clone https://github.com/MicrosoftDocs/mslearn-troubleshoot-inbound-network-connectivity-azure-load-balancer load-balancer
    
  5. Перейдите в папку load-balancer/src/scripts.

    cd ~/load-balancer/src/scripts
    
  6. Выполните приведенную ниже команду, чтобы задать имя пользователя для виртуальных машин. Имя пользователя можно изменить на другое. Вам потребуется имя пользователя позже в этом упражнении, поэтому запишите то, что вы используете.

    export USERNAME=azureuser
    
  7. Выполните приведенную ниже команду, чтобы задать пароль для виртуальных машин, созданных сценариями. Пароль хранится в переменной, а также записывается в текстовый файл passwd.txt на тот случай, если он потребуется позже.

    export PASSWORD=$(openssl rand -base64 32)
    echo $PASSWORD > passwd.txt
    
  8. Укажите имя группы ресурсов.

    export RESOURCEGROUP=learn-ts-loadbalancer-rg
    
  9. Укажите расположение. Замените значение eastus на ближайшее к вам расположение.

    export LOCATION=eastus
    

    Ниже перечислены некоторые возможные значения расположения:

    • westus2
    • центрально-южная часть США
    • centralus
    • eastus
    • westeurope
    • юго-восточная Азия
    • japaneast
    • brazilsouth
    • australiasoutheast
    • centralindia
  10. Выполните приведенную ниже команду, чтобы создать группу ресурсов.

    az group create --name $RESOURCEGROUP --location $LOCATION
    
  11. Выполните приведенную ниже команду, чтобы создать подсистему балансировки нагрузки, виртуальные машины и виртуальную сеть.

    bash setup.sh $RESOURCEGROUP
    

    Выполнение сценария займет до 25 минут.

Проверка созданных ресурсов

  1. На портале Azure найдите Группы ресурсов.

  2. Выберите learn-ts-loadbalancer-rg.

  3. Отсортируйте список ресурсов по типу.

  4. Группа ресурсов должна содержать ресурсы, указанные в этой таблице.

    Имя. Тип Описание
    retailappvm1_disk1_xxx и retailappvm1_disk2_xxx Диск Виртуальные жесткие диски для двух виртуальных машин.
    retailapplb Подсистема балансировки нагрузки Подсистема балансировки нагрузки для приложения, выполняемого на виртуальных машинах. Внутренний пул в подсистеме балансировки нагрузки ссылается на виртуальные машины retailappvm1 и retailappvm2.
    nicvm1 и nicvm2 Сетевой интерфейс Сетевые интерфейсы для двух виртуальных машин.
    retailappnicvm1nsg и retailappnicvm2nsg Группа безопасности сети (NSG) Группы безопасности сети, управляющие трафиком, поступающим на каждую виртуальную машину.
    retailappnsg группу безопасности сети; Выступает в качестве начального фильтра для обеих виртуальных машин, но группа безопасности сети для каждой виртуальной машины позволяет фильтровать трафик на основе каждого компьютера.
    retailappip Общедоступный IP-адрес Общедоступный IP-адрес, предоставляющий интерфейсный доступ к подсистеме балансировки нагрузки.
    retailappvm1 и retailappvm2 Виртуальная машина Виртуальные машины, на которых выполняется приложение розничной торговли.
    retailappvmjumpbox Виртуальная машина Виртуальная машина, которая также находится в виртуальной сети, но имеет общедоступный IP-адрес. Администратор может войти на эту виртуальную машину, чтобы получить доступ к виртуальным машинам retailappvm1 и retailappvm2, которые имеют только частные IP-адреса.
    retailappvnet Виртуальная сеть Виртуальная сеть для виртуальных машин.
  5. Выберите подсистему балансировки нагрузки retailapplb.

  6. В разделе Параметры выберите Правила балансировки нагрузки.

  7. Выберите retailapprule. Подсистема балансировки нагрузки настроена для маршрутизации трафика, поступающего на порт 80 внешнего адреса, на порт 80 машин во внутреннем пуле.

  8. Закройте панель retailapprule.

  9. В разделе Параметры выберите Зонды работоспособности.

  10. Выберите retailapphealthprobe. Проба работоспособности для внутреннего пула также отправляет сообщения на порт 80, чтобы убедиться, что приложение доступно на каждой виртуальной машине.

  11. Закройте панель retailapphealthprobe.

Тестирование подсистемы балансировки нагрузки

  1. Вернитесь в Azure Cloud Shell.

  2. Выполните следующую команду, чтобы получить общедоступный IP-адрес внешнего интерфейса подсистемы балансировки нагрузки.

    bash findip.sh
    
  3. Откройте браузер и перейдите по этому IP-адресу. Результатом должно быть страница с сообщением retailappvm1 или retailappvm2 в зависимости от того, как подсистема балансировки нагрузки направляет запрос.

    Screenshot of the browser showing the response from the sample app running in Load Balancer.

  4. В Cloud Shell выполните следующую команду, чтобы перейти в папку src/stresstest.

    cd ~/load-balancer/src/stresstest
    

    Эта папка содержит приложение .NET Core, которое имитирует сотни одновременно работающих пользователей, отправляющих запросы на виртуальные машины через Load Balancer.

  5. Запустите приложение с помощью приведенной ниже команды. Замените элемент <ip address> внешним IP-адресом подсистемы балансировки нагрузки.

    dotnet run <ip address>
    

    Приложение должно ответить рядом сообщений, указывающих, был ли получен ответ от retailappvm1 или retailappvm2.

  6. Дайте приложению поработать в течение пяти минут. Чтобы остановить приложение, нажмите клавишу ВВОД.

Создание диаграмм для мониторинга метрик

  1. На портале Azure перейдите к группе ресурсов learn-ts-loadbalancer-rg.

  2. Выберите подсистему балансировки нагрузки retailapplb.

  3. В разделе Мониторинг выберите Метрики.

  4. Добавьте приведенную ниже метрику на пустую диаграмму.

    Свойство Значение
    Область retailapplb
    Пространство имен метрики Стандартные метрики подсистемы балансировки нагрузки
    Метрика Число пакетов
    Агрегат Ср.
  5. В верхней части страницы задайте диапазон Последние 30 минут. Диаграмма должна выглядеть примерно следующим образом. Обратите внимание на пиковое значение среднего числа пакетов.

    Chart showing the average packet count while the load balancer is in a healthy state.

  6. Кроме того, установите флажок Закрепить на панели мониторинга.

  7. Выберите Создать и введите следующие значения.

    Поле значение
    Тип Private
    Имя панели мониторинга dashboard-learn-ts-loadbalancer
  8. Выберите Создать и закрепить.

  9. Выберите Создать диаграмму и добавьте следующую метрику.

    Свойство Значение
    Область retailapplb
    Пространство имен метрики Стандартные метрики подсистемы балансировки нагрузки
    Метрика Health Probe Status (Состояние пробы работоспособности)
    Агрегат Ср.
  10. Выберите Добавить метрику и добавьте еще одну метрику на диаграмму, введя приведенные ниже значения.

    Свойство Значение
    Область retailapplb
    Пространство имен метрики Стандартные метрики подсистемы балансировки нагрузки
    Метрика Data Path Availability (Доступность пути к данным)
    Агрегат Ср.
  11. Задайте диапазон Последние 30 минут. Диаграмма должна выводить статистику по обеим метрикам в масштабе 100 %.

  12. Выберите Закрепить на панели мониторинга>Существующие.

  13. Для панели мониторинга выберите dashboard-learn-ts-loadbalancer.

  14. Выберите Закрепить.

Теперь у вас есть базовый набор метрик для системы, когда она работает правильно.