Дженкинс - Краткое руководство
Почему Дженкинс?
Jenkins - это программа, которая позволяет continuous integration. Jenkins будет установлен на сервере, на котором будет происходить центральная сборка. Следующая блок-схема демонстрирует очень простой рабочий процесс того, как работает Jenkins.
Наряду с Дженкинсом иногда можно увидеть ассоциацию Hudson. Hudson - очень популярный инструмент непрерывной интеграции на основе Java с открытым исходным кодом, разработанный Sun Microsystems, который позже был приобретен Oracle. После приобретения Sun компанией Oracle из исходного кода Hudson был создан форк, который привел к появлению Jenkins.
Что такое непрерывная интеграция?
Непрерывная интеграция - это практика разработки, которая требует от разработчиков регулярно интегрировать код в общий репозиторий. Эта концепция была предназначена для устранения проблемы обнаружения последующих проблем в жизненном цикле сборки. Непрерывная интеграция требует от разработчиков частых сборок. Обычная практика заключается в том, что всякий раз, когда происходит фиксация кода, должна запускаться сборка.
Системные Требования
JDK | JDK 1.5 или выше |
объем памяти | 2 ГБ ОЗУ (рекомендуется) |
Дисковое пространство | Нет минимальных требований. Обратите внимание: поскольку все сборки будут храниться на машинах Jenkins, необходимо убедиться, что для хранения сборок доступно достаточно дискового пространства. |
Версия операционной системы | Jenkins можно установить в Windows, Ubuntu / Debian, Red Hat / Fedora / CentOS, Mac OS X, openSUSE, FReeBSD, OpenBSD, Gentoo. |
Контейнер Java | Файл WAR можно запустить в любом контейнере, который поддерживает Servlet 2.4 / JSP 2.0 или новее (например, Tomcat 5). |
Скачать Jenkins
Официальный сайт Jenkins - Jenkins . Если вы нажмете данную ссылку, вы сможете попасть на домашнюю страницу официального сайта Jenkins, как показано ниже.
По умолчанию последняя версия и версия с долгосрочной поддержкой будут доступны для загрузки. Предыдущие выпуски также доступны для скачивания. Щелкните вкладку «Выпуск долгосрочной поддержки» в разделе загрузки.
Щелкните ссылку «Более старая, но стабильная версия», чтобы загрузить файл войны Дженкинса.
Запуск Jenkins
Откройте командную строку. В командной строке перейдите в каталог, в котором находится файл jenkins.war. Выполните следующую команду
D:\>Java –jar Jenkins.war
После запуска команды будут выполняться различные задачи, одна из которых - извлечение файла войны, которое выполняется встроенным веб-сервером под названием winstone.
D:\>Java –jar Jenkins.war
Running from: D:\jenkins.war
Webroot: $user.home/ .jenkins
Sep 29, 2015 4:10:46 PM winstone.Logger logInternal
INFO: Beginning extraction from war file
Когда обработка завершится без серьезных ошибок, в выводе командной строки появится следующая строка.
INFO: Jenkins is fully up and running
Доступ к Дженкинсу
Как только Jenkins запущен и работает, вы можете получить доступ к Jenkins по ссылке - http://localhost:8080
Эта ссылка откроет панель управления Jenkins.
Для установки Jenkins Tomcat должны быть выполнены следующие предварительные условия.
Шаг 1. Проверка установки Java
Чтобы проверить установку Java, откройте консоль и выполните следующую команду java.
Операционные системы | Задача | Команда |
---|---|---|
Windows | Открыть командную консоль | \> java –version |
Linux | Открыть командный терминал | $ java –version |
Если Java была правильно установлена в вашей системе, вы должны получить один из следующих результатов, в зависимости от платформы, на которой вы работаете.
Операционные системы | Вывод |
---|---|
Windows | Версия Java "1.7.0_60" Среда выполнения Java (TM) SE (сборка 1.7.0_60-b19) 64-разрядная серверная виртуальная машина Java Hotspot (TM) (сборка 24.60-b09, смешанный режим) |
Linux | версия java "1.7.0_25" Откройте среду выполнения JDK (rhel-2.3.10.4.el6_4-x86_64) Откройте виртуальную машину 64-разрядного сервера JDK (сборка 23.7-b01, смешанный режим) |
Мы предполагаем, что читатели этого руководства установили Java 1.7.0_60 в своей системе, прежде чем переходить к этому руководству.
Если у вас нет Java JDK, вы можете скачать его по ссылке Oracle
Шаг 2. Проверка установки Java
Установите переменную среды JAVA_HOME, чтобы она указывала на расположение базового каталога, в котором установлена Java на вашем компьютере. Например,
Операционные системы | Вывод |
---|---|
Windows | Установите для переменной среды JAVA_HOME значение C: \ ProgramFiles \ java \ jdk1.7.0_60 |
Linux | экспорт JAVA_HOME = / usr / local / java-current |
Добавьте полный путь расположения компилятора Java к системному пути.
Операционные системы | Вывод |
---|---|
Windows | Добавить строку; C: \ Program Files \ Java \ jdk1.7.0_60 \ bin до конца системной переменной PATH. |
Linux | экспорт ПУТЬ = $ ПУТЬ: $ JAVA_HOME / bin / |
Проверьте версию команды java из командной строки, как описано выше.
Шаг 3. Загрузите Tomcat
Официальный сайт Tomcat - Tomcat . Если вы нажмете данную ссылку, вы сможете перейти на домашнюю страницу официального сайта tomcat, как показано ниже.
Перейдите по ссылке https://tomcat.apache.org/download-70.cgi чтобы получить загрузку для tomcat.
Перейдите в раздел «Бинарные распределения». Загрузите 32-разрядный zip-файл Windows.
Затем разархивируйте содержимое загруженного zip-файла.
Шаг 4: установка Jenkins и Tomcat
Скопируйте файл Jenkis.war, который был загружен из предыдущего раздела, и скопируйте его в папку webapps в папке tomcat.
Теперь откройте командную строку. В командной строке перейдите в каталог, в котором находится папка tomcat7. Перейдите в каталог bin в этой папке и запустите файл start.bat.
E:\Apps\tomcat7\bin>startup.bat
Когда обработка завершится без серьезных ошибок, в выводе командной строки появится следующая строка.
INFO: Server startup in 1302 ms
Откройте браузер и перейдите по ссылке - http://localhost:8080/jenkins. Дженкинс будет работать на Tomcat.
Для этого упражнения вы должны убедиться, что подключение к Интернету присутствует с компьютера, на котором установлен Jenkins. На панели управления Jenkins (главный экран) щелкните параметр «Управление Jenkins» слева.
На следующем экране выберите опцию «Управление плагинами».
На следующем экране щелкните вкладку Доступные. На этой вкладке будет представлен список плагинов, доступных для загрузки. На вкладке "Фильтр" введите "Git plugin"
После этого список будет отфильтрован. Отметьте опцию Git Plugin и нажмите кнопку «Установить без перезапуска».
После этого начнется установка, и экран обновится, чтобы показать статус загрузки.
После завершения всех установок перезапустите Jenkins, введя в браузере следующую команду. http://localhost:8080/jenkins/restart
После перезапуска Jenkins Git будет доступен в качестве опции при настройке заданий. Чтобы проверить, нажмите «Новый элемент» в параметрах меню для Jenkins. Затем введите имя для работы, в следующем случае введенное имя - «Демо». В качестве типа элемента выберите «Проект Freestyle». Щелкните кнопку ОК.
На следующем экране, если вы перейдете в раздел «Управление исходным кодом», вы увидите вариант «Git».
Шаг 1: загрузка и настройка Maven
Официальный сайт maven - Apache Maven . Если вы нажмете данную ссылку, вы сможете перейти на домашнюю страницу официального сайта maven, как показано ниже.
При просмотре сайта перейдите в раздел Файлы и загрузите ссылку на файл Binary.zip.
После загрузки файла извлеките файлы в соответствующую папку приложения. Для этого файлы maven будут помещены в E: \ Apps \ apache-maven-3.3.3.
Шаг 2: настройка Jenkins и Maven
На панели управления Jenkins (главный экран) щелкните Управление Jenkins в левом меню.
Затем нажмите «Настроить систему» с правой стороны.
На экране «Настроить систему» прокрутите вниз, пока не увидите раздел Maven, а затем нажмите кнопку «Добавить Maven».
Снимите флажок «Установить автоматически».
Добавьте любое имя для настройки и расположение MAVEN_HOME.
Затем нажмите кнопку «Сохранить» в конце экрана.
Теперь вы можете создать задание с опцией «Проект Maven». На панели управления Jenkins щелкните параметр «Новый элемент».
Вы, вероятно, видели пару раз в предыдущих упражнениях, когда нам приходилось настраивать параметры в Jenkins. Ниже показаны различные варианты конфигурации в Jenkins.
Таким образом, можно получить различные параметры конфигурации для Jenkins, щелкнув опцию «Управление Jenkins» в левой части меню.
Затем вам будет представлен следующий экран -
Щелкните Настроить систему. Ниже обсуждаются некоторые параметры конфигурации Jenkins, которые можно выполнить.
Домашний каталог Jenkins
Дженкинсу требуется некоторое дисковое пространство для выполнения сборки и хранения архивов. Это местоположение можно проверить на экране конфигурации Jenkins. По умолчанию это ~ / .jenkins, и это местоположение изначально будет сохранено в вашем профиле пользователя. В подходящей среде вам необходимо изменить это местоположение на подходящее для хранения всех соответствующих сборок и архивов. Один раз можно сделать это следующими способами
Установите переменную среды «JENKINS_HOME» в новый домашний каталог перед запуском контейнера сервлета.
Установите системное свойство "JENKINS_HOME" для контейнера сервлета.
Установите запись среды JNDI "JENKINS_HOME" в новый каталог.
В следующем примере будет использоваться первый вариант установки переменной среды «JENKINS_HOME».
Сначала создайте новую папку E: \ Apps \ Jenkins. Скопируйте все содержимое из существующего ~ / .jenkins в этот новый каталог.
Установите переменную среды JENKINS_HOME, чтобы она указывала на расположение базового каталога, в котором установлена Java на вашем компьютере. Например,
Операционные системы | Вывод |
---|---|
Windows | Установите переменную среды JENKINS_HOME в нужное вам место. В качестве примера вы можете установить его на E: \ Apps \ Jenkins |
Linux | export JENKINS_HOME = / usr / local / Jenkins или в желаемое место. |
На панели управления Jenkins нажмите Manage Jenkins в левом меню. Затем нажмите «Настроить систему» с правой стороны.
В домашнем каталоге вы увидите новый настроенный каталог.
# исполнителей
Это относится к общему количеству одновременных выполнений заданий, которые могут выполняться на машине Jenkins. Это можно изменить в зависимости от требований. Иногда рекомендуется оставлять это число таким же, как количество ЦП на машинах для повышения производительности.
Переменные среды
Это используется для добавления пользовательских переменных среды, которые будут применяться ко всем заданиям. Это пары ключ-значение, к которым можно получить доступ и использовать в сборках везде, где это необходимо.
URL Jenkins
По умолчанию URL-адрес Jenkins указывает на localhost. Если у вас есть настройка доменного имени для вашего компьютера, установите это имя домена, иначе перезапишите localhost IP-адресом машины. Это поможет в настройке ведомых устройств и при отправке ссылок по электронной почте, поскольку вы можете напрямую получить доступ к URL-адресу Jenkins, используя переменную среды JENKINS_URL, к которой можно получить доступ как $ {JENKINS_URL}.
Уведомление по электронной почте
В области уведомлений по электронной почте вы можете настроить параметры SMTP для отправки электронных писем. Это необходимо для Jenkins, чтобы подключиться к почтовому серверу SMTP и отправлять электронные письма списку получателей.
Чтобы управлять Jenkins, нажмите на опцию «Manage Jenkins» в левой части меню.
Таким образом, можно получить различные параметры конфигурации для Jenkins, щелкнув опцию «Управление Jenkins» в левой части меню.
Затем вам будет представлен следующий экран -
Некоторые из вариантов управления следующие:
Настроить систему
Здесь можно управлять путями к различным инструментам, используемым в сборках, например JDK, версиям Ant и Maven, а также параметрами безопасности, почтовыми серверами и другими общесистемными деталями конфигурации. Когда плагины установлены. Jenkins динамически добавит необходимые поля конфигурации после установки плагинов.
Перезагрузить конфигурацию с диска
Jenkins хранит всю свою систему и детали конфигурации задания сборки в виде файлов XML, которые хранятся в домашнем каталоге Jenkins. Здесь также хранится вся история сборки. Если вы переносите задания сборки из одного экземпляра Jenkins в другой или архивируете старые задания сборки, вам нужно будет добавить или удалить соответствующие каталоги заданий сборки в каталог сборок Jenkins. Для этого не нужно переводить Jenkins в автономный режим - вы можете просто использовать параметр «Перезагрузить конфигурацию с диска», чтобы перезагрузить систему Jenkins и напрямую построить конфигурации заданий.
Управление плагином
Здесь можно установить широкий спектр сторонних плагинов прямо из различных инструментов управления исходным кодом, таких как Git, Mercurial или ClearCase, до отчетов о качестве кода и метриках покрытия кода. Плагины можно устанавливать, обновлять и удалять через экран «Управление плагинами».
Системная информация
На этом экране отображается список всех текущих системных свойств Java и переменных системной среды. Здесь можно точно проверить, в какой версии Java Jenkins работает, от имени какого пользователя она работает и т. Д.
На следующем снимке экрана показана некоторая информация о значении имени, доступная в этом разделе.
Системный журнал
Экран системного журнала - это удобный способ просматривать файлы журнала Jenkins в режиме реального времени. Опять же, основное использование этого экрана - устранение неполадок.
Статистика загрузки
На этой странице отображаются графические данные о том, насколько загружен экземпляр Jenkins с точки зрения количества параллельных сборок и длины очереди сборки, что дает представление о том, как долго ваши сборки должны ждать перед выполнением. Эта статистика может дать хорошее представление о том, требуется ли дополнительная емкость или дополнительные узлы сборки с точки зрения инфраструктуры.
Консоль скрипта
Этот экран позволяет запускать сценарии Groovy на сервере. Это полезно для расширенного поиска и устранения неисправностей, так как требует глубоких знаний внутренней архитектуры Jenkins.
Управлять узлами
Jenkins может обрабатывать параллельные и распределенные сборки. На этом экране вы можете настроить, сколько сборок вы хотите. Jenkins работает одновременно, и, если вы используете распределенные сборки, настройте узлы сборки. Узел сборки - это еще одна машина, которую Jenkins может использовать для выполнения своих сборок.
Подготовьтесь к выключению
Если необходимо выключить Jenkins или сервер, на котором работает Jenkins, лучше не делать этого во время выполнения сборки. Чтобы полностью завершить работу Jenkins, вы можете использовать ссылку Prepare for Shutdown, которая предотвращает запуск любых новых сборок. В конце концов, когда все текущие сборки будут завершены, можно будет полностью завершить работу Jenkins.
Для этого упражнения мы создадим задание в Jenkins, которое подберет простое приложение HelloWorld, построит и запустит программу java.
Step 1 - Перейдите на панель управления Jenkins и нажмите «Новый элемент».
Step 2- На следующем экране введите имя элемента, в данном случае мы назвали его Helloworld. Выберите опцию Freestyle project option.
Step 3 - Появится следующий экран, в котором вы можете указать детали задания.
Step 4- Нам нужно указать расположение файлов, которые необходимо построить. В этом примере мы предположим, что был настроен локальный репозиторий git (E: \ Program), который содержит файл HelloWorld.java. Следовательно, прокрутите вниз, нажмите на опцию Git и введите URL-адрес локального репозитория git.
Note- Если ваш репозиторий размещен на Github, вы также можете ввести здесь URL-адрес этого репозитория. В дополнение к этому вам нужно будет нажать кнопку «Добавить» для учетных данных, чтобы добавить имя пользователя и пароль в репозиторий github, чтобы код можно было получить из удаленного репозитория.
Step 5 - Теперь перейдите в раздел «Сборка» и нажмите «Добавить шаг сборки» → «Выполнить пакетную команду Windows».
Step 6 - В командном окне введите следующие команды и нажмите кнопку «Сохранить».
Javac HelloWorld.java
Java HelloWorld
Step 7 - После сохранения вы можете нажать на опцию Build Now, чтобы увидеть, успешно ли вы определили задание.
Step 8- Как только сборка будет запланирована, она будет запущена. В следующем разделе истории сборки показано, что сборка выполняется.
Step 9- После завершения сборки статус сборки покажет, была ли сборка успешной или нет. В нашем случае следующая сборка была выполнена успешно. Нажмите на №1 в истории сборок, чтобы просмотреть подробности сборки.
Step 10 - Щелкните ссылку «Вывод в консоль», чтобы просмотреть подробную информацию о сборке.
Помимо шагов, показанных выше, существует очень много способов создать задание сборки, доступно множество вариантов, что делает Jenkins таким фантастическим инструментом непрерывного развертывания.
Jenkins предоставляет готовые функциональные возможности для Junit и множество подключаемых модулей для модульного тестирования других технологий, например, MSTest для модульных тестов .Net. Если перейти по ссылкеhttps://wiki.jenkins-ci.org/display/JENKINS/xUnit+Plugin он предоставит список доступных плагинов для модульного тестирования.
Пример теста Junit в Jenkins
В следующем примере рассматривается
- Простой класс HelloWorldTest на основе Junit.
- Ant как инструмент сборки в Jenkins для соответствующей сборки класса.
Step 1 - Перейдите на панель управления Jenkins, щелкните существующий проект HelloWorld и выберите параметр «Настроить».
Step 2 - Перейдите к разделу «Добавить этап сборки» и выберите параметр «Вызов Ant».
Step 3 - Щелкните по кнопке Advanced.
Step 4 - В разделе файла сборки введите расположение файла build.xml.
Step 5 - Затем нажмите на опцию «Добавить опцию после сборки» и выберите опцию «Опубликовать отчет о результатах теста Junit».
Step 6- В XML-файлах отчетов об испытаниях введите местоположение, как показано ниже. Убедитесь, что «Отчеты» - это папка, созданная в рабочей области проекта HelloWorld. «* .Xml» в основном указывает Jenkins забрать XML-файлы результатов, созданные при выполнении тестовых случаев Junit. Эти файлы xml, которые затем преобразуются в отчеты, которые можно просмотреть позже.
По завершении нажмите кнопку Сохранить в конце.
Step 7 - После сохранения вы можете нажать на опцию Build Now.
После завершения сборки статус сборки покажет, была ли сборка успешной или нет. В информации о выходе сборки вы теперь заметите дополнительный раздел под названием Test Result. В нашем случае мы ввели отрицательный тестовый случай, чтобы результат не прошел просто в качестве примера.
Можно перейти к выходу консоли, чтобы увидеть дополнительную информацию. Но что еще интереснее, если вы нажмете на «Результат теста», вы увидите детализацию результатов теста.
Один из основных принципов непрерывной интеграции - сборка должна поддаваться проверке. Вы должны иметь возможность объективно определить, готова ли конкретная сборка для перехода к следующему этапу процесса сборки, и наиболее удобный способ сделать это - использовать автоматические тесты. Без надлежащего автоматизированного тестирования вам придется сохранять многие артефакты сборки и тестировать их вручную, что вряд ли соответствует духу непрерывной интеграции. В следующем примере показано, как использовать Selenium для запуска автоматических веб-тестов.
Step 1 - Перейдите в раздел "Управление плагинами".
Step 2- Найдите плагин Hudson Selenium и выберите установку. Перезапустите экземпляр Jenkins.
Step 3 - Зайдите в Настроить систему.
Step 4 - Сконфигурируйте jar-сервер selenium и нажмите кнопку «Сохранить».
Note- Файл selenium jar можно скачать из папки SeleniumHQ.
Щелкните по загрузке для автономного сервера Selenium.
Step 5 - Вернитесь на свою панель управления и нажмите кнопку «Настроить» для проекта HelloWorld.
Step 6 - Нажмите «Добавить этап сборки» и выберите вариант «SeleniumHQ htmlSuite Run».
Step 7- Добавьте необходимые детали для теста на селен. Здесь suiteFile - это TestSuite, созданный с помощью Selenium IDE. Нажмите «Сохранить» и выполните сборку. Теперь пост-сборка запустит драйвер селена и выполнит тест html.
Jenkins поставляется с готовой возможностью добавить уведомление по электронной почте для проекта сборки.
Step 1- Настройка SMTP-сервера. Перейти к управлению Jenkins → Настроить систему. Перейдите в раздел Уведомление по электронной почте и введите требуемый SMTP-сервер и данные суффикса электронной почты пользователя.
Step 2- Настройте получателей в проекте Jenkins. - Когда вы настраиваете любой проект сборки Jenkins, в самом конце появляется возможность добавлять получателей, которые будут получать уведомления по электронной почте о нестабильных или неисправных сборках. Затем нажмите кнопку «Сохранить».
Помимо стандартного, на рынке также доступны плагины уведомлений. Примером может служить плагин уведомлений от Tikal Knowledge, который позволяет отправлять уведомления о статусе работы в форматах JSON и XML. Этот плагин позволяет настраивать конечные точки, как показано ниже.
Вот подробности каждого варианта -
"Format" - Это формат полезной нагрузки уведомления, который может быть JSON или XML.
"Protocol" - протокол, используемый для отправки уведомлений, HTTP, TCP или UDP.
"Event" - События задания, вызывающие уведомления: "Задание начато", "Задание завершено", "Задание завершено" или "Все события" (вариант по умолчанию).
"URL"- URL для отправки уведомлений. Он принимает форму "http://host"для протокола HTTP, а также
"host:port"
для протоколов TCP и UDP."Timeout" - Таймаут в миллисекундах для отправки запроса на уведомление, по умолчанию 30 секунд.
Как было показано в предыдущем разделе, доступно множество плагинов для создания отчетов, самый простой из которых - это отчеты, доступные для тестов jUnit.
В действии «Пост-сборка» для любого задания вы можете определить создаваемые отчеты. После завершения сборки параметр «Результаты тестирования» будет доступен для дальнейшего изучения.
У Jenkins есть множество плагинов для анализа кода. Различные плагины можно найти наhttps://wiki.jenkins-ci.org/display/JENKINS/Static+Code+Analysis+Plugins
Этот плагин предоставляет утилиты для плагинов статического анализа кода. Jenkins может анализировать файл результатов из различных инструментов анализа кода, таких как CheckStyle, FindBugs, PMD и т. Д. Для каждого соответствующего инструмента анализа кода необходимо установить плагин в Jenkins.
Кроме того, доступен дополнительный плагин Static Analysis Collector, который объединяет отдельные результаты этих плагинов в единый график трендов и представление.
Плагины могут предоставлять такую информацию, как
- Общее количество предупреждений в задании
- Отображение новых и исправленных предупреждений сборки
- Отчеты о тенденциях, показывающие количество предупреждений для каждой сборки
- Обзор найденных предупреждений для каждого модуля, пакета, категории или типа
- Подробные отчеты об обнаруженных предупреждениях с возможностью фильтрации по серьезности (или новые и исправленные)
Иногда требуется много машин для сборки, если есть экземпляры, в которых есть более крупные и тяжелые проекты, которые строятся на регулярной основе. И запуск всех этих сборок на центральной машине может быть не лучшим вариантом. В таком сценарии можно настроить другие машины Jenkins как подчиненные машины, чтобы снять нагрузку с главного сервера Jenkins.
Иногда вам также может потребоваться несколько разных сред для тестирования ваших сборок. В этом случае использование ведомого устройства для представления каждой из ваших требуемых сред почти обязательно.
Подчиненный компьютер - это компьютер, настроенный для разгрузки проектов сборки с ведущего устройства, и после настройки это распределение задач выполняется автоматически. Точное поведение делегирования зависит от конфигурации каждого проекта; некоторые проекты могут «придерживаться» определенной машины для сборки, в то время как другие могут свободно перемещаться между ведомыми устройствами.
Поскольку каждое ведомое устройство запускает отдельную программу, называемую «ведомым агентом», нет необходимости устанавливать полный пакет Jenkins (пакет или скомпилированные двоичные файлы) на ведомом устройстве. Существуют различные способы запуска подчиненных агентов, но в конце подчиненный агент и мастер Jenkins должны установить двунаправленный канал связи (например, сокет TCP / IP) для работы.
Чтобы настроить подчиненные устройства / узлы в Jenkins, выполните следующие действия.
Step 1 - Перейдите в раздел «Управление Jenkins» и прокрутите вниз до раздела «Управление узлами».
Step 2 - Щелкните New Node
Step 3 - Дайте имя для узла, выберите опцию «Dumb slave» и нажмите «Ok».
Step 4- Введите сведения о подчиненной машине узла. В приведенном ниже примере мы рассматриваем подчиненную машину как машину с Windows, поэтому в качестве метода запуска был выбран вариант «Разрешить Дженкинсу управлять этим подчиненным устройством Windows как службой Windows». Нам также необходимо добавить необходимые сведения о подчиненном узле, такие как имя узла и учетные данные для входа на компьютер узла. Нажмите кнопку "Сохранить". Ярлыки, для которых вводится имя «New_Slave», - это то, что можно использовать для настройки заданий на использование этого ведомого компьютера.
После выполнения вышеуказанных шагов новый узел-компьютер изначально будет в автономном состоянии, но перейдет в оперативный режим, если все настройки на предыдущем экране были введены правильно. При необходимости можно в любой момент отключить подчиненную машину узла.
Доступно множество плагинов, которые можно использовать для передачи файлов сборки после успешной сборки в соответствующее приложение / веб-сервер. В качестве примера можно привести плагин «Развернуть в контейнере». Чтобы использовать это, следуйте инструкциям ниже.
Step 1- Перейдите в «Управление Jenkins» → «Управление плагинами». Перейдите в раздел «Доступные», найдите плагин «Развернуть в контейнерный плагин» и установите плагин. Перезагрузите сервер Jenkins.
Этот плагин принимает файл war / ear и развертывает его на работающем удаленном сервере приложений в конце сборки.
Tomcat 4.x / 5.x / 6.x / 7.x
JBoss 3.x / 4.x
Стеклянная рыба 2.x / 3.x
Step 2- Перейдите в свой проект сборки и нажмите кнопку «Настроить». Выберите вариант «Развернуть войну / ухо в контейнер».
Step 3- В разделе «Развернуть войну / ухо в контейнер» введите необходимые данные о сервере, на котором необходимо развернуть файлы, и нажмите кнопку «Сохранить». Эти шаги теперь гарантируют, что необходимые файлы будут развернуты в необходимом контейнере после успешной сборки.
В Jenkins доступны различные плагины для демонстрации показателей сборок, выполняемых в течение определенного периода времени. Эти показатели полезны для понимания ваших сборок и того, как часто они выходят из строя / проходят с течением времени. В качестве примера рассмотрим плагин Build History Metrics.
Этот плагин вычисляет следующие показатели для всех установленных сборок.
- Среднее время до отказа (MTTF)
- Среднее время восстановления (MTTR)
- Стандартное отклонение времени сборки
Step 1 - Перейдите на панель управления Jenkins и нажмите Manage Jenkins.
Step 2 - Перейдите к опции «Управление плагинами».
Step 3 - Перейдите на вкладку «Доступные», найдите плагин «Плагин Build History Metrics» и выберите «установить без перезапуска».
Step 4- Появится следующий экран, подтверждающий успешную установку плагина. Перезапустите экземпляр Jenkins.
Когда вы перейдете на страницу своей вакансии, вы увидите таблицу с рассчитанными показателями. Показатели отображаются за последние 7 дней, последние 30 дней и за все время.
Чтобы увидеть общие тенденции в Jenkins, доступны плагины для сбора информации из сборок и Jenkins и отображения их в графическом формате. Одним из примеров такого плагина является плагин Hudson global-build-stats. Итак, давайте пройдемся по шагам для этого.
Step 1 - Перейдите на панель управления Jenkins и нажмите Manage Jenkins.
Step 2 - Перейдите к опции "Управление плагинами".
Step 3 - Перейдите на вкладку «Доступные», найдите плагин «Hudson global-build-stats plugin» и выберите «установить без перезапуска».
Step 4- Появится следующий экран, подтверждающий успешную установку плагина. Перезапустите экземпляр Jenkins.
Чтобы увидеть глобальную статистику, выполните шаги с 5 по 8.
Step 5- Перейдите на панель управления Jenkins и нажмите Manage Jenkins. На экране «Управление Jenkins» прокрутите вниз, и теперь вы увидите параметр «Глобальная статистика сборки». Щелкните по этой ссылке.
Step 6- Нажмите кнопку «Инициализировать статистику». При этом собираются все существующие записи для уже выполненных сборок, и на основе этих результатов можно создавать диаграммы.
Step 7- После инициализации данных самое время создать новую диаграмму. Щелкните ссылку "Создать новую диаграмму".
Step 8- Появится всплывающее окно для ввода соответствующей информации для деталей новой диаграммы. Введите следующую обязательную информацию
- Заголовок - любая информация о заголовке, в этом примере представлена как «Демо».
- Ширина диаграммы - 800
- Высота диаграммы - 600
- Шкала времени графика - Ежедневно
- Продолжительность графика - 30 дней
Остальную информацию можно оставить как есть. После ввода информации нажмите «Создать новую диаграмму».
Теперь вы увидите диаграмму, которая отображает тенденции построений с течением времени.
Если вы щелкните любой раздел в диаграмме, он предоставит вам подробную информацию о работе и их построениях.
Ниже приведены некоторые из основных действий, которые вы будете выполнять, некоторые из которых являются передовыми методами обслуживания сервера Jenkins.
Параметры URL
Следующие команды, добавленные к URL-адресу экземпляра Jenkins, будут выполнять соответствующие действия с экземпляром Jenkins.
http://localhost:8080/jenkins/exit - выключение, Дженкинс
http://localhost:8080/jenkins/restart - перезапустить Дженкинс
http://localhost:8080/jenkins/reload - перезагрузить конфигурацию
Резервное копирование Jenkins Home
Домашний каталог Jenkins - это не что иное, как место на вашем диске, где Jenkins хранит всю информацию о заданиях, сборках и т. Д. Местоположение вашего домашнего каталога можно увидеть, когда вы нажмете «Управление Jenkins → Настроить систему».
Настройте Jenkins на разделе с наибольшим объемом свободного дискового пространства - поскольку Jenkins будет использовать исходный код для различных заданий и выполнять непрерывные сборки, всегда убедитесь, что Jenkins настроен на диске, на котором достаточно места на жестком диске. Если на вашем жестком диске не хватает места, все сборки на экземпляре Jenkins начнут давать сбой.
Еще одна передовая практика - написать задания cron или задачи обслуживания, которые могут выполнять операции очистки, чтобы избежать переполнения диска, на котором установлен Jenkins.
Jenkins обеспечивает хорошую поддержку для обеспечения непрерывного развертывания и доставки. Если вы посмотрите на процесс разработки любого программного обеспечения через развертывание, он будет таким, как показано ниже.
Основная часть непрерывного развертывания - обеспечить автоматизацию всего процесса, показанного выше. Дженкинс достигает всего этого с помощью различных подключаемых модулей, одним из которых является «Развертывание в контейнерный подключаемый модуль», который мы видели в предыдущих уроках.
Доступны плагины, которые могут фактически дать вам графическое представление процесса непрерывного развертывания. Но сначала давайте создадим еще один проект в Jenkins, чтобы лучше понять, как это работает.
Давайте создадим простой проект, который имитирует этап контроля качества и проведет тестирование приложения Helloworld.
Step 1- Перейдите на панель управления Jenkins и нажмите «Новый элемент». Выберите «Freestyle project» и введите название проекта «QA». Нажмите кнопку ОК, чтобы создать проект.
Step 2 - В этом примере мы сохраняем простоту и просто используем этот проект для выполнения тестовой программы для приложения Helloworld.
Итак, наш проект QA настроен. Вы можете выполнить сборку, чтобы увидеть, правильно ли она строится.
Step 3 - Теперь перейдите к своему проекту Helloworld и нажмите кнопку «Настроить».
Step 4 - В конфигурации проекта выберите «Добавить действие после сборки» и выберите «Создать другие проекты».
Step 5- В разделе «Проект для сборки» введите QA в качестве имени проекта для сборки. Вы можете оставить параметр по умолчанию «Запускать, только если сборка стабильна». Щелкните по кнопке Сохранить.
Step 6- Создайте проект Helloworld. Теперь, если вы видите вывод консоли, вы также увидите, что после успешной сборки проекта Helloworld также произойдет сборка проекта QA.
Step 7- Теперь давайте установим плагин Delivery pipeline. Перейдите в Управление Jenkins → Управление плагинами. На доступной вкладке найдите «Плагин конвейера доставки». Нажмите «Установить без перезагрузки». После этого перезапустите экземпляр Jenkins.
Step 8 - Чтобы увидеть конвейер доставки в действии, на панели инструментов Jenkins щелкните значок + на вкладке рядом с вкладкой «Все».
Step 9 - Введите любое имя для имени просмотра и выберите опцию «Просмотр конвейера доставки».
Step 10- На следующем экране вы можете оставить параметры по умолчанию. Можно изменить следующие настройки -
- Убедитесь, что установлен флажок «Показать результаты статического анализа».
- Убедитесь, что установлен флажок «Показать общее время сборки».
- Для начального задания - введите проект Helloworld в качестве первого задания, которое необходимо построить.
- Введите любое имя для конвейера
- Щелкните кнопку ОК.
Теперь вы увидите великолепный вид всего конвейера доставки и сможете видеть статус каждого проекта во всем конвейере.
Еще один известный плагин - это build pipeline plugin. Давайте посмотрим на это.
Step 1- Перейдите в Управление Jenkins → Управление плагинами. На доступной вкладке найдите «Build Pipeline Plugin». Нажмите «Установить без перезагрузки». После этого перезапустите экземпляр Jenkins.
Step 2 - Чтобы увидеть конвейер сборки в действии, на панели инструментов Jenkins щелкните значок + на вкладке рядом с вкладкой «Все».
Step 3 - Введите любое имя для имени представления и выберите опцию «Создать представление конвейера».
Step 4- Примите настройки по умолчанию, только в выбранном исходном задании убедитесь, что вы ввели имя проекта Helloworld. Щелкните кнопку ОК.
Теперь вы увидите великолепный вид всего конвейера доставки и сможете видеть статус каждого проекта во всем конвейере.
Чтобы получить список всех плагинов, доступных в Jenkins, можно перейти по ссылке - https://wiki.jenkins-ci.org/display/JENKINS/Plugins
Мы уже видели много примеров установки плагинов, давайте посмотрим на некоторые другие задачи обслуживания в отношении плагинов.
Удаление плагинов
Чтобы удалить плагин, перейдите в «Управление Jenkins» → «Управление плагинами». Щелкните вкладку Установлено. У некоторых плагинов есть опция удаления. Вы можете нажать эти кнопки, чтобы удалить плагины. Обязательно перезапустите экземпляр Jenkins после удаления.
Установка другой версии плагина
Иногда может потребоваться установить более старую версию плагина, в таком случае вы можете загрузить плагин со страницы соответствующего плагина на веб-сайте Jenkins. Затем вы можете использоватьUpload возможность загрузить плагин вручную.
В Jenkins у вас есть возможность настраивать пользователей и их соответствующие разрешения для экземпляра Jenkins. По умолчанию вы не хотите, чтобы все могли определять задания или другие административные задачи в Jenkins. Таким образом, у Дженкинса есть возможность иметь конфигурацию безопасности.
Чтобы настроить безопасность в Jenkins, выполните действия, указанные ниже.
Step 1 - Нажмите «Управление Jenkins» и выберите «Настроить глобальную безопасность».
Step 2- Нажмите на опцию Включить безопасность. В качестве примера предположим, что мы хотим, чтобы Jenkins поддерживал собственную базу данных пользователей, поэтому в области безопасности выберите вариант «собственная база данных пользователей Jenkins».
По умолчанию вы хотите, чтобы центральный администратор определял пользователей в системе, поэтому убедитесь, что опция «Разрешить пользователям регистрироваться» не выбрана. Вы можете оставить все остальное как есть и нажать кнопку «Сохранить».
Step 3- Вам будет предложено добавить вашего первого пользователя. В качестве примера мы настраиваем пользователей с правами администратора для системы.
Step 4- Пришло время настроить пользователей в системе. Теперь, когда вы перейдете в «Управление Jenkins» и прокрутите вниз, вы увидите опцию «Управление пользователями». Щелкните эту опцию.
Step 5- Так же, как вы определили своего администратора, начните создавать других пользователей для системы. В качестве примера мы просто создаем еще одного пользователя с именем «пользователь».
Step 6- Теперь пришло время настроить ваши авторизации, в основном, кто к чему имеет доступ. Перейдите в Управление Jenkins → Настроить глобальную безопасность.
Теперь в разделе «Авторизация» нажмите «Безопасность на основе матрицы».
Step 7- Если вы не видите пользователя в списке групп пользователей, введите имя пользователя и добавьте его в список. Затем дайте пользователю соответствующие разрешения.
После того, как вы определили соответствующие полномочия, нажмите кнопку «Сохранить».
Теперь ваша безопасность Jenkins настроена.
Note - Для аутентификации Windows AD необходимо добавить плагин Active Directory в Jenkins.
У Jenkins есть плагин резервного копирования, который можно использовать для резервного копирования важных параметров конфигурации, связанных с Jenkins. Следуйте инструкциям ниже, чтобы иметь резервную копию.
Step 1 - Нажмите «Управление Jenkins» и выберите «Управление плагинами».
Step 2- На доступной вкладке найдите «Плагин резервного копирования». Нажмите «Установить без перезагрузки». После этого перезапустите экземпляр Jenkins.
Step 3- Теперь, когда вы перейдете в Управление Jenkins и прокрутите вниз, вы увидите «Диспетчер резервного копирования» в качестве опции. Щелкните эту опцию.
Step 4 - Щелкните «Настройка».
Step 5- Здесь главное поле - это каталог для вашей резервной копии. Убедитесь, что он находится на другом диске, отличном от диска, на котором установлен ваш экземпляр Jenkins. Щелкните по кнопке Сохранить.
Step 6 - Щелкните «Backup Hudson configuration» на экране диспетчера резервного копирования, чтобы начать резервное копирование.
На следующем экране будет показан статус резервного копирования.
Чтобы восстановить данные из резервной копии, перейдите на экран «Диспетчер резервного копирования» и нажмите «Восстановить конфигурацию Hudson».
Будет показан список резервных копий, щелкните соответствующий, чтобы щелкнуть «Запустить восстановление», чтобы начать восстановление резервной копии.
Веб-тесты, такие как тесты на селен, можно запускать на удаленных подчиненных машинах с помощью главного подчиненного устройства и установки плагина набора селена. Следующие шаги показывают, как запускать удаленные тесты с использованием этой конфигурации.
Step 1- Убедитесь, что конфигурация вашего главного подчиненного устройства на месте. Перейдите на свой главный сервер Jenkins. Перейдите в Управление Jenkins → Управление узлами.
В нашем списке узлов метка DXBMEM30 - это ведомая машина. В этом примере и главная, и подчиненная машины являются машинами Windows.
Step 2 - Нажмите на кнопку «Настроить» для ведомой машины DXBMEM30.
Step 3 - Убедитесь, что метод запуска указан как «Запуск ведомых агентов через Java Web Start».
Step 4- Теперь перейдите к своему подчиненному компьютеру и оттуда откройте экземпляр браузера в главном экземпляре Jenkins. Затем перейдите в Manage Jenkins → Manage Nodes. Перейдите в DXBMEM30 и нажмите
Step 5 - Щелкните экземпляр DXBMEM30.
Step 6 - Прокрутите вниз, и вы увидите опцию Launch, которая является опцией Start 'Java Web Start'.
Step 7- Вам будет представлено предупреждение системы безопасности. Установите флажок «Принятие» и нажмите «Выполнить».
Теперь вы увидите открытое окно Jenkins Slave, которое теперь подключено.
Step 8- Настройка ваших тестов для запуска на ведомом устройстве. Здесь вы должны убедиться, что создаваемое задание предназначено только для запуска тестов на селен.
В конфигурации задания убедитесь, что выбран параметр «Ограничить, где может быть запущен этот проект», и в выражении метки укажите имя подчиненного узла.
Step 9- Убедитесь, что селеновая часть вашей работы настроена. Вы должны убедиться, что файл Sample.html и файл selenium-server.jar также присутствуют на подчиненной машине.
После того, как вы выполнили все вышеперечисленные шаги и нажали на Build, этот проект запустит тест Selenium на подчиненной машине, как и ожидалось.