Hi Everyone.
AWX is a powerful tool to help one wander the wonderful world of ansible. Obviously we are all keen to give the AWX operator a go in Kubernetes. Just like the song New York, New York (if I can make it there I cam make it anywhere) which translates into Kubernetarian + If I can install it on my laptop, I can install it anywhere!! We will attempt to do so on my old “chuck it in the bin already” Window$ laptop
You need to install my true love of late “Rancher Desktop”
Enable kubernetes and for convenience although optional turn on the wsl integration with your wsl distro:
data:image/s3,"s3://crabby-images/5136d/5136dda476bb76275bba2789af9b48ebfadbb2c5" alt=""
I am using kubernetes v1.25.6 and remember in Rancher Desktop lurking under the hood is k3s.
data:image/s3,"s3://crabby-images/94395/9439530a7a1713fff58b7161d60e9dd3c775a2c1" alt=""
Ok so we are ready to rumble!
open your Ubuntu terminal window and make sure your single node cluster is smilling:
kubectl get nodes
data:image/s3,"s3://crabby-images/d55da/d55daddea871f56be0f71d5129f7cfeb89b0c928" alt=""
The awx-operator has all the instructions and I am basically following them with some tweaks for my local setup.
https://github.com/ansible/awx-operator
Let’s clone the repo
git clone https://github.com/ansible/awx-operator.git
We will change into that directory:
cd awx-operator
According to the instructions we need to install kustomize so let’s also update our distribution:
sudo apt update
sudo apt upgrade -y
curl -s "https://raw.githubusercontent.com/kubernetes-sigs/kustomize/master/hack/install_kustomize.sh" | bash
We will create a kustomization.yaml file and I have filled in the latest version for the tag:
apiVersion: kustomize.config.k8s.io/v1beta1
kind: Kustomization
resources:
- github.com/ansible/awx-operator/config/default?ref=1.1.4
images:
- name: quay.io/ansible/awx-operator
newTag: 1.1.4
namespace: awx
Now we will run kustomize to install the operator:
./kustomize build . | kubectl apply -f -
We should see the pod appear:
kubectl get pods -n awx
data:image/s3,"s3://crabby-images/bd219/bd21903faf934c1c936d954312484c96e62c0f80" alt=""
You can switch contexts if you don’t want to constantly add the namespace in your command:
kubectl config set-context --current --namespace=awx
Now we will create an awx-demo.yml. You can change the one that they have provided in the repo folder:
---
apiVersion: awx.ansible.com/v1beta1
kind: AWX
metadata:
name: awx-demo
spec:
service_type: clusterip
ingress_type: ingress
As you may have noticed we are going to set the service type a clusterip and use ingress.
Remember k3s by default with traefik turned on so your ingress should work out of the box.
Now lets apply that file:
kubectl apply -f awx.demo.yml
You have to be patient but eventually you should see database pod and an awx pod
data:image/s3,"s3://crabby-images/0d2e1/0d2e10567162baf6a4047e0391fc1b91f2bd3c62" alt=""
Also the database is leveraging a pvc (k3s default local-path):
data:image/s3,"s3://crabby-images/7e5e2/7e5e21b6bcc2fb7b3303f7826f67eb4a16259966" alt=""
Remember if you want to get fancy and back this up you would need to use a Kasten generic backup since is not a csi driver and there is no snapshotting. We could of course make this post longer and install the csi-hostpath driver with snapshotting but I fear you could fall asleep :)
We can also see an ingress has also appeared:
data:image/s3,"s3://crabby-images/8a168/8a16800e5ff9edcdb36c4a3262d0953b5e65b598" alt=""
Again be patient but after a little wait you should be able to navigate in your browser to:
data:image/s3,"s3://crabby-images/0a719/0a7199360f961ab18aff0e21f9c2d666a6122bd2" alt=""
Behold!
data:image/s3,"s3://crabby-images/f2d56/f2d569f0946814c486a83eec32a3801e3cafc094" alt=""
Great but now what do I do?
At this point try guessing the password. There probably a billion variations so this will keep you busy for a while.
Just joking!
You could have set the password in one of the config files but we want to have fun so:
kubectl get secrets -oyaml awx-demo-admin-password
data:image/s3,"s3://crabby-images/53b2a/53b2ab12594fe8b7125e3b62db32cb99918cdfce" alt=""
The password is in there for the admin user but it is in base64 format so:
echo bjF2MXg0aldQTG1DSnhyT3owOGFsT0J5VG53TUNXNDQ= |base64 -d
data:image/s3,"s3://crabby-images/29e53/29e53b9fa574ce93e1141b8bf4f61c918fc8f760" alt=""
Copy the result from your output and use that as a password for the admin user:
data:image/s3,"s3://crabby-images/214a9/214a9a44a73a485c5771b4c12c2096303a8d2b14" alt=""
Boom!
data:image/s3,"s3://crabby-images/20cee/20ceefcefd663afe584f0729094ba302ee74831e" alt=""
Now you can setup ansible jobs to run on anything you want. Next time maybe I will turn on winrm on my laptop and have my AWX Tower setup in k3s sent it jobs to do, or I can tell my Linux servers hiding around the house to perform updates and patches.
Never a dull moment in the Burke home!