Упражнение. Настройка среды Azure DevOps
В этом разделе описано, как настроить организацию Azure DevOps для завершения остальной части этого модуля. Вы также создадите среды службы приложение Azure, которые будут развернуты.
Для выполнения этих задач выполните следующие действия:
- Добавьте пользователя, чтобы убедиться, что Azure DevOps может подключиться к подписке Azure.
- Настройте проект Azure DevOps для этого модуля.
- Переместите рабочий элемент для этого модуля в Azure Boards в столбец "Выполнение ".
- Создайте среды службы приложение Azure с помощью Azure CLI в Azure Cloud Shell.
- Создайте переменные конвейера, определяющие имена сред Служба приложений.
- Создайте подключение к службе, позволяющее Azure Pipelines безопасно получить доступ к подписке Azure.
Добавление пользователя в Azure DevOps
Чтобы завершить этот модуль, вам потребуется собственная подписка Azure. Вы можете бесплатно приступить к работе с Azure.
Хотя вам не нужна подписка Azure для работы с Azure DevOps, здесь вы будете использовать Azure DevOps для развертывания в ресурсах, существующих в подписке Azure. Чтобы упростить процесс, войдите в подписку Azure и организацию Azure DevOps в одной учетной записи Майкрософт.
Если вы используете разные учетные записи Майкрософт для входа в Azure и Azure DevOps, добавьте пользователя в организацию DevOps в учетной записи Майкрософт, которую вы используете для входа в Azure. Дополнительные сведения см. в разделе "Добавление пользователей в организацию или проект". При добавлении пользователя выберите уровень доступа "Базовый".
Затем выйдите из Azure DevOps. Затем снова войдите в учетную запись Майкрософт, используемую для входа в подписку Azure.
Получение проекта Azure DevOps
Здесь необходимо убедиться, что ваша организация Azure DevOps настроена для завершения остальной части этого модуля. Чтобы выполнить эту задачу, выполните шаблон, создающий проект в Azure DevOps.
Модули в этой схеме обучения формируют прогрессию, когда вы следуете веб-команде Tailspin через свое путешествие DevOps. Для обучения каждый модуль имеет связанный проект Azure DevOps.
Запуск шаблона
Запустите шаблон, который настраивает все в организации Azure DevOps.
На сайте демонстрационного генератора Azure DevOps выполните следующие действия, чтобы запустить шаблон:
Выберите вход и примите условия использования.
На странице "Создание проекта" выберите организацию Azure DevOps. Затем введите имя проекта, например Space Game — веб-функциональные тесты.
Выберите "Да", я хочу вставить этот репозиторий. Затем выберите "Авторизовать".
Выберите "Создать проект".
Выполнение шаблона занимает несколько минут.
Выберите "Перейти к проекту ", чтобы перейти к проекту в Azure DevOps.
Внимание
Страница Очистка среды Azure DevOps в этом модуле содержит важные инструкции по очистке. Очистка позволяет гарантировать, что вам хватит бесплатных минут сборки. Обязательно выполните действия по очистке, даже если не завершите этот модуль.
Настройка видимости проекта
Изначально для вашего вилки репозитория Space Game на GitHub установлено общедоступное значение, пока для проекта, созданного шаблоном Azure DevOps, задано частное значение. Доступ к общедоступный репозиторий на GitHub можно получить любым пользователям, в то время как частный репозиторий доступен только для вас, и пользователи, с которыми вы хотите поделиться им. Аналогичным образом, в Azure DevOps общедоступные проекты предоставляют доступ только для чтения пользователям, не прошедшим проверку подлинности, в то время как частные проекты требуют предоставления пользователям доступа и проверки подлинности для доступа к службам.
На данный момент не требуется изменять какие-либо из этих параметров в целях этого модуля. Однако для личных проектов необходимо определить видимость и доступ, которые вы хотите предоставить другим пользователям. Например, если проект открытый код, вы можете сделать репозиторий GitHub и проект Azure DevOps общедоступным. Если проект является закрытым, обычно вы сделаете репозиторий GitHub и проект Azure DevOps закрытым.
Далее вы можете найти следующие ресурсы, которые помогут определить, какой вариант лучше всего подходит для вашего проекта:
- Использование частных и общедоступных проектов
- Краткое руководство. Предоставление общедоступного частного проекта
- Настройка видимости репозитория
Перемещение рабочего элемента в раздел "Выполняется"
В этой части вы назначаете себе рабочий элемент в Azure Boards, которые относятся к этому модулю. Вы также перемещаете рабочий элемент в состояние "Выполнение ". На практике ваша команда создаст рабочие элементы в начале каждой итерации спринта или работы.
Назначение работы таким образом дает вам список проверка, из которого следует работать. Он дает вашей команде представление о том, над чем вы работаете, и сколько работы осталось. Она также помогает команде применять ограничения на работу в ходе работы (WIP), чтобы избежать слишком много работы в один раз.
Напомним, что команда урегулировала эти основные вопросы для текущего спринта:
Примечание.
В организации Azure DevOps рабочие элементы нумеруются последовательно. В проекте число каждого рабочего элемента может не совпадать с тем, что вы видите здесь.
Здесь вы перемещаете третий элемент, автоматизируйте тесты качества в столбец "Выполнение ". Затем вы назначаете себя рабочему элементу. Автоматизация тестов качества связана с автоматизацией тестов пользовательского интерфейса для веб-сайта Space Game .
Чтобы настроить рабочий элемент, выполните указанные ниже действия.
В Azure DevOps перейдите в Boards и выберите "Доски " в меню.
В рабочем элементе "Автоматизация тестов качества" щелкните стрелку вниз в нижней части карта. Затем назначьте рабочий элемент себе.
Переместите рабочий элемент из столбца Список дел в столбец "Выполнение".
В конце этого модуля после завершения задачи вы переместите карта в столбец "Готово".
Локальная настройка проекта
Здесь вы загружаете проект Space Game в Visual Studio Code, настраиваете Git, клонируйте репозиторий локально и установите вышестоящий удаленный, чтобы можно было скачать начальный код.
Примечание.
Если вы уже настроили проект mslearn-tailspin-spacegame-web-deploy локально, вы можете перейти к следующему разделу.
Открытие интегрированного терминала
Visual Studio Code поставляется с интегрированным терминалом. Здесь можно редактировать файлы и работать из командной строки.
Запустите Visual Studio Code.
В меню "Вид" выберите терминал.
В раскрывающемся списке выберите Git Bash. Если вы знакомы с другой оболочкой Unix, которую вы предпочитаете использовать, выберите эту оболочку.
В окне терминала можно выбрать любую оболочку, установленную в вашей системе. Например, можно выбрать Git Bash или PowerShell или другую оболочку.
Здесь вы будете использовать Git Bash, часть Git для Windows, что упрощает выполнение команд Git.
Примечание.
В Windows, если вы не видите Git Bash в списке в качестве параметра, убедитесь, что вы установили Git, а затем перезапустите Visual Studio Code.
Выполните команду
cd
, чтобы перейти в каталог, в котором вы будете работать. Выберите свой домашний каталог (~
) или другой каталог, если хотите.cd ~
Настройка Git
Если вы не знакомы с Git и GitHub, сначала выполните несколько команд, чтобы связать удостоверение с Git и пройти проверку подлинности с помощью GitHub. Дополнительные сведения см. в разделе "Настройка Git".
Как минимум, необходимо выполнить следующие действия. Выполните команды из интегрированного терминала.
- Задайте имя пользователя.
- Задайте адрес электронной почты фиксации.
- Кэшируйте пароль GitHub.
Примечание.
Если вы уже используете двухфакторную проверку подлинности с GitHub, создайте личный маркер доступа. При появлении запроса используйте маркер вместо пароля.
Обратитесь к маркеру доступа как к паролю. Держите его в безопасном месте.
Настройка проекта в Visual Studio Code
В приложениях сборки с помощью схемы обучения Azure DevOps вы клонировали и клонировали репозиторий Git. Репозиторий содержит исходный код для веб-сайта Space Game . Ваш вилку был подключен к вашим проектам в Azure DevOps, чтобы сборка выполнялась при отправке изменений в GitHub.
Внимание
В этой схеме обучения мы переключимся на другой репозиторий Git, mslearn-tailspin-spacegame-web-deploy. При запуске шаблона для настройки проекта Azure DevOps процесс автоматически закрепил репозиторий.
В этой части клонируйте вилку локально, чтобы можно было изменить и построить конфигурацию конвейера.
Клонирование вилки локально
Теперь у вас есть копия веб-проекта Space Game в вашей учетной записи GitHub. Теперь вы скачайте или клонируете копию на компьютер, чтобы вы могли работать с ней.
Клон, как и вилка, является копией репозитория. Клонируйте репозиторий, вы можете внести изменения, убедиться, что они работают должным образом, а затем передать эти изменения в GitHub. Вы также можете синхронизировать локальную копию с изменениями, внесенными другими пользователями, прошедшими проверку подлинности, в копию репозитория GitHub.
Чтобы клонировать веб-проект Space Game на компьютер:
Перейдите в вилку веб-проекта Space Game (mslearn-tailspin-spacegame-web-deploy) на сайте GitHub.
Выберите Код. Затем на вкладке HTTPS нажмите кнопку рядом с URL-адресом, чтобы скопировать URL-адрес в буфер обмена.
В Visual Studio Code перейдите в окно терминала.
В терминале перейдите в каталог, где вы хотите работать. Выберите свой домашний каталог (
~
) или другой каталог, если хотите.cd ~
Выполните команду
git clone
. Замените URL-адрес, показанный здесь содержимым буфера обмена:git clone https://github.com/your-name/mslearn-tailspin-spacegame-web-deploy.git
Перейдите в каталог
mslearn-tailspin-spacegame-web-deploy
. Это корневой каталог репозитория.cd mslearn-tailspin-spacegame-web-deploy
Настройка вышестоящего удаленного репозитория
Удаленный — это репозиторий Git, в котором участники группы совместно работают (например, репозиторий на GitHub). Здесь вы выводите список удаленных репозиториев и добавляете удаленный репозиторий, указывающий на копию репозитория Майкрософт, чтобы вы могли получить актуальный пример кода.
Выполните следующую
git remote
команду, чтобы вывести список удаленных элементов:git remote -v
Вы видите, что у вас есть доступ к репозиторию как для получения (скачивания), так и отправки (отправки):
origin https://github.com/username/mslearn-tailspin-spacegame-web-deploy.git (fetch) origin https://github.com/username/mslearn-tailspin-spacegame-web-deploy.git (push)
Источник указывает репозиторий на сайте GitHub. При вводе кода из другого репозитория исходный удаленный (который вы вилировали из) часто называется вышестоящий.
Выполните команду
git remote add
, чтобы создать удаленный именованный вышестоящий репозиторий, указывающий на репозиторий Майкрософт:git remote add upstream https://github.com/MicrosoftDocs/mslearn-tailspin-spacegame-web-deploy.git
Запустите
git remote
еще раз, чтобы увидеть изменения:git remote -v
Вы видите, что у вас по-прежнему есть доступ (скачивание) и отправка (отправка) доступа к репозиторию. Теперь у вас также есть доступ к репозиторию Майкрософт:
origin https://github.com/username/mslearn-tailspin-spacegame-web-deploy.git (fetch) origin https://github.com/username/mslearn-tailspin-spacegame-web-deploy.git (push) upstream https://github.com/MicrosoftDocs/mslearn-tailspin-spacegame-web-deploy.git (fetch)
Откройте проект в обозревателе файлов
В Visual Studio Code окно терминала указывает на корневой каталог веб-проекта Space Game. Чтобы просмотреть ее структуру и работать с файлами, из проводника вы откроете проект.
Самый простой способ открыть проект заключается в повторном открытии Visual Studio Code в текущем каталоге. Для этого во встроенном терминале выполните следующую команду.
code -r .
В обозревателе вы увидите каталог и дерево файлов.
Откройте интегрированный терминал. Вы будете перемещены в корень веб-проекта.
Если выполнение команды code
завершается неудачно, необходимо добавить Visual Studio Code в системную переменную PATH. Для этого:
- В Visual Studio Code выберите F1 или Представление>Палитра команд для доступа к палитре команд.
- В палитре команд введите команду shell: установите команду "code" в PATH.
- Повторите предыдущую процедуру, чтобы открыть проект в проводнике.
Теперь вы настроили работу с исходным кодом Space Game и конфигурацией Azure Pipelines из локальной среды разработки.
Создание сред службы приложение Azure
Здесь вы создадите среды, определяющие этапы конвейера. Вы создаете один Служба приложений экземпляр, соответствующий каждому этапу: разработка, тестирование и промежуточное выполнение.
В модуле Azure Pipelines с помощью модуля Azure Pipelines вы использовали Azure CLI для создания Служба приложений экземпляров. Здесь вы будете делать то же самое.
Внимание
Чтобы выполнить упражнения в этом уроке, необходима собственная подписка Azure.
Создание Cloud Shell с помощью портал Azure
- Перейдите на портал Azure и войдите в систему.
- В строке меню выберите Cloud Shell. При появлении запроса выберите интерфейс Bash .
Выбор региона Azure
Здесь вы указываете регион по умолчанию или географическое расположение, в котором будут созданы ресурсы Azure.
В Cloud Shell выполните следующую
az account list-locations
команду, чтобы получить список регионов, доступных в подписке Azure.az account list-locations \ --query "[].{Name: name, DisplayName: displayName}" \ --output table
В столбце "Имя" в выходных данных выберите регион, близкий к вам. Например, выберите eastasia или westus2.
Запустите
az configure
, чтобы задать регион по умолчанию. Замените <REGION> именем выбранного региона.az configure --defaults location=<REGION>
Ниже приведен пример, который задает westus2 в качестве региона по умолчанию:
az configure --defaults location=westus2
Создание экземпляров Служба приложений
Здесь вы создадите экземпляры Службы приложений для трех этапов: разработки, тестирования и промежуточного хранения.
Примечание.
Для обучения здесь используются параметры сети по умолчанию. Эти параметры делают сайт доступным из Интернета. На практике вы можете настроить виртуальную сеть Azure, которая помещает веб-сайт в сеть, которая не доступна в Интернете, и это доступно только для вас и вашей команды. Позже, когда вы будете готовы, вы можете перенастроить сеть, чтобы сделать веб-сайт доступным для пользователей.
Из Cloud Shell создайте случайное число, которое делает доменное имя веб-приложения уникальным.
webappsuffix=$RANDOM
Выполните следующую команду
az group create
, чтобы создать группу ресурсов с именем tailspin-space-game-rg.az group create --name tailspin-space-game-rg
Выполните следующую команду
az appservice plan create
, чтобы создать план Службы приложений с именем tailspin-space-game-asp.az appservice plan create \ --name tailspin-space-game-asp \ --resource-group tailspin-space-game-rg \ --sku B1 \ --is-linux
Аргумент
--sku
указывает план B1, который выполняется на уровне Базовый. Аргумент--is-linux
определяет использование рабочих ролей Linux.Внимание
Если номер SKU B1 не входит в подписку Azure, выберите другой план, например S1 (цен. категория "Стандартный").
Выполните следующие команды
az webapp create
, чтобы создать три экземпляра Службы приложений: по одному для каждой среды — разработки, тестирования и промежуточной.az webapp create \ --name tailspin-space-game-web-dev-$webappsuffix \ --resource-group tailspin-space-game-rg \ --plan tailspin-space-game-asp \ --runtime "DOTNET|6.0" az webapp create \ --name tailspin-space-game-web-test-$webappsuffix \ --resource-group tailspin-space-game-rg \ --plan tailspin-space-game-asp \ --runtime "DOTNET|6.0" az webapp create \ --name tailspin-space-game-web-staging-$webappsuffix \ --resource-group tailspin-space-game-rg \ --plan tailspin-space-game-asp \ --runtime "DOTNET|6.0"
В целях обучения здесь вы применяете один и тот же план Служба приложений (B1 Basic) к каждому экземпляру Служба приложений. На практике вы назначите план, соответствующий ожидаемой рабочей нагрузке.
Выполните следующую
az webapp list
команду, чтобы указать имя узла и состояние каждого Служба приложений экземпляра.az webapp list \ --resource-group tailspin-space-game-rg \ --query "[].{hostName: defaultHostName, state: state}" \ --output table
Обратите внимание на имя узла для каждой работающей службы. Эти имена узлов потребуются позже при проверке работы. Приведем пример:
HostName State ------------------------------------------------------- ------- tailspin-space-game-web-dev-21017.azurewebsites.net Running tailspin-space-game-web-test-21017.azurewebsites.net Running tailspin-space-game-web-staging-21017.azurewebsites.net Running
В качестве дополнительного шага скопируйте и вставьте одно или несколько имен в браузер, чтобы убедиться, что они запущены, и отображается домашняя страница по умолчанию.
Вы должны получить эту страницу:
Внимание
Страница Очистка среды Azure DevOps в этом модуле содержит важные инструкции по очистке. Очистка помогает убедиться, что вы не взимаете плату за ресурсы Azure после завершения работы с этим модулем. Обязательно выполните действия по очистке, даже если не завершите этот модуль.
Создание переменных конвейера в Azure Pipelines
В конвейере создания нескольких этапов с помощью Azure Pipelines вы добавили одну переменную для каждого из Служба приложений экземпляров, которые соответствуют этапам разработки, тестирования и промежуточного хранения в конвейере. Здесь вы делаете то же самое.
Каждый этап в конфигурации конвейера использует эти переменные, чтобы определить, в каком Служба приложений экземпляре развертывается.
Чтобы добавить переменные, выполните следующие действия.
В Azure DevOps перейдите в проект Space Game — веб-функциональные тесты .
В разделе "Конвейеры" выберите библиотеку.
Выберите и группу переменных.
В разделе "Свойства" введите имя группы переменных.
В разделе "Переменные" нажмите кнопку +Добавить.
Для имени переменной введите WebAppNameDev. В качестве значения введите имя экземпляра Служба приложений, соответствующего вашей среде разработки, например tailspin-space-game-web-dev-1234.
Повторите шаги 5 и 6 еще раз, чтобы создать переменные для сред тестирования и промежуточного хранения , как показано в этой таблице:
Имя переменной Пример значения WebAppNameTest tailspin-space-game-web-test-1234 WebAppNameStaging tailspin-space-game-web-staging-1234 Обязательно замените каждое значение примера на экземпляр Служба приложений, соответствующий вашей среде.
Внимание
Задайте имя экземпляра Служба приложений, а не имя узла. В этом примере вы введете tailspin-space-game-web-dev-1234 , а не tailspin-space-game-web-dev-1234.azurewebsites.net.
В верхней части страницы нажмите кнопку "Сохранить ", чтобы сохранить переменную в конвейере.
Ваша группа переменных должна выглядеть следующим образом:
Создание сред разработки, тестирования и промежуточного хранения
В упражнении Создание многоступенчатого конвейера с помощью Azure Pipelines вы создали среды для сред разработки, тестированияи промежуточной обработки. Здесь вы повторяете этот же процесс. Однако на этот раз вы пропускаете дополнительные критерии, такие как требование утверждения человеком для продвижения изменений с одного этапа на следующий.
Чтобы создать среды разработки, тестирования и промежуточной обработки, выполните следующие действия.
В Azure Pipelines выберите "Среды".
Чтобы создать среду разработки, выполните следующие действия:
- Нажмите Создать среду.
- В поле Имя введите dev.
- В остальных полях оставьте значения по умолчанию.
- Нажмите кнопку создания.
Чтобы создать тестовую среду, выполните следующие действия:
- Вернитесь на страницу Среды.
- Выберите новую среду.
- В поле Имя введите test.
- Нажмите кнопку создания.
Чтобы создать промежуточную среду, выполните следующие действия.
- Вернитесь на страницу Среды.
- Выберите новую среду.
- В разделе "Имя" введите промежуточное значение.
- Нажмите кнопку создания.
Создание подключения службы
Здесь вы создадите подключение к службе, позволяющее Azure Pipelines получить доступ к подписке Azure. Azure Pipelines использует это подключение к службе для развертывания веб-сайта в Служба приложений. Вы создали аналогичное подключение к службе в предыдущем модуле.
Внимание
Убедитесь, что вы вошли в портал Azure и Azure DevOps под одной учетной записью Майкрософт.
В Azure DevOps перейдите в проект Space Game — веб-функциональные тесты .
В нижнем углу страницы выберите параметры проекта.
В разделе Конвейеры выберите Подключения к службе.
Выберите новое подключение к службе, а затем выберите Azure Resource Manager, а затем нажмите кнопку "Далее".
В верхней части страницы субъект-служба (автоматически). Затем выберите Далее.
Заполните следующие поля:
Поле значение Уровень области Подписка Отток подписок Ваша подписка Azure Группа ресурсов tailspin-space-game-rg Имя подключения службы Resource Manager — Tailspin — Space Game Во время процесса может появиться запрос на вход в учетную запись Майкрософт.
Убедитесь, что выбрано разрешение на доступ ко всем конвейерам .
Выберите Сохранить.
Azure DevOps выполняет тестовое подключение, чтобы убедиться, что он может подключиться к подписке Azure. Если Azure DevOps не удается подключиться, у вас есть возможность войти во второй раз.