Integrazione con Jenkins

Questa pagina ti guida nella configurazione di Jenkins per archiviare i pacchetti Maven creati in un repository Artifact Registry.

Prima di iniziare

Se il repository di destinazione non esiste, creane uno nuovo.

Configurazione dell'accesso al repository

  1. Crea un account di servizio dedicato da utilizzare con Artifact Registry.

    Esegui questo comando per creare un account di servizio denominato jenkins-sa:

    gcloud iam service-accounts create jenkins-sa
    

    In questo modo viene creato un account di servizio denominato jenkins-sa@PROJECT.iam.gserviceaccount.com, dove PROJECT è l'ID progetto.

  2. Nel progetto che contiene il repository, concedi il ruolo Writer Artifact Registry al account di servizio Jenkins che hai creato. Puoi concedere il ruolo per tutti i repository nel progetto oppure per i repository specifici a cui account di servizio deve accedere.

    Per informazioni dettagliate sulle autorizzazioni e sulla concessione dell'accesso in base al ruolo, consulta Configurazione del controllo dell'accesso.

Configurazione di un cluster GKE

Quando configuri un nuovo cluster Google Kubernetes Engine o un nuovo pool di nodi, utilizza il account di servizio che hai creato per Jenkins.

Console

Per creare un cluster utilizzando la console Google Cloud , segui questi passaggi:

  1. Visita il menu Artifact Registry nella console Google Cloud .

    Visita il menu di Artifact Registry

  2. Fai clic su Crea cluster.

  3. Configura il cluster come preferisci. Non fare ancora clic su Crea.

  4. Fai clic su Altre opzioni nel pool di nodi predefinito.

  5. Nella sezione Sicurezza, seleziona il service account Jenkins che hai creato.

  6. Fai clic su Salva per uscire dalla sovrapposizione.

  7. Fai clic su Crea.

gcloud

Utilizza uno dei seguenti comandi per creare il cluster con il account di servizio Jenkins. Nei comandi, PROJECT è l'ID progetto.

Per creare un cluster con il account di servizio, esegui il comando.

gcloud container clusters create example-cluster --service-account=jenkins-sa@PROJECT.iam.gserviceaccount.com

Per creare un pool di nodi in un cluster esistente:

gcloud container node-pools create example-pool --service-account=jenkins-sa@PROJECT.iam.gserviceaccount.com

Per maggiori dettagli sul comando, consulta la documentazione di gcloud container clusters create.

Configurazione di Jenkins su GKE

  1. Segui il tutorial per configurare Jenkins su GKE. Utilizza il cluster che hai creato nella sezione precedente.

  2. In Jenkins, aggiorna il plug-in GKE all'ultima versione. Fai clic su Manage Jenkins (Gestisci Jenkins) > Manage Plugins (Gestisci plug-in) > Updates (Aggiornamenti).

Configura un progetto Maven

  1. Crea un fork del progetto Maven di esempio nel repository GitHub della documentazione di Jenkins.

  2. Clona il repository di cui è stato eseguito il fork.

    git clone git@github.com:USER_NAME/simple-java-maven-app.git
    
  3. Configura una nuova pipeline nell'interfaccia di Jenkins.

    1. Fai clic su Nuovo elemento.
    2. Seleziona Pipeline.
    3. Imposta un nome per la pipeline e fai clic su OK.
  4. Nella scheda Generale, configura le seguenti opzioni nella sezione Pipeline:

    • Seleziona Pipeline script from SCM (Script della pipeline da SCM).
    • Nell'elenco a discesa SCM, seleziona Git, quindi specifica l'URL e le credenziali per connetterti al tuo repository GitHub.

    Screenshot delle impostazioni della pipeline

  5. Fai clic su Salva.

Configurazione della connessione al repository

Configura Jenkins con il repository e le credenziali per connetterti al repository.

  1. Aggiungi il tuo repository a Maven pom.xml. Utilizza il seguente comando per stampare uno snippet da aggiungere.

    gcloud artifacts print-settings mvn [--project=PROJECT] \
    [--repository=REPOSITORY] [--location=LOCATION]
    

    Dove

    • PROJECT è l'ID progetto. Se questo flag viene omesso, viene utilizzato il progetto corrente o predefinito.
    • REPOSITORY è l'ID del repository. Se hai configurato un repository Artifact Registry predefinito, questo viene utilizzato quando questo flag viene omesso dal comando.
    • LOCATION è la posizione regionale o multiregionale del repository.
  2. Crea un file YAML come modello di pod per gli agenti Jenkins.

    mkdir jenkins
    cat > jenkins/maven-pod.yaml << EOF
    apiVersion: v1
    kind: Pod
    spec:
      containers:
      - name: maven
        image: maven:3.3.9-jdk-8-alpine
        command: ['cat']
        tty: true
    EOF
    
  3. Modifica il file Jenkinsfile.

    pipeline {
        agent none
        stages {
            stage('Deploy') {
                steps {
                     agent {
                         kubernetes {
                             label 'mavenpod'
                             yamlFile 'jenkins/maven-pod.yaml'
                           }
                       }
                       container('maven') {
                       sh "mvn -B clean deploy"
                     }
                }
            }
        }
    }
    

Avvio di una build

  1. Esegui il push delle modifiche apportate al progetto GitHub.

    git add . && git commit -m "Configure my Jenkins pipeline" && git push
    
  2. Nell'interfaccia Jenkins, avvia una nuova build per l'applicazione nel progetto Maven di esempio.

Al termine della build, gli artefatti vengono aggiunti al repository di pacchetti Java di Artifact Registry che hai creato.

Esegui il comando seguente per elencare i pacchetti nel repository:

gcloud artifacts packages list --repository=mvn-jenkins --location=LOCATION

L'output è simile al seguente esempio:

Listing items under project {YOUR_PROJECT}, repository mvn-jenkins.

PACKAGE                   CREATE_TIME          UPDATE_TIME
com.mycompany.app:my-app  2019-06-25T17:09:44  2019-06-25T17:09:44