Rozproszone śledzenie za pomocą usług Spring Cloud Sleuth i Cloud Trace

Rozproszone śledzenie za pomocą usług Spring Cloud Sleuth i Cloud Trace

Informacje o tym ćwiczeniu (w Codelabs)

subjectOstatnia aktualizacja: kwi 11, 2023
account_circleDokument stworzony przez pracownika Google

1. Omówienie

Rozproszone śledzenie jest ważne, ponieważ pozwala uzyskać statystyki i obserwację wielowarstwowej architektury mikroserwisów. Jeśli udało Ci się utworzyć łańcuch wywołań usługi z usługi A do usługi B i usługi C, musisz wiedzieć, czy wywołania były udane, a także opóźnienia na każdym kroku.

W Spring Boot możesz użyć usługi Spring Cloud Sleuth, aby płynnie dodać do swojej aplikacji instrumentację rozproszonego śledzenia. Domyślnie może przekazywać dane śledzenia do Zipkin.

W Google Cloud Platform jest usługa zarządzana Cloud Trace, która umożliwia przechowywanie danych śledzenia bez konieczności zarządzania własną instancją Zipkin ani jej pamięcią. Cloud Trace może również generować raporty z rozkładem czasu oczekiwania i automatycznie wykrywać spadki wydajności.

Cloud Trace możesz używać z aplikacji Spring Boot na 2 sposoby:

  1. Użyj serwera proxy usługi Stackdriver Trace Zipkin i skonfiguruj aplikację Spring Cloud Sleuth tak, aby używała tego serwera proxy jako punktu końcowego Zipkin
  2. Możesz też użyć logu czasu usługi Spring Cloud GCP, który płynnie integruje się z usługą Spring Cloud Sleuth i przekazuje dane z logów czasu bezpośrednio do Cloud Trace.

Z tego ćwiczenia w Codelabs dowiesz się, jak utworzyć nową aplikację Spring Boot i użyć śledzenia usługi Spring Cloud GCP do śledzenia rozproszonego.

Czego się nauczysz

  • Jak utworzyć aplikację Spring Boot w Javie i skonfigurować Cloud Trace.

Czego potrzebujesz

  • Projekt Google Cloud Platform
  • przeglądarkę, np. Chrome lub Firefox;
  • znajomość standardowych edytorów tekstu systemu Linux, takich jak Vim, EMAC lub Nano;

Jak wykorzystasz ten samouczek?

Jak oceniasz swoje doświadczenie z tworzeniem aplikacji internetowych HTML/CSS?

Jak oceniasz swoje wrażenia z korzystania z usług Google Cloud Platform?

2. Konfiguracja i wymagania

Samodzielne konfigurowanie środowiska

  1. Zaloguj się w konsoli Google Cloud i utwórz nowy projekt lub wykorzystaj już istniejący. Jeśli nie masz jeszcze konta Gmail ani Google Workspace, musisz je utworzyć.

b35bf95b8bf3d5d8.png

a99b7ace416376c4.png

bd84a6d3004737c5.png

  • Nazwa projektu jest wyświetlaną nazwą uczestników tego projektu. To ciąg znaków, który nie jest używany przez interfejsy API Google. W każdej chwili możesz ją zaktualizować.
  • Identyfikator projektu jest unikalny we wszystkich projektach Google Cloud i nie można go zmienić (po jego ustawieniu nie można go zmienić). Cloud Console automatycznie wygeneruje unikalny ciąg znaków. zwykle nieważne, co ona jest. W większości ćwiczeń w Codelabs musisz podać swój identyfikator projektu (zwykle identyfikowany jako PROJECT_ID). Jeśli nie podoba Ci się wygenerowany identyfikator, możesz wygenerować kolejny losowy. Możesz też spróbować własnych sił i sprawdzić, czy jest dostępna. Po wykonaniu tej czynności nie można jej już zmienić. Pozostanie ona przez cały czas trwania projektu.
  • Jest jeszcze trzecia wartość, numer projektu, z którego korzystają niektóre interfejsy API. Więcej informacji o wszystkich 3 wartościach znajdziesz w dokumentacji.
  1. Następnie musisz włączyć płatności w Cloud Console, aby korzystać z zasobów Cloud/interfejsów API. Ukończenie tego ćwiczenia z programowania nic nie kosztuje. Aby wyłączyć zasoby w celu uniknięcia naliczania opłat po zakończeniu tego samouczka, możesz usunąć utworzone zasoby lub projekt. Nowi użytkownicy Google Cloud mogą skorzystać z programu bezpłatnego okresu próbnego o wartości 300 USD.

Google Cloud Shell,

Google Cloud i Kubernetes możesz obsługiwać zdalnie z Twojego laptopa, ale w ramach tego ćwiczenia z programowania użyjemy Google Cloud Shell – środowiska wiersza poleceń działającego w chmurze.

Aktywowanie Cloud Shell

  1. W konsoli Cloud kliknij Aktywuj Cloud Shell 853e55310c205094.png.

55efc1aaa7a4d3ad.png

Jeśli uruchamiasz Cloud Shell po raz pierwszy, zobaczysz ekran pośredni z opisem tej usługi. Jeśli wyświetlił się ekran pośredni, kliknij Dalej.

9c92662c6a846a5c.png

Uzyskanie dostępu do Cloud Shell i połączenie się z nim powinno zająć tylko kilka chwil.

9f0e51b578fecce5.png

Ta maszyna wirtualna ma wszystkie potrzebne narzędzia dla programistów. Zawiera stały katalog domowy o pojemności 5 GB i działa w Google Cloud, co znacznie zwiększa wydajność sieci i uwierzytelnianie. Większość zadań w ramach tego ćwiczenia z programowania można wykonać w przeglądarce.

Po nawiązaniu połączenia z Cloud Shell powinno pojawić się potwierdzenie, że użytkownik jest uwierzytelniony, a projekt jest ustawiony na identyfikator Twojego projektu.

  1. Uruchom to polecenie w Cloud Shell, aby potwierdzić, że jesteś uwierzytelniony:
gcloud auth list

Dane wyjściowe polecenia

 Credentialed Accounts
ACTIVE  ACCOUNT
*       <my_account>@<my_domain.com>

To set the active account, run:
    $ gcloud config set account `ACCOUNT`
  1. Uruchom to polecenie w Cloud Shell, aby sprawdzić, czy polecenie gcloud zna Twój projekt:
gcloud config list project

Dane wyjściowe polecenia

[core]
project = <PROJECT_ID>

Jeśli tak nie jest, możesz go ustawić za pomocą tego polecenia:

gcloud config set project <PROJECT_ID>

Dane wyjściowe polecenia

Updated property [core/project].

3. Utwórz nową usługę Spring Boot REST

Po uruchomieniu Cloud Shell możesz użyć wiersza poleceń, aby wygenerować nową aplikację Spring Boot za pomocą Spring Initializr:

$ curl https://start.spring.io/starter.tgz -d packaging=jar \
 
-d bootVersion=2.7.6 \
 
-d dependencies=web,lombok,cloud-gcp,distributed-tracing \
 
-d jvmVersion=17 \
 
-d type=maven-project \
 
-d baseDir=trace-service-one | tar -xzvf - \
 
&& cd trace-service-one

Utwórz nowy kontroler REST, dodając nową klasę:

src/main/java/com/example/demo/WorkController.java

package com.example.demo;

import lombok.extern.slf4j.Slf4j;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RestController;

import java.util.Random;

@RestController
@Slf4j
public class WorkController {
 
Random r = new Random();

 
public void meeting() {
   
try {
      log
.info("meeting...");
     
// Delay for random number of milliseconds.
     
Thread.sleep(r.nextInt(500));
   
} catch (InterruptedException e) {
   
}
 
}

 
@GetMapping("/")
 
public String work() {
   
// What is work? Meetings!
   
// When you hit this URL, it'll call meetings() 5 times.
   
// Each time will have a random delay.
    log
.info("starting to work");
   
for (int i = 0; i < 5; i++) {
     
this.meeting();
   
}
    log
.info("finished!");
   
return "finished work!";
 
}
}

Upewnij się, że masz właściwą wersję JVM dla aplikacji:

$ export JAVA_HOME=/usr/lib/jvm/java-1.17.0-openjdk-amd64

Aplikację Spring Boot możesz uruchomić w zwykły sposób, używając wtyczki Spring Boot. W tym module pomińmy testy:

$ ./mvnw -DskipTests spring-boot:run

Po uruchomieniu aplikacji kliknij ikonę podglądu w przeglądarce 3a9b40fafa650b2b.png na pasku narzędzi Cloud Shell i wybierz podgląd na porcie 8080.

3aca52f76c6c22a3.png

Wynik powinien pojawić się po krótkim czasie:

6793a3339447cbb5.png

W Cloud Shell powinny być też widoczne komunikaty logu z identyfikatorami logu czasu i identyfikatorami spanu:

18d597c388de1ba.png

4. Korzystanie z Cloud Trace

Włącz Cloud Trace API

Zanim użyjesz Cloud Trace do przechowywania danych logu czasu, musisz włączyć interfejs Cloud Trace API. Aby włączyć interfejs API, wykonaj:

$ gcloud services enable cloudtrace.googleapis.com

Skonfiguruj domyślne dane logowania aplikacji

W tym module musisz skonfigurować domyślne dane logowania aplikacji. Te dane logowania będą automatycznie pobierane przez polecenie inicjujące logi czasu Spring Cloud GCP.

Najpierw się zaloguj:

$ gcloud auth application-default login
You are running on a Google Compute Engine virtual machine.
The service credentials associated with this virtual machine
will automatically be used
by Application Default
Credentials, so it is not necessary to use this command.
If you decide to proceed anyway, your user credentials may be visible
to others
with access to this virtual machine. Are you sure you want
to authenticate
with your personal account?
Do you want to continue (Y/n)? Y

Go to the following link in your browser:
    https
://accounts.google.com/o/oauth2/auth...
Enter verification code: ...

Kliknij link, aby otworzyć nową kartę przeglądarki, a następnie kliknij Zezwól.

85f500de6f5dc0a8.png

Następnie skopiuj kod weryfikacyjny, wklej go z powrotem do Cloud Shell i naciśnij Enter. Zobaczysz, że:

Credentials saved to file: [/tmp/tmp.jm9bnQ4R9Q/application_default_credentials.json]
These credentials will be used by any library that requests
Application Default Credentials.

Dodaj log czasu Spring Cloud GCP

W tej usłudze używamy już do śledzenia usługi Spring Cloud Sleuth. Dodajmy polecenie inicjujące logi czasu Spring Cloud GCP, aby przekierować dane do Cloud Trace.

Dodaj zależność śledzenia usługi Spring Cloud GCP:

pom.xml

<project>
  ...
 
<dependencies>
    ...
   
<!-- Add Cloud Trace Starter -->
   
<dependency>
     
<groupId>com.google.cloud</groupId>
     
<artifactId>spring-cloud-gcp-starter-trace</artifactId>
   
</dependency>
 
</dependencies>
  ...
</project>

Domyślnie Spring Cloud Sleuth nie sprawdza wszystkich żądań. Aby ułatwić testowanie, zwiększ w application.properties częstotliwość próbkowania do 100%, aby mieć pewność, że widzisz dane logu czasu, a potem zignoruj niektóre adresy URL, które są dla nas nieistotne:

$ echo "
spring.sleuth.sampler.probability=1.0
spring.sleuth.web.skipPattern=(^cleanup.*|.+favicon.*)
"
> src/main/resources/application.properties

Uruchom aplikację jeszcze raz i użyj podglądu Cloud Shell w przeglądarce, aby ją wyświetlić:

$ export GOOGLE_CLOUD_PROJECT=`gcloud config list --format 'value(core.project)'`
$
./mvnw -DskipTests spring-boot:run

Domyślnie usługa Spring Cloud GCP Trace zbiera dane śledzenia i wysyła je co 10 sekund lub po otrzymaniu minimalnej liczby takich danych. Możesz to skonfigurować. Więcej informacji znajdziesz w dokumentacji dotyczącej śledzenia usługi Spring Cloud GCP.

Wyślij żądanie do usługi:

$ curl localhost:8080

W konsoli Google Cloud wybierz OperacjeŚledzenieLista logów czasu

be48cb0f99b5f7c2.png

U góry zawęź zakres czasu do 1 godziny. Domyślnie opcja Automatyczne odświeżanie jest włączona. Gdy przyjdą dane logu czasu, powinny się one pojawić w konsoli.

3522eef823df39d8.png

Dane logu czasu powinny się pojawić w ciągu około 30 sekund.

9628f6e1d2e75b05.png

Aby zobaczyć szczegóły logu czasu, kliknij niebieską kropkę:

ba9051a8d4f3e725.png

To było całkiem proste.

5. Tworzenie drugiej aplikacji internetowej Spring Boot

Otwórz nową sesję Cloud Shell, klikając ikonę +:

9799bee5fea95aa6.png

W nowej sesji utwórz drugą aplikację Spring Boot:

$ curl https://start.spring.io/starter.tgz -d packaging=jar \
 
-d bootVersion=2.7.6 \
 
-d dependencies=web,lombok,cloud-gcp,distributed-tracing \
 
-d jvmVersion=17 \
 
-d type=maven-project \
 
-d baseDir=trace-service-two | tar -xzvf - \
 
&& cd trace-service-two

Utwórz nowy kontroler REST, dodając nową klasę:

src/main/java/com/example/demo/MeetingController.java

package com.example.demo;

import lombok.extern.slf4j.Slf4j;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RestController;

import java.util.Random;

@RestController
@Slf4j
public class MeetingController {
 
Random r = new Random();

 
@GetMapping("/meet")
 
public String meeting() {
   
try {
      log
.info("meeting...");
     
Thread.sleep(r.nextInt(500 - 20 + 1) + 20);
   
} catch (InterruptedException e) {
   
}
   
return "finished meeting";
 
}
}

Dodaj ślad Spring Cloud GCP do pliku pom.xml

pom.xml

<project>
  ...
 
<dependencies>
    ...
   
<!-- Add Cloud Trace starter -->
   
<dependency>
     
<groupId>com.google.cloud</groupId>
     
<artifactId>spring-cloud-gcp-starter-trace</artifactId>
   
</dependency>
 
</dependencies>
  ...
</project>

Skonfiguruj w usłudze Sleuth próbkowanie 100% żądań:

src/main/resources/application.properties

$ echo "
spring.sleuth.sampler.probability=1.0
spring.sleuth.web.skipPattern=(^cleanup.*|.+favicon.*)
"
> src/main/resources/application.properties

Możesz też uruchomić aplikację Spring Boot na porcie 8081, używając wtyczki Spring Boot:

$ export GOOGLE_CLOUD_PROJECT=`gcloud config list --format 'value(core.project)'`
$
./mvnw -DskipTests spring-boot:run -Dspring-boot.run.jvmArguments="-Dserver.port=8081"

6. Zaktualizuj pierwszą usługę, aby skorzystać z drugiej usługi

Gdy masz uruchomiony pakiet trace-service-two, wróć do pierwszego okna sesji Cloud Shell i wprowadź zmiany do trace-service-one.

Najpierw zainicjuj nowy komponent bean RestTemplate:

src/main/java/com/example/demo/DemoApplication.java

package com.example.demo;

...

import org.springframework.web.client.RestTemplate;
import org.springframework.context.annotation.Bean;

@SpringBootApplication
public class DemoApplication {
       
@Bean
       
public RestTemplate restTemplate() {
               
return new RestTemplate();
       
}
       
       
public static void main(String[] args) {
               
SpringApplication.run(DemoApplication.class, args);
       
}
}

W WorkController.meeting() zadzwoń do usługi spotkań.

src/main/java/com/example/demo/WorkController.java

package com.example.demo;

...
import org.springframework.web.client.RestTemplate;
import org.springframework.beans.factory.annotation.Autowired;

@RestController
@Slf4j
public class WorkController {
 
@Autowired
 
RestTemplate restTemplate;

 
public void meeting() {
   
String result = restTemplate.getForObject("http://localhost:8081/meet", String.class);
    log
.info(result);
 
}

 
...
}

Uruchom usługę ponownie i aktywuj punkt końcowy za pomocą wiersza poleceń:

$ export GOOGLE_CLOUD_PROJECT=`gcloud config list --format 'value(core.project)'`

# The '&' places the process in the background. Bring it back to the foreground with 'fg'.
$
./mvnw -DskipTests spring-boot:run &

$ curl localhost
:8080

W obu oknach sesji powinny być widoczne komunikaty dziennika, w których identyfikator logu czasu jest przekazywany między usługami.

Na liście logów czasu Cloud Trace powinien pojawić się drugi log czasu:

13490977f1638702.png

Możesz kliknąć nową niebieską kropkę i zobaczyć szczegóły logu czasu:

ca69ef9cdd13d4aa.png

Możesz też kliknąć dowolny rozpiętość na tym diagramie, aby zobaczyć jego szczegóły.

7. Dystrybucja czasu oczekiwania i Raport skuteczności

Gdy używasz Cloud Trace do przechowywania danych śledzenia, Cloud Trace może wykorzystać te dane do utworzenia raportu rozkładu opóźnień. Aby utworzyć taki raport, potrzebujesz ponad 100 śladów:

c8713f3d9e51dc25.png

Możesz uruchomić te 100 pierwszych żądań za pomocą polecenia hej, które jest już zainstalowane w Cloud Shell.

$ hey localhost:8080 -n 150

Dodatkowo Cloud Trace może automatycznie wykrywać w raporcie analizy spadek wydajności tej samej usługi w 2 różnych okresach.

8. Podsumowanie

W tym module udało Ci się utworzyć 2 proste usługi, dodać śledzenie rozproszone za pomocą usługi Spring Cloud Sleuth oraz wykorzystać platformę Spring Cloud GCP do przekazania informacji logu czasu do Cloud Trace.

9. Gratulacje!

Wiesz już, jak napisać swoją pierwszą aplikację internetową App Engine.

Więcej informacji

Licencja

To zadanie jest licencjonowane na podstawie ogólnej licencji Creative Commons Attribution 2.0.