Wdrażanie oprogramowania WebSphere Liberty i Open Liberty w usłudze Azure Red Hat OpenShift
W tym artykule pokazano, jak szybko stanąć w stanie IBM WebSphere Liberty i Open Liberty w usłudze Azure Red Hat OpenShift przy użyciu witryny Azure Portal.
W tym artykule użyto oferty witryny Azure Marketplace dla platformy Open/WebSphere Liberty, aby przyspieszyć podróż do usługi Azure Red Hat OpenShift. Oferta automatycznie aprowizuje kilka zasobów, w tym klaster usługi Azure Red Hat OpenShift z wbudowanym rejestrem OpenShift Container Registry (OCR), operatorami Wolności i opcjonalnie obrazem kontenera, w tym liberty i aplikacją. Aby wyświetlić ofertę, odwiedź witrynę Azure Portal. Jeśli wolisz ręczne wskazówki krok po kroku dotyczące uruchamiania oprogramowania Liberty w usłudze Azure Red Hat OpenShift, które nie korzystają z automatyzacji włączonej przez ofertę, zobacz Ręczne wdrażanie aplikacji Java przy użyciu biblioteki Open Liberty/WebSphere Liberty w klastrze Usługi Azure Red Hat OpenShift.
Ten artykuł ma pomóc w szybkim rozpoczęciu wdrażania. Przed przejściem do środowiska produkcyjnego należy zapoznać się z tematem Tuning Liberty.
Jeśli chcesz przekazać opinię lub ściśle pracować nad scenariuszami migracji z zespołem inżynierów opracowującym rozwiązanie WebSphere na platformie Azure, wypełnij tę krótką ankietę dotyczącą migracji webSphere i dołącz informacje kontaktowe. Zespół menedżerów programów, architektów i inżynierów natychmiast skontaktuje się z Tobą w celu zainicjowania ścisłej współpracy.
Ważne
Chociaż usługa Azure Red Hat OpenShift jest wspólnie zaprojektowana, obsługiwana i obsługiwana przez firmę Red Hat i Microsoft w celu zapewnienia zintegrowanego środowiska pomocy technicznej, oprogramowanie uruchamiane na platformie Azure Red Hat OpenShift, w tym opisane w tym artykule, podlega własnym warunkom pomocy technicznej i postanowień licencyjnych. Aby uzyskać szczegółowe informacje o obsłudze usługi Azure Red Hat OpenShift, zobacz Cykl życia pomocy technicznej dla usługi Azure Red Hat OpenShift 4. Aby uzyskać szczegółowe informacje o obsłudze oprogramowania opisanego w tym artykule, zobacz strony główne dotyczące tego oprogramowania zgodnie z opisem w artykule.
Uwaga
Usługa Azure Red Hat OpenShift wymaga co najmniej 40 rdzeni do utworzenia i uruchomienia klastra OpenShift. Domyślny limit przydziału zasobów platformy Azure dla nowej subskrypcji platformy Azure nie spełnia tego wymagania. Aby zażądać zwiększenia limitu zasobów, zobacz sekcję Request an increase for non-adjustable quotas in Increase VM-family vCPU quotas (Żądanie zwiększenia limitów przydziałów procesorów wirtualnych z rodziną maszyn wirtualnych). Ponieważ rodzaj limitu przydziału, dla którego należy zażądać zwiększenia, jest "nienastawny", musisz złożyć bilet pomocy technicznej. Kroki opisane w temacie Żądanie zwiększenia limitów przydziałów niezwiązanych pokazują dokładnie, jak utworzyć bilet z poprawną zawartością.
Subskrypcja bezpłatnej wersji próbnej nie kwalifikuje się do zwiększenia limitu przydziału. Przed zażądaniem zwiększenia limitu przydziału przeprowadź uaktualnienie do subskrypcji z płatnością zgodnie z rzeczywistym użyciem. Aby uzyskać więcej informacji, zobacz Uaktualnianie bezpłatnego konta platformy Azure lub konta startowego usługi Azure for Students.
Wymagania wstępne
- Subskrypcja platformy Azure. Jeśli nie masz subskrypcji platformy Azure, przed rozpoczęciem utwórz bezpłatne konto platformy Azure.
- Maszyna lokalna z zainstalowanym systemem operacyjnym przypominającym system Unix (na przykład Ubuntu, macOS lub Podsystem Windows dla systemu Linux).
- Interfejs wiersza polecenia platformy Azure. Jeśli korzystasz z systemu Windows lub macOS, rozważ uruchomienie interfejsu wiersza polecenia platformy Azure w kontenerze Docker. Aby uzyskać więcej informacji, zobacz Jak uruchomić interfejs wiersza polecenia platformy Azure w kontenerze platformy Docker.
- Zaloguj się do interfejsu wiersza polecenia platformy Azure przy użyciu polecenia az login . Aby ukończyć proces uwierzytelniania, wykonaj kroki wyświetlane w terminalu. Aby uzyskać inne opcje logowania, zobacz Logowanie się do platformy Azure przy użyciu interfejsu wiersza polecenia platformy Azure.
- Po wyświetleniu monitu zainstaluj rozszerzenie interfejsu wiersza polecenia platformy Azure podczas pierwszego użycia. Aby uzyskać więcej informacji na temat rozszerzeń, zobacz Używanie rozszerzeń i zarządzanie nimi za pomocą interfejsu wiersza polecenia platformy Azure.
- Uruchom polecenie az version, aby znaleźć zainstalowane wersje i biblioteki zależne. Aby uaktualnić do najnowszej wersji, uruchom polecenie az upgrade. Ten artykuł wymaga co najmniej wersji 2.61.0 interfejsu wiersza polecenia platformy Azure.
- Implementacja języka Java Standard Edition (SE) w wersji 17 (na przykład Eclipse Open J9).
- Maven w wersji 3.9.8 lub nowszej.
- Platforma Docker dla systemu operacyjnego.
- Tożsamość platformy Azure używana do logowania ma rolę Współautor oraz rolę Administrator dostępu użytkowników lub Rolę Właściciela w bieżącej subskrypcji. Aby zapoznać się z omówieniem ról platformy Azure, zobacz Co to jest kontrola dostępu oparta na rolach platformy Azure (Azure RBAC)?
Uzyskiwanie wpisu tajnego ściągania oprogramowania Red Hat
Oferta witryny Azure Marketplace, której będziesz używać w tym artykule, wymaga wpisu tajnego ściągnięcia oprogramowania Red Hat. W tej sekcji pokazano, jak uzyskać wpis tajny ściągania oprogramowania Red Hat dla usługi Azure Red Hat OpenShift. Aby dowiedzieć się, czym jest wpis tajny ściągania oprogramowania Red Hat i dlaczego jest potrzebny, zobacz sekcję Get a Red Hat pull secret (Uzyskiwanie wpisu tajnego ściągnięcia red hat) w temacie Create an Azure Red Hat OpenShift 4 cluster (Tworzenie klastra usługi Azure Red Hat OpenShift 4). Aby uzyskać klucz tajny ściągnięcia do użycia, wykonaj kroki opisane w tej sekcji.
Zaloguj się do portalu menedżera klastra OpenShift przy użyciu konta Red Hat OpenShift, odwiedzając konsolę Chmury hybrydowej Red Hat OpenShift. Może być konieczne zaakceptowanie większej liczby warunków i zaktualizowanie konta, jak pokazano na poniższym zrzucie ekranu. Użyj tego samego hasła co podczas tworzenia konta.
Po zalogowaniu wybierz pozycję OpenShift, a następnie pozycję Pobrane. Wybierz listę rozwijaną Wszystkie kategorie, a następnie wybierz pozycję Tokeny. W obszarze Ściąganie wpisu tajnego wybierz pozycję Kopiuj lub Pobierz, jak pokazano na poniższym zrzucie ekranu.
Poniższa zawartość to przykład skopiowany z portalu konsoli Red Hat z kodami uwierzytelniania zastąpionymi ciągiem xxxx...xxx
.
{"auths":{"cloud.openshift.com":{"auth":"xxxx...xxx","email":"contoso-user@contoso.com"},"quay.io":{"auth":"xxx...xxx","email":"contoso-user@test.com"},"registry.connect.redhat.com":{"auth":"xxxx...xxx","email":"contoso-user@contoso.com"},"registry.redhat.io":{"auth":"xxxx...xxx","email":"contoso-user@contoso.com"}}}
Zapisz wpis tajny w pliku, aby można było go użyć później.
Tworzenie jednostki usługi Microsoft Entra w witrynie Azure Portal
Oferta witryny Azure Marketplace, której będziesz używać w tym artykule, wymaga jednostki usługi Entra firmy Microsoft w celu wdrożenia klastra Usługi Azure Red Hat OpenShift. Oferta przypisuje jednostkę usługi z odpowiednimi uprawnieniami w czasie wdrażania, bez konieczności przypisywania roli. Jeśli masz jednostkę usługi gotową do użycia, pomiń tę sekcję i przejdź do następnej sekcji, w której wdrażasz ofertę.
Wykonaj poniższe kroki, aby wdrożyć jednostkę usługi i uzyskać identyfikator aplikacji (klienta) i wpis tajny z witryny Azure Portal. Aby uzyskać więcej informacji, zobacz Create and use a service principal to deploy an Azure Red Hat OpenShift cluster (Tworzenie i używanie jednostki usługi do wdrażania klastra Usługi Azure Red Hat OpenShift).
Uwaga
Aby zarejestrować aplikację w dzierżawie firmy Microsoft Entra, musisz mieć wystarczające uprawnienia. Jeśli wystąpi problem, sprawdź wymagane uprawnienia, aby upewnić się, że twoje konto może utworzyć tożsamość. Aby uzyskać więcej informacji, zobacz Rejestrowanie aplikacji Microsoft Entra i tworzenie jednostki usługi.
Zaloguj się do konta platformy Azure za pośrednictwem witryny Azure Portal.
Wybierz Microsoft Entra ID.
Wybierz pozycję Rejestracje aplikacji.
Wybierz opcjęNowa rejestracja.
Nazwij aplikację, na przykład "liberty-on-aro-app". Wybierz obsługiwany typ konta, który określa, kto może korzystać z aplikacji. Po ustawieniu wartości wybierz pozycję Zarejestruj, jak pokazano na poniższym zrzucie ekranu. Aprowizowania aplikacji zajmuje kilka sekund. Przed kontynuowaniem poczekaj na ukończenie wdrożenia.
Zapisz identyfikator aplikacji (klienta) ze strony przeglądu, jak pokazano na poniższym zrzucie ekranu. Umieść wskaźnik na wartości (zredagowany na zrzucie ekranu) i wybierz wyświetloną ikonę kopiowania. Etykietka narzędzia mówi Kopiuj do schowka. Zachowaj ostrożność, aby skopiować poprawną wartość, ponieważ inne wartości w tej sekcji mają również ikony kopiowania. Zapisz identyfikator aplikacji w pliku, aby można było go użyć później.
Utwórz nowy klucz tajny klienta, wykonując następujące kroki:
- Wybierz pozycję Certyfikaty i wpisy tajne.
- Wybierz pozycję Wpisy tajne klienta, a następnie Pozycję Nowy klucz tajny klienta.
- Podaj opis wpisu tajnego i czas trwania. Gdy wszystko będzie gotowe, wybierz pozycję Dodaj.
- Po dodaniu wpisu tajnego klienta zostanie wyświetlona wartość klucza tajnego klienta. Skopiuj tę wartość, ponieważ nie można jej pobrać później.
Masz teraz aplikację Firmy Microsoft Entra, jednostkę usługi i klucz tajny klienta.
Wdrażanie oprogramowania IBM WebSphere Liberty lub Open Liberty w usłudze Azure Red Hat OpenShift
Kroki opisane w tej sekcji umożliwiają wdrożenie oprogramowania IBM WebSphere Liberty lub Open Liberty w usłudze Azure Red Hat OpenShift.
W poniższych krokach pokazano, jak znaleźć ofertę i wypełnić okienko Podstawy .
Na pasku wyszukiwania w górnej części witryny Azure Portal wprowadź Liberty. W wynikach wyszukiwania automatycznego sugerowania w sekcji Marketplace wybierz pozycję WebSphere Liberty/Open Liberty w witrynie OpenShift, jak pokazano na poniższym zrzucie ekranu.
Możesz również przejść bezpośrednio do oferty za pomocą tego linku portalu.
Na stronie oferty wybierz pozycję Utwórz.
W okienku Podstawowe upewnij się, że wartość wyświetlana w polu Subskrypcja jest taka sama, która ma role wymienione w sekcji wymagań wstępnych.
W polu Grupa zasobów wybierz pozycję Utwórz nową i wypełnij wartość dla grupy zasobów. Ponieważ grupy zasobów muszą być unikatowe w ramach subskrypcji, wybierz unikatową nazwę. Łatwym sposobem na posiadanie unikatowych nazw jest użycie kombinacji inicjałów, dzisiejszej daty i identyfikatora — na przykład abc1228rg.
Utwórz zmienną środowiskową w powłoce dla nazwy grupy zasobów.
export RESOURCE_GROUP_NAME=<your-resource-group-name>
W obszarze Szczegóły wystąpienia wybierz region wdrożenia. Aby uzyskać listę regionów świadczenia usługi Azure, w których działa usługa OpenShift, zobacz Regiony dla platformy Red Hat OpenShift 4.x na platformie Azure.
Po wybraniu regionu wybierz pozycję Dalej.
Poniższe kroki pokazują, jak wypełnić okienko ARO pokazane na poniższym zrzucie ekranu:
W obszarze Utwórz nowy klaster wybierz pozycję Tak.
W obszarze Podaj informacje, aby utworzyć nowy klaster, w polu Klucz tajny ściągnięcia oprogramowania Red Hat wypełnij wpis tajny ściągania red hat uzyskany w sekcji Pobieranie wpisu tajnego ściągnięcia oprogramowania Red Hat. Użyj tej samej wartości dla opcji Potwierdź wpis tajny.
Wypełnij pole Identyfikator klienta jednostki usługi za pomocą identyfikatora jednostki usługi (klienta) uzyskanego w sekcji Tworzenie jednostki usługi Microsoft Entra w witrynie Azure Portal.
W polu Klucz tajny klienta jednostki usługi wprowadź wpis tajny aplikacji jednostki usługi uzyskany w sekcji Tworzenie jednostki usługi Microsoft Entra w witrynie Azure Portal . Użyj tej samej wartości dla opcji Potwierdź wpis tajny.
Po wypełnieniu wartości wybierz pozycję Dalej.
Poniższe kroki pokazują, jak wypełnić okienko Operator i aplikacja pokazane na poniższym zrzucie ekranu i rozpocząć wdrażanie.
W obszarze Ibm supported? (Obsługiwane przez firmę IBM)? ( Tak).
Uwaga
Ten przewodnik Szybki start wdraża obsługiwany przez ibm operator WebSphere Liberty, ale zamiast tego możesz wybrać pozycję Nie , aby wdrożyć operator Open Liberty.
Pozostaw domyślną opcję Nie dla opcji Wdróż aplikację?.
Uwaga
W tym przewodniku Szybki start ręcznie wdrożysz przykładową aplikację później, ale możesz wybrać opcję Tak w polu Wdróż aplikację? Jeśli wolisz.
Wybierz pozycję Przejrzyj i utwórz. Upewnij się, że w górnej części ekranu pojawi się zielony komunikat Weryfikacja przekazana pomyślnie. Jeśli komunikat nie zostanie wyświetlony, rozwiąż problemy z walidacją, a następnie ponownie wybierz pozycję Przejrzyj i utwórz .
Wybierz pozycję Utwórz.
Śledzenie postępu wdrażania na stronie Wdrażanie jest w toku .
W zależności od warunków sieciowych i innych działań w wybranym regionie wdrożenie może potrwać do 40 minut.
Weryfikowanie funkcjonalności wdrożenia
W krokach w tej sekcji pokazano, jak sprawdzić, czy wdrożenie zostało ukończone pomyślnie.
Jeśli nastąpi przejście z dala od strony Wdrożenie jest w toku , poniższe kroki pokazują, jak wrócić do tej strony. Jeśli nadal znajdujesz się na stronie z wyświetlonym komunikatem Wdrożenie zostało ukończone, możesz przejść do kroku 5.
W rogu dowolnej strony portalu wybierz menu hamburgera, a następnie wybierz pozycję Grupy zasobów.
W polu z tekstem Filtr dla dowolnego pola wprowadź kilka pierwszych znaków utworzonej wcześniej grupy zasobów. Jeśli wykonano zalecaną konwencję, wprowadź swoje inicjały, a następnie wybierz odpowiednią grupę zasobów.
W okienku nawigacji w sekcji Ustawienia wybierz pozycję Wdrożenia. Zostanie wyświetlona uporządkowana lista wdrożeń w tej grupie zasobów z najnowszą.
Przewiń do najstarszego wpisu na tej liście. Ten wpis odpowiada wdrożeniu rozpoczętym w poprzedniej sekcji. Wybierz najstarsze wdrożenie, jak pokazano na poniższym zrzucie ekranu.
W okienku nawigacji wybierz pozycję Dane wyjściowe. Ta lista zawiera wartości wyjściowe z wdrożenia, które zawierają kilka przydatnych informacji.
Otwórz terminal i wklej wartość z pola cmdToGetKubeadminCredentials . Zobaczysz konto administratora i poświadczenia logowania się do portalu konsoli klastra OpenShift. Poniższa zawartość to przykład konta administratora.
az aro list-credentials --resource-group abc1228rg --name clusterf9e8b9 { "kubeadminPassword": "xxxxx-xxxxx-xxxxx-xxxxx", "kubeadminUsername": "kubeadmin" }
Wklej wartość z pola clusterConsoleUrl do przeglądarki internetowej połączonej z Internetem, a następnie naciśnij Enter. Wypełnij nazwę użytkownika i hasło administratora i zaloguj się.
Sprawdź, czy jest zainstalowany odpowiedni operator Kubernetes dla platformy Liberty. W okienku nawigacji wybierz pozycję Operatory, a następnie pozycję Zainstalowane operatory, jak pokazano na poniższym zrzucie ekranu:
Pamiętaj, jeśli zainstalowano operatora WebSphere Liberty lub operatora Open Liberty. Wariant operatora jest zgodny z wybranymi elementami w czasie wdrażania. W przypadku wybrania opcji IBM Supported (Obsługiwane przez firmę IBM) masz operator WebSphere Liberty. W przeciwnym razie masz operator Open Liberty. Te informacje są ważne, aby wiedzieć w kolejnych krokach.
Pobierz i zainstaluj interfejs wiersza polecenia platformy OpenShift, wykonując kroki opisane w samouczku Instalowanie interfejsu wiersza polecenia
oc
platformy OpenShift, a następnie wróć do tej dokumentacji.Przejdź do okienka Dane wyjściowe , skopiuj wartość z pola cmdToLoginWithKubeadmin , a następnie wklej ją w terminalu. Uruchom polecenie , aby zalogować się do serwera interfejsu API klastra OpenShift. Powinny zostać wyświetlone dane wyjściowe podobne do poniższego przykładu w konsoli programu :
Login successful. You have access to 71 projects, the list has been suppressed. You can list all projects with 'oc projects' Using project "default".
Tworzenie bazy danych SQL platformy Azure
Poniższe kroki zawierają instrukcje tworzenia pojedynczej bazy danych usługi Azure SQL Database do użycia z aplikacją:
Utwórz pojedynczą bazę danych w usłudze Azure SQL Database, wykonując kroki opisane w przewodniku Szybki start: Tworzenie pojedynczej bazy danych Usługi Azure SQL Database, uważnie zwracając uwagę na różnice opisane w poniższej notatce. Bazę danych można wdrożyć w tej samej grupie zasobów co klaster OpenShift. Wróć do tego artykułu po utworzeniu i skonfigurowaniu serwera bazy danych.
Uwaga
W kroku Podstawowe zapisz wartości dla grupy zasobów, nazwy bazy danych, <nazwy> serwera.database.windows.net, identyfikatora logowania administratora serwera i hasła. Grupa zasobów bazy danych jest określana
<db-resource-group>
w dalszej części tego artykułu.W kroku Sieć ustaw opcję Metoda łączności na publiczny punkt końcowy, Zezwalaj usługom i zasobom platformy Azure na dostęp do tego serwera na wartość Tak, a następnie dodaj bieżący adres IP klienta na wartość Tak.
Utwórz zmienną środowiskową w powłoce dla nazwy grupy zasobów bazy danych.
export DB_RESOURCE_GROUP_NAME=<db-resource-group>
Uwaga
Ten artykuł zawiera instrukcje tworzenia pojedynczej bazy danych usługi Azure SQL Database z uwierzytelnianiem SQL. Bezpieczniejszą praktyką jest użycie uwierzytelniania usługi Microsoft Entra dla usługi Azure SQL do uwierzytelniania połączenia serwera bazy danych. Usługa Azure Red Hat OpenShift nie obsługuje obecnie Tożsamość obciążeń Microsoft Entra, dlatego uwierzytelnianie SQL jest jedyną dostępną opcją.
Po utworzeniu bazy danych i klastra Azure Red Hat OpenShift możesz przygotować klaster Usługi Azure Red Hat OpenShift do hostowania aplikacji WebSphere Liberty.
Konfigurowanie i wdrażanie przykładowej aplikacji
Wykonaj kroki opisane w tej sekcji, aby wdrożyć przykładową aplikację w środowisku uruchomieniowym Liberty. W tych krokach użyto narzędzia Maven.
Wyewidencjonowywanie aplikacji
Sklonuj przykładowy kod dla tego przewodnika, używając następujących poleceń. Przykład znajduje się w witrynie GitHub.
git clone https://github.com/Azure-Samples/open-liberty-on-aro.git
cd open-liberty-on-aro
export BASE_DIR=$PWD
git checkout 20240920
cd 3-integration/connect-db/mssql
Jeśli zostanie wyświetlony komunikat o stanie "odłączony HEAD", ten komunikat jest bezpieczny do zignorowania. Oznacza to po prostu wyewidencjonowanie tagu.
W repozytorium znajduje się kilka przykładów. Używamy 3-integration/connect-db/mssql/. Oto struktura plików aplikacji:
mssql
├─ src/main/
│ ├─ aro/
│ │ ├─ db-secret.yaml
│ │ ├─ openlibertyapplication.yaml
│ │ ├─ webspherelibertyapplication.yaml
│ ├─ docker/
│ │ ├─ Dockerfile
│ │ ├─ Dockerfile-ol
│ ├─ liberty/config/
│ │ ├─ server.xml
│ ├─ java/
│ ├─ resources/
│ ├─ webapp/
├─ pom.xml
Katalogi java, zasoby i aplikacja internetowa zawierają kod źródłowy przykładowej aplikacji. Kod deklaruje i używa źródła danych o nazwie jdbc/JavaEECafeDB
.
W katalogu aro znajdują się trzy pliki wdrożenia. db-secret.xml służy do tworzenia wpisów tajnych kubernetes z poświadczeniami połączenia bazy danych. Plik webspherelibertyapplication.yaml jest używany w tym przewodniku Szybki start do wdrażania aplikacji WebSphere Liberty. Użyj pliku openlibertyapplication.yaml , aby wdrożyć aplikację Open Liberty, jeśli wdrożono program Open Liberty Operator w sekcji Wdrażanie ibm WebSphere Liberty lub Open Liberty w usłudze Azure Red Hat OpenShift.
W katalogu platformy Docker istnieją dwa pliki do utworzenia obrazu aplikacji za pomocą polecenia Open Liberty lub WebSphere Liberty. Są to odpowiednio pliki Dockerfile i Dockerfile-ol. Plik Dockerfile służy do kompilowania obrazu aplikacji za pomocą rozwiązania WebSphere Liberty w tym przewodniku Szybki start. Podobnie użyj pliku Dockerfile-ol , aby skompilować obraz aplikacji za pomocą biblioteki Open Liberty, jeśli wdrożono program Open Liberty Operator w sekcji Deploy IBM WebSphere Liberty or Open Liberty on Azure Red Hat OpenShift (Wdrażanie oprogramowania IBM WebSphere Liberty lub Open Liberty w usłudze Azure Red Hat OpenShift).
W katalogu liberty/config plik server.xml służy do konfigurowania połączenia bazy danych dla klastra Open Liberty i WebSphere Liberty.
Kompilowanie projektu
Po zebraniu niezbędnych właściwości możesz skompilować aplikację przy użyciu następujących poleceń. Plik POM dla projektu odczytuje wiele zmiennych ze środowiska. W ramach kompilacji narzędzia Maven te zmienne są używane do wypełniania wartości w plikach YAML znajdujących się w pliku src/main/aro. Jeśli wolisz, możesz zrobić coś podobnego dla aplikacji spoza narzędzia Maven.
cd ${BASE_DIR}/3-integration/connect-db/mssql
# The following variables are used for deployment file generation into target.
export DB_SERVER_NAME=<server-name>.database.windows.net
export DB_NAME=<database-name>
export DB_USER=<server-admin-login>@<server-name>
export DB_PASSWORD=<server-admin-password>
mvn clean install
(Opcjonalnie) Testowanie projektu lokalnie
Teraz możesz uruchomić i przetestować projekt lokalnie przed wdrożeniem na platformie Azure, wykonując następujące kroki. Dla wygody użyjemy elementu liberty-maven-plugin
. Aby dowiedzieć się więcej na temat programu liberty-maven-plugin
, zobacz Tworzenie aplikacji internetowej za pomocą narzędzia Maven. W przypadku aplikacji możesz zrobić coś podobnego przy użyciu dowolnego innego mechanizmu, takiego jak lokalne środowisko IDE. Możesz również rozważyć użycie opcji przeznaczonej liberty:devc
do programowania z kontenerami. Więcej liberty:devc
informacji można przeczytać w dokumentacji Liberty.
Uruchom aplikację przy użyciu polecenia
liberty:run
, jak pokazano w poniższym przykładzie.liberty:run
Używa również zmiennych środowiskowych zdefiniowanych w poprzedniej sekcji.cd ${BASE_DIR}/3-integration/connect-db/mssql mvn liberty:run
Sprawdź, czy aplikacja działa zgodnie z oczekiwaniami. W przypadku powodzenia powinien zostać wyświetlony komunikat podobny do
[INFO] [AUDIT] CWWKZ0003I: The application javaee-cafe updated in 1.930 seconds.
w danych wyjściowych polecenia. Przejdź dohttp://localhost:9080/
przeglądarki lubhttps://localhost:9443/
w przeglądarce i sprawdź, czy aplikacja jest dostępna, a wszystkie funkcje działają.Naciśnij Ctrl+C, aby zatrzymać.
Następnie wykonaj następujące kroki, aby konteneryzować projekt przy użyciu platformy Docker i uruchomić go jako kontener lokalnie przed wdrożeniem na platformie Azure:
Użyj następujących poleceń, aby skompilować obraz:
cd ${BASE_DIR}/3-integration/connect-db/mssql/target docker buildx build --platform linux/amd64 -t javaee-cafe:v1 --pull --file=Dockerfile .
Uruchom obraz przy użyciu następującego polecenia. Pamiętaj, że używamy wcześniej zdefiniowanych zmiennych środowiskowych.
docker run -it --rm -p 9080:9080 -p 9443:9443 \ -e DB_SERVER_NAME=${DB_SERVER_NAME} \ -e DB_NAME=${DB_NAME} \ -e DB_USER=${DB_USER} \ -e DB_PASSWORD=${DB_PASSWORD} \ javaee-cafe:v1
Po uruchomieniu kontenera przejdź do
http://localhost:9080/
https://localhost:9443/
lub w przeglądarce, aby uzyskać dostęp do aplikacji.Naciśnij Ctrl+C, aby zatrzymać.
Kompilowanie obrazu i wypychanie do strumienia obrazu
Jeśli stan aplikacji jest zadowalający, należy utworzyć obraz zdalnie w klastrze, wykonując następujące kroki.
Użyj następujących poleceń, aby tożsamości katalogu źródłowego i pliku Dockerfile:
cd ${BASE_DIR}/3-integration/connect-db/mssql/target # If you are deploying the application with WebSphere Liberty Operator, the existing Dockerfile is ready for you # If you are deploying the application with Open Liberty Operator, uncomment and execute the following two commands to rename Dockerfile-ol to Dockerfile # mv Dockerfile Dockerfile.backup # mv Dockerfile-ol Dockerfile
Użyj następującego polecenia, aby utworzyć strumień obrazu:
oc create imagestream javaee-cafe
Użyj następującego polecenia, aby utworzyć konfigurację kompilacji, która określa tag strumienia obrazu danych wyjściowych kompilacji:
oc new-build --name javaee-cafe-config --binary --strategy docker --to javaee-cafe:v1
Użyj następującego polecenia, aby uruchomić kompilację w celu przekazania zawartości lokalnej, konteneryzowania i danych wyjściowych do tagu strumienia obrazu określonego wcześniej:
oc start-build javaee-cafe-config --from-dir . --follow
Wdrażanie i testowanie aplikacji
Aby wdrożyć i przetestować aplikację, wykonaj następujące kroki:
Użyj następującego polecenia, aby zastosować wpis tajny bazy danych:
cd ${BASE_DIR}/3-integration/connect-db/mssql/target oc apply -f db-secret.yaml
Powinny zostać wyświetlone dane wyjściowe
secret/db-secret-mssql created
.Użyj następującego polecenia, aby zastosować plik wdrożenia:
oc apply -f webspherelibertyapplication.yaml
Zaczekaj, aż wszystkie zasobniki zostaną uruchomione i uruchomione pomyślnie, używając następującego polecenia:
oc get pods -l app.kubernetes.io/name=javaee-cafe --watch
Powinny zostać wyświetlone dane wyjściowe podobne do poniższego przykładu, aby wskazać, że wszystkie zasobniki są uruchomione:
NAME READY STATUS RESTARTS AGE javaee-cafe-67cdc95bc-2j2gr 1/1 Running 0 29s javaee-cafe-67cdc95bc-fgtt8 1/1 Running 0 29s javaee-cafe-67cdc95bc-h47qm 1/1 Running 0 29s
Aby sprawdzić wyniki, wykonaj następujące czynności:
Użyj następującego polecenia, aby pobrać host zasobu Route wdrożonego z aplikacją:
echo "route host: https://$(oc get route javaee-cafe --template='{{ .spec.host }}')"
Skopiuj wartość z danych wyjściowych
route host
, otwórz ją w przeglądarce i przetestuj aplikację. Jeśli strona internetowa nie jest poprawnie renderowana, oznacza to, że aplikacja nadal zaczyna się w tle. Poczekaj kilka minut, a następnie spróbuj ponownie.Dodaj i usuń kilka kaw, aby zweryfikować funkcjonalność aplikacji i połączenia bazy danych.
Czyszczenie zasobów
Aby uniknąć opłat za platformę Azure, należy wyczyścić niepotrzebne zasoby. Gdy klaster nie jest już potrzebny, użyj polecenia az group delete , aby usunąć grupę zasobów, klaster Azure Red Hat OpenShift, usługę Azure SQL Database i wszystkie powiązane zasoby.
az group delete --name $RESOURCE_GROUP_NAME --yes --no-wait
az group delete --name $DB_RESOURCE_GROUP_NAME --yes --no-wait
Następne kroki
Aby uzyskać więcej informacji na temat wdrażania rodziny IBM WebSphere na platformie Azure, zobacz Co to są rozwiązania do uruchamiania rodziny produktów WebSphere na platformie Azure?