Questa guida spiega come integrare le applicazioni Java con i flag di funzionalità di App Lifecycle Manager. Scoprirai come utilizzare l'SDK OpenFeature con il provider flagd per valutare i flag gestiti da App Lifecycle Manager, consentendoti di controllare dinamicamente la disponibilità e il comportamento delle funzionalità nei tuoi servizi Java.
Questa guida presuppone che tu abbia già configurato le risorse App Lifecycle Manager necessarie (come offerte SaaS, tipi di unità, unità, flag e rollout) completando una delle seguenti guide rapide:
- Guida rapida: esegui il deployment dei feature flag con App Lifecycle Manager (integrato): se gestisci i deployment delle applicazioni con App Lifecycle Manager.
- Guida rapida: utilizza i flag funzionalità autonomi: se gestisci l'infrastruttura dell'applicazione in modo indipendente, ma vuoi utilizzare App Lifecycle Manager per la gestione dei flag funzionalità.
Prerequisiti
Prima di iniziare, assicurati di disporre di quanto segue:
- Java installato:JDK 17 o versioni successive.
- Hai completato una guida rapida sui flag delle funzionalità di App Lifecycle Manager:
Autenticato
gcloudper le Credenziali predefinite dell'applicazione (ADC): l'applicazione Java utilizza le ADC per l'autenticazione con i servizi Google Cloud . Assicurati di aver eseguito l'autenticazione nel tuo ambiente:gcloud auth application-default loginAutorizzazioni IAM:l'identità che esegue l'applicazione Java richiede il ruolo Identity and Access Management
roles/saasconfig.viewernel progetto Google Cloud per leggere le configurazioni dei flag:gcloud projects add-iam-policy-binding YOUR_PROJECT_ID \ --member="user:YOUR_EMAIL_ADDRESS" \ --role="roles/saasconfig.viewer"Sostituisci
YOUR_PROJECT_IDeYOUR_EMAIL_ADDRESSdi conseguenza.
Informazioni sulle variabili di ambiente chiave
La tua applicazione Java si basa su variabili di ambiente per connettersi alla configurazione dei flag corretta.
FLAGD_SOURCE_PROVIDER_ID: specifica quale configurazione del flag funzionalità recuperare dal servizio App Lifecycle Manager. Deve essere il nome completo della risorsa diFeatureFlagConfigassociata alla tua unità.- Format (Formato):
projects/PROJECT_ID/locations/LOCATION/featureFlagsConfigs/UNIT_ID - Esempio:
projects/my-gcp-project/locations/us-central1/featureFlagsConfigs/my-app-instance-01
- Format (Formato):
Configura il progetto Java
Prima di poter eseguire l'applicazione, devi inizializzare il progetto e configurare le dipendenze necessarie.
Creare una directory di progetto:
mkdir java-featureflag-app cd java-featureflag-appAggiungi dipendenze:configura il sistema di compilazione (Maven o Gradle) in modo da includere le seguenti librerie. Garantisci la compatibilità utilizzando versioni successive a OpenFeature 1.14.1, flagd 0.11.5 e gRPC 1.71.0.
dev.openfeature:javasdk:1.14.1+dev.openfeature.contrib.providers:flagd:0.11.5+io.grpc:grpc-netty-shaded:1.71.0+io.grpc:grpc-auth:1.71.0+com.google.auth:google-auth-library-oauth2-http
Crea il codice di inizializzazione:aggiungi un file denominato
FeatureManagement.javacon i seguenti contenuti. Questa classe configura gli intercettori gRPC per collegare le intestazioni ADC e di routing regionale e inizializzaFlagdProviderutilizzando la risoluzione in-process.import com.google.auth.oauth2.GoogleCredentials; import dev.openfeature.contrib.providers.flagd.Config; import dev.openfeature.contrib.providers.flagd.FlagdOptions; import dev.openfeature.contrib.providers.flagd.FlagdProvider; import dev.openfeature.sdk.OpenFeatureAPI; import io.grpc.*; import io.grpc.auth.MoreCallCredentials; import java.util.ArrayList; import java.util.List; public class FeatureManagement { public static void initialize() throws Exception { // Read the full Unit resource name String flagConfigId = System.getenv("FLAGD_SOURCE_PROVIDER_ID"); if (flagConfigId == null || flagConfigId.isEmpty()) { throw new IllegalStateException("FLAGD_SOURCE_PROVIDER_ID environment variable is not set."); } // Configure gRPC Security and Routing GoogleCredentials credentials = GoogleCredentials.getApplicationDefault(); CallCredentials callCredentials = MoreCallCredentials.from(credentials); List<ClientInterceptor> interceptors = new ArrayList<>(); // Interceptor to inject the Unit name into headers for regional routing interceptors.add(new ClientInterceptor() { @Override public <ReqT, RespT> ClientCall<ReqT, RespT> interceptCall(MethodDescriptor<ReqT, RespT> method, CallOptions callOptions, Channel next) { return new ForwardingClientCall.SimpleForwardingClientCall<ReqT, RespT>(next.newCall(method, callOptions)) { @Override public void start(Listener<RespT> responseListener, Metadata headers) { headers.put(Metadata.Key.of("x-goog-request-params", Metadata.ASCII_STRING_MARSHALLER), "name=" + flagConfigId); super.start(responseListener, headers); } }; } }); // Interceptor to attach ADC to the gRPC calls interceptors.add(new ClientInterceptor() { @Override public <ReqT, RespT> ClientCall<ReqT, RespT> interceptCall(MethodDescriptor<ReqT, RespT> method, CallOptions callOptions, Channel next) { return next.newCall(method, callOptions.withCallCredentials(callCredentials)); } }); // Initialize the flagd provider with In-Process resolution FlagdProvider provider = new FlagdProvider( FlagdOptions.builder() .resolverType(Config.Resolver.IN_PROCESS) .host("saasconfig.googleapis.com").port(443) .tls(true) .providerId(flagConfigId) .clientInterceptors(interceptors) .syncMetadataDisabled(true) .deadline(10000) .build() ); // Set the global provider OpenFeatureAPI.getInstance().setProviderAndWait(provider); } }Crea la logica dell'applicazione:aggiungi un file denominato
Main.javacon il seguente contenuto per eseguire la valutazione del flag.import dev.openfeature.sdk.OpenFeatureAPI; import dev.openfeature.sdk.MutableContext; public class Main { public static void main(String[] args) throws Exception { // 1. Get Client var client = OpenFeatureAPI.getInstance().getClient("simple-api"); // 2. Create Evaluation Context var context = new dev.openfeature.sdk.MutableContext(); // 3. Evaluate Flag // Default to false if evaluation fails or service is unreachable boolean isEnhanced = client.getBooleanValue("enhanced-search", false, context); // 4. Execute business logic based on result if (isEnhanced) { System.out.println("Executing enhanced search algorithm..."); } else { System.out.println("Standard search algorithm..."); } } }
Esegui l'applicazione Java
Puoi eseguire l'applicazione localmente utilizzando la configurazione autonoma o eseguirne il deployment come container.
Esegui in modalità autonoma (localmente)
Imposta le variabili di ambiente:
export PROJECT_ID="your-gcp-project-id" export LOCATION_1="us-central1" export UNIT_ID="my-app-instance-01" export FLAGD_SOURCE_PROVIDER_ID="projects/${PROJECT_ID}/locations/${LOCATION_1}/featureFlagsConfigs/${UNIT_ID}"Esegui l'applicazione:esegui il progetto utilizzando il comando dello strumento di compilazione che preferisci (ad es.
mvn compile exec:javao./gradlew run).
Esegui integrato (containerizzato)
Crea un Dockerfile:definisci una build del container che pacchettizza il binario Java.
FROM maven:3.9-eclipse-temurin-17 AS builder WORKDIR /app COPY pom.xml . COPY src ./src RUN mvn clean package FROM eclipse-temurin:17-jre WORKDIR /app COPY --from=builder /app/target/java-featureflag-app.jar app.jar ENTRYPOINT ["java", "-jar", "app.jar"]Crea ed esegui il push dell'immagine:
export PROJECT_ID="your-gcp-project-id" docker build -t gcr.io/${PROJECT_ID}/my-java-app:latest . docker push gcr.io/${PROJECT_ID}/my-java-app:latestEsegui il deployment del servizio:aggiorna il progetto dell'unità in modo che faccia riferimento a
gcr.io/${PROJECT_ID}/my-java-app:latested esegui il deployment della nuova release utilizzando un'implementazione di App Lifecycle Manager.
Verificare le modifiche ai flag
Una volta eseguita l'applicazione, verifica che valuti correttamente i flag.
- Osserva il valore iniziale:verifica che l'output della console registri il valore valutato corrispondente allo stato di configurazione iniziale.
- Aggiorna il flag in App Lifecycle Manager:modifica il payload del flag o le regole di targeting utilizzando la console Google Cloud o
gcloud. - Verifica il valore aggiornato:esegui di nuovo l'esecuzione locale o osserva i log del container per confermare il nuovo stato valutato.
Passaggi successivi
- Per maggiori dettagli concettuali, leggi la panoramica dei flag delle funzionalità di App Lifecycle Manager.
- Scopri di più sui lanci di App Lifecycle Manager per implementazioni di flag più sicure.
- Consulta la panoramica principale di App Lifecycle Manager.