Skip to content

Contact sales

By filling out this form and clicking submit, you acknowledge our privacy policy.
  • Labs icon Lab
  • A Cloud Guru
Google Cloud Platform icon
Labs

Installing and Configuring Flux with GitHub

This lab introduces the steps necessary steps for installing Flux and configuring it to work with a student repository in GitHub. The student will need their own GitHub account to fork a sample repository, and this lab will spin up a Kubernetes cluster to enable the student to install and configure Flux.

Google Cloud Platform icon
Labs

Path Info

Level
Clock icon Beginner
Duration
Clock icon 45m
Published
Clock icon Feb 13, 2020

Contact sales

By filling out this form and clicking submit, you acknowledge our privacy policy.

Table of Contents

  1. Challenge

    Create a GitHub Repository Under Your Own Account

    To create a repository on GitHub you must log in to your own account, and then you can create a repository with the YAML files you require. Or you can find the linuxacademy/content-gitops repository and fork it. Once you create your own version of that repository, examine the YAML files in the namespaces and workloads folders.

  2. Challenge

    Deploy Flux Into Your Cluster

    To check whether fluxctl is installed, enter:

    $ fluxctl version
    

    If fluxctl did not install automatically, you may enter the following command to install it:

    $ sudo wget https://github.com/fluxcd/flux/releases/download/1.25.4/fluxctl_linux_amd64 -O /usr/bin/fluxctl && sudo chmod +x /usr/bin/fluxctl
    

    Create a namespace for Flux:

    $ kubectl create ns flux
    

    Set the GHUSER environment variable:

    $ export GHUSER=[Your GitHub Handle]
    

    Deploy Flux using the fluxctl command:

    $ fluxctl install 
    --git-user=${GHUSER} 
    --git-email=${GHUSER}@users.noreply.github.com 
    [email protected]:${GHUSER}/content-gitops 
    --git-path=namespaces,workloads 
    --namespace=flux | kubectl apply -f -
    
  3. Challenge

    Verify The Deployment and Obtain the RSA Key

    Verify the Flux deployment:

    $ kubectl -n flux rollout status deployment/flux
    

    Obtain the Flux RSA key created by fluxctl:

    $ fluxctl identity --k8s-fwd-ns flux
    

    Copy off the RSA key to implement in GitHub.

  4. Challenge

    Implement the RSA Key in GitHub

    Use the GitHub User Interface to Add the RSA Key obtained as a Deploy Key in GitHub.

  5. Challenge

    Use the fluxctl sync Command to Synchronize the Cluster with the Repository

    Use fluxctl to sync the cluster with the repository:

    $ fluxctl sync --k8s-fwd-ns flux
    

    Then check the existence of the lasample namespace:

    $ kubectl get namespaces
    

    Finally check that the Nginx deployment is running:

    $ kubectl get pods --all-namespaces
    

The Cloud Content team comprises subject matter experts hyper focused on services offered by the leading cloud vendors (AWS, GCP, and Azure), as well as cloud-related technologies such as Linux and DevOps. The team is thrilled to share their knowledge to help you build modern tech solutions from the ground up, secure and optimize your environments, and so much more!

What's a lab?

Hands-on Labs are real environments created by industry experts to help you learn. These environments help you gain knowledge and experience, practice without compromising your system, test without risk, destroy without fear, and let you learn from your mistakes. Hands-on Labs: practice your skills before delivering in the real world.

Provided environment for hands-on practice

We will provide the credentials and environment necessary for you to practice right within your browser.

Guided walkthrough

Follow along with the author’s guided walkthrough and build something new in your provided environment!

Did you know?

On average, you retain 75% more of your learning if you get time for practice.

Start learning by doing today

View Plans