Samouczek: wdrażanie na maszynie wirtualnej z systemem Linux przy użyciu usług Jenkins i Azure DevOps Services
Ciągła integracja (CI) i ciągłe wdrażanie (CD) tworzą potok, za pomocą którego możesz kompilować, wydawać i wdrażać swój kod. Usługi Azure DevOps Services udostępniają kompletny, rozbudowany zestaw narzędzi automatyzacji CI/CD do wdrażania na platformie Azure. Usługa Jenkins to popularne serwerowe narzędzie CI/CD innej firmy, które udostępnia również automatyzację CI/CD. Usług Azure DevOps Services i Jenkins można używać razem, aby dostosować sposób dostarczania aplikacji lub usługi w chmurze.
W tym samouczku użyjesz usługi Jenkins do skompilowania aplikacji internetowej Node.js. Następnie użyjesz usług Azure DevOps do jej wdrożenia
do grupy wdrożenia zawierającej maszyny wirtualne (VM) systemu Linux. Dowiedz się, jak odbywa się:
- Pobieranie przykładowej aplikacji.
- Konfigurowanie wtyczek usługi Jenkins.
- Konfigurowanie projektu Jenkins Freestyle dla środowiska Node.js.
- Konfigurowanie usługi Jenkins do integracji z usługami Azure DevOps Services.
- Tworzenie punktu końcowego usługi Jenkins.
- Tworzenie grupy wdrożenia dla maszyn wirtualnych platformy Azure.
- Tworzenie potoku wydania usługi Azure Pipelines.
- Przeprowadzanie wdrożeń wyzwalanych ręcznie i za pomocą CI.
Wymagania wstępne
Subskrypcja platformy Azure: jeśli nie masz subskrypcji platformy Azure, przed rozpoczęciem utwórz bezpłatne konto platformy Azure.
Serwer Jenkins: jeśli nie masz zainstalowanego serwera Jenkins, utwórz serwer Jenkins na platformie Azure.
Uwaga
Aby uzyskać więcej informacji, zobacz Nawiązywanie połączenia z usługami Azure DevOps Services.
Maszyna wirtualna systemu Linux jest potrzebna jako cel wdrożenia. Aby uzyskać więcej informacji, zobacz Create and manage Linux VMs with the Azure CLI (Tworzenie maszyn wirtualnych systemu Linux i zarządzanie nimi za pomocą interfejsu wiersza polecenia platformy Azure).
Otwórz port wejściowy 80 dla maszyny wirtualnej. Aby uzyskać więcej informacji, zobacz Create network security groups using the Azure portal (Tworzenie sieciowych grup zabezpieczeń przy użyciu witryny Azure Portal).
Pobieranie przykładowej aplikacji
Do wdrożenia potrzebujesz aplikacji przechowywanej w repozytorium usługi Git. W tym samouczku zalecamy używanie tej przykładowej aplikacji dostępnej w serwisie GitHub. Ten samouczek zawiera przykładowy skrypt używany do instalowania platformy Node.js i aplikacji. Jeśli chcesz pracować z własnym repozytorium, musisz skonfigurować podobny przykład.
Utwórz rozwidlenie tej aplikacji i zanotuj lokalizację (adres URL) do użycia w dalszych krokach tego samouczka. Aby uzyskać więcej informacji, zobacz Fork a repo (Tworzenie rozwidlenia repozytorium).
Uwaga
Aplikacja została skompilowana przy użyciu narzędzia Yeoman. Używa ona narzędzi Express, Bower i Grunt. I ma niektóre pakiety npm jako zależności. Przykład zawiera także skrypt, który konfiguruje serwer Nginx, a następnie wdraża aplikację. Jest on wykonywany na maszynach wirtualnych. W szczególności skrypt:
- Instaluje rozwiązania Node, Nginx i PM2.
- Konfiguruje rozwiązania Nginx i PM2.
- Uruchamia aplikację Node.
Konfigurowanie wtyczek usługi Jenkins
Najpierw musisz skonfigurować dwie wtyczki usługi Jenkins: NodeJS i VS Team Services Continuous Deployment.
- Otwórz konto usługi Jenkins i wybierz pozycję Manage Jenkins (Zarządzaj usługą Jenkins).
- Na stronie Manage Jenkins (Zarządzanie usługą Jenkins) wybierz pozycję Manage Plugins (Zarządzanie wtyczkami).
- Odfiltruj listę, aby zlokalizować wtyczkę NodeJS, a następnie wybierz opcję Install without restart (Instaluj bez ponownego uruchamiania).
- Odfiltruj listę, aby odnaleźć wtyczkę VS Team Services Continuous Deployment, a następnie wybierz opcję Install without restart (Instaluj bez ponownego uruchamiania).
- Wróć do pulpitu nawigacyjnego usługi Jenkins i wybierz pozycję Manage Jenkins (Zarządzaj usługą Jenkins).
- Wybierz pozycję Global Tool Configuration (Globalna konfiguracja narzędzi). Znajdź wtyczkę NodeJS i wybierz pozycję NodeJS installations (Instalacje wtyczki NodeJS).
- Wybierz opcję Install automatically (Instaluj automatycznie), a następnie wprowadź wartość Name (Nazwa).
- Wybierz pozycję Zapisz.
Konfigurowanie projektu Jenkins Freestyle dla środowiska Node.js
- Wybierz pozycję New Item (Nowy element). Wprowadź nazwę elementu.
- Wybierz pozycję Freestyle project (Projekt Freestyle). Wybierz przycisk OK.
- Na karcie Source Code Management (Zarządzanie kodem źródłowym) wybierz pozycję Git, a następnie wprowadź szczegóły repozytorium i gałęzi zawierającej kod aplikacji.
- Na karcie Build Triggers (Wyzwalacze kompilacji) wybierz pozycję Poll SCM (Sondowanie SCM), a następnie wprowadź harmonogram
H/03 * * * *
, aby przeprowadzać sondowanie repozytorium Git pod kątem zmian co trzy minuty. - Na karcie Środowisko kompilacji wybierz pozycję Podaj węzeł i plik npm bin/ ścieżkę folderu, a następnie wybierz wartość Instalacja nodeJS. Pozostaw pozycję npmrc file (plik npmrc) ustawioną na use system default (użyj wartości domyślnej systemu).
- Na karcie Build (Kompilacja) wybierz pozycję Execute shell (Wykonaj powłokę), a następnie wprowadź polecenie
npm install
, aby upewnić się, że wszystkie zależności będą aktualizowane.
Konfigurowanie usługi Jenkins do integracji z usługami Azure DevOps Services
Uwaga
Upewnij się, że osobisty token dostępu używany w następnych krokach zawiera uprawnienie Wydanie (odczyt, zapis, wykonanie i zarządzanie) w usługach Azure DevOps Services.
Utwórz osobisty token dostępu w swojej organizacji Azure DevOps Services, jeśli jeszcze go nie masz. Usługa Jenkins wymaga tych informacji, aby uzyskać dostęp do organizacji Azure DevOps Services. Pamiętaj, aby przechować informacje o tokenie na potrzeby kolejnych kroków w tej sekcji.
Aby dowiedzieć się, jak wygenerować token, przeczytaj temat Jak mogę utworzyć osobisty token dostępu dla usług Azure DevOps Services?.
Na karcie Post-build Actions (Akcje po kompilacji) wybierz pozycję Add post-build action (Dodaj akcję po kompilacji). Wybierz pozycję Archive the artifacts (Archiwizuj artefakty).
Dla pozycji Files to archive (Pliki do archiwizacji) wprowadź
**/*
, aby uwzględnić wszystkie pliki.Aby utworzyć inną akcję, wybierz pozycję Add post-build action (Dodaj akcję po kompilacji).
Wybierz pozycję Trigger release in TFS/Team Services (Wyzwalanie wydania w TFS/Team Services). Wprowadź identyfikator URI swojej organizacji Azure DevOps Services, taki jak https://{nazwa-organizacji}.visualstudio.com.
Wprowadź Nazwa projektu.
Wybierz nazwę potoku wydania. (Ten potok wydania utworzysz później w usługach Azure DevOps Services).
Wybierz poświadczenia, aby nawiązać połączenie z usługą Azure DevOps Services lub środowiskiem usługi Azure DevOps Server:
- Pozostaw puste pole Nazwa użytkownika, jeśli używasz usług Azure DevOps Services.
- Wprowadź nazwę użytkownika i hasło, jeśli używasz lokalnej wersji serwera Azure DevOps Server.
Zapisz projekt usługi Jenkins.
Tworzenie punktu końcowego usługi Jenkins
Punkt końcowy usługi umożliwia usługom Azure DevOps Services nawiązanie połączenia z usługą Jenkins.
- Otwórz stronę Usługi w usługach Azure DevOps Services, otwórz listę Nowy punkt końcowy usługi, a następnie wybierz pozycję Jenkins.
- Wprowadź nazwę połączenia.
- Wprowadź adres URL serwera Jenkins, a następnie wybierz opcję Zaakceptuj niezaufane certyfikaty SSL. Przykładowy adres URL to http://{Adres_URL_usługi_Jenkins}.westcentralus.cloudapp.azure.com.
- Wprowadź nazwę użytkownika i hasło konta usługi Jenkins.
- Wybierz pozycję Sprawdź połączenie, aby sprawdzić, czy informacje są poprawne.
- Wybierz przycisk OK, aby utworzyć punkt końcowy usługi.
Tworzenie grupy wdrożenia dla maszyn wirtualnych platformy Azure
Potrzebujesz grupy wdrożenia, aby zarejestrować agenta usług Azure DevOps Services, co umożliwi wdrażanie potoku wydania na maszynie wirtualnej. Grupy wdrożenia ułatwiają określenie grup logicznych docelowych komputerów dla wdrożenia i zainstalowanie wymaganego agenta na każdej maszynie.
Uwaga
W poniższej procedurze zainstaluj wymagania wstępne i nie uruchamiaj skryptu z uprawnieniami programu sudo.
- Otwórz kartę Wydania centrum Kompilacja i wydanie, otwórz grupy wdrożenia i wybierz pozycję + Nowy.
- Wprowadź nazwę grupy wdrożenia i opcjonalny opis. Następnie wybierz Utwórz.
- Wybierz system operacyjny docelowej maszyny wirtualnej wdrożenia. Na przykład wybierz pozycję Ubuntu 16.04+.
- Wybierz pozycję Do uwierzytelnienia użyj osobistego tokenu dostępu w skrypcie.
- Wybierz link Wymagania wstępne systemu. Zainstaluj wymagania wstępne swojego systemu operacyjnego.
- Wybierz pozycję Kopiuj skrypt do schowka, aby skopiować skrypt.
- Zaloguj się do docelowej maszyny wirtualnej wdrożenia i uruchom skrypt. Nie uruchamiaj skryptu przy użyciu uprawnień programu sudo.
- Po zakończeniu instalacji zostanie wyświetlony monit o tagi grupy wdrożenia. Zaakceptuj wartości domyślne.
- W usługach Azure DevOps Services sprawdź nowo zarejestrowaną maszynę wirtualną w pozycji Miejsca docelowe w obszarze Grupy wdrożenia.
Tworzenie potoku wydania usługi Azure Pipelines
Potok wydania określa proces, którego usługa Azure Pipelines używa do wdrażania aplikacji. W tym przykładzie wykonasz skrypt powłoki.
W celu utworzenia potoku wydania w usłudze Azure Pipelines:
- Otwórz kartę Wydania centrum Kompilacja i wydanie, a następnie wybierz pozycję Utwórz potok wydania.
- Wybierz szablon Pusty, wybierając rozpoczęcie od pozycji Pusty proces.
- W sekcji Artefakty wybierz pozycję + Dodaj artefakt, a następnie wybierz wartość Jenkins dla pozycji Typ źródła. Wybierz połączenie punktu końcowego usługi Jenkins. Następnie wybierz zadanie źródłowe usługi Jenkins, po czym wybierz pozycję Dodaj.
- Wybierz symbol wielokropka obok pozycji Środowisko 1. Wybierz pozycję Dodaj fazę grupy wdrożenia.
- Wybierz swoją grupę wdrożenia.
- Wybierz symbol +, aby dodać zadanie do pozycji Faza grupy wdrożenia.
- Wybierz zadanie Skrypt powłoki, a następnie wybierz pozycję Dodaj. Zadanie Skrypt powłoki zapewnia, że konfiguracja skryptu jest uruchamiana na każdym serwerze w celu zainstalowania środowiska Node.js i uruchomienia aplikacji.
- W pozycji Ścieżka skryptu wprowadź $(System.DefaultWorkingDirectory)/Fabrikam-Node/deployscript.sh.
- Wybierz pozycję Zaawansowane, a następnie włącz pozycję Określ katalog roboczy.
- W obszarze Katalog roboczy wprowadź $(System.DefaultWorkingDirectory)/Fabrikam-Node.
- Zmień nazwę potoku wydania na nazwę określoną na karcie Post-build Actions (Akcje po kompilacji) kompilacji w usłudze Jenkins. Usługa Jenkins wymaga tej nazwy, aby mogła wyzwolić nowe wydanie po zaktualizowaniu artefaktów źródła.
- Wybierz pozycję Zapisz, a następnie wybierz przycisk OK, aby zapisać potok wydania.
Przeprowadzanie wdrożeń wyzwalanych ręcznie i za pomocą CI
- Wybierz pozycję + Wydanie, a następnie wybierz pozycję Utwórz wydanie.
- Wybierz ukończoną kompilację na wyróżnionej liście rozwijanej, a następnie wybierz pozycję Kolejka.
- Wybierz link wydania w komunikacie podręcznym. Na przykład: „Wydanie Wydanie 1 zostało utworzone”.
- Otwórz kartę Dzienniki, aby obejrzeć dane wyjściowe konsoli wydania.
- W przeglądarce otwórz adres URL jednego z serwerów, które zostały dodane do grupy wdrożenia. Na przykład wprowadź http://{adres_IP_serwera}.
- Przejdź do źródłowego repozytorium Git i zmodyfikuj zawartość nagłówka h1 w pliku app/views/index.jade, zmieniając tekst.
- Zatwierdź wprowadzone zmiany.
- Po kilku minutach nowo utworzone wydanie pojawi się na stronie Wydania usług Azure DevOps Services. Otwórz wydanie, aby zobaczyć trwające wdrożenie. Gratulacje!
Rozwiązywanie problemów z wtyczką narzędzia Jenkins
Jeśli napotkasz jakiekolwiek usterki we wtyczkach narzędzia Jenkins, prześlij zgłoszenie za pomocą narzędzia Jenkins JIRA dla określonego składnika.
Następne kroki
W tym samouczku zautomatyzowano wdrażanie aplikacji na platformie Azure przy użyciu usługi Jenkins na potrzeby kompilacji i usług Azure DevOps Services na potrzeby wydania. W tym samouczku omówiono:
- Kompilowanie aplikacji w usłudze Jenkins.
- Konfigurowanie usługi Jenkins do integracji z usługami Azure DevOps Services.
- Tworzenie grupy wdrożenia dla maszyn wirtualnych platformy Azure.
- Utwórz potok platformy Azure, który konfiguruje maszyny wirtualne i wdraża aplikację.
Aby dowiedzieć się, jak używać usługi Azure Pipelines w przypadku kroków kompilacji i wydania, zapoznaj się z tym tematem.
Aby dowiedzieć się, jak utworzyć potok ciągłej integracji/ciągłego wdrażania oparty na języku YAML w celu wdrożenia na maszynach wirtualnych, przejdź do następnego samouczka.