I’m trying to use a netapp collection - I have enabled collection and role download within AWX, but the error I’m getting is the python NetApp-Lib module is required
I’ve tried putting a requirements.yaml and collection/requirements.yaml in my SCM with the test playbook, but it doesn’t seem to grab everything necessary.
Netapp documentation says I need to modify the build image for awx, but that’s a step I’d rather not take if I don’t have to… are there other options?
I received a direct reply (Thank you Stefan!) which pointed me in the direction of using Ansible-Builder… I’ve got that working and creating a context… I’m now at the point of wanting to try running that in AWX but am uncertain how to proceed with that next step…
Any suggestions/thoughts would be greatly appreciated.
I think the ansible-builder approach of creating a custom execution environment with the collection and using that for the job execution won’t work until you upgrade to an AWX version 18+ … which is not released yet
What does the output of your project update look like?
One problem I’ve faced is that if you don’t have an ansible galaxy credential associated with the organization that the project belongs to (I know, this is obtuse), the collections download skips.
I’m of the opinion that this is opaque and is a UX bug, but has not been prioritized yet to get fixed (I’m not sure if there is an issue for this yet on awx).
Let me know if trying this changes the outcome, and if not, what the output of the project update is.
The problem I have is when I try to run a playbook with a reference to the netapp.ontap collection, it errors out that the netapp-lib python module isn’t available. The netapp documentation I was pointed at originally when I was looking at this suggested customizing the awx build to include the module at the base level… but that’s not something I’m wanting to do as I don’t want to have to re-build that part of the project everytime I want to update awx (or if I have ot update the python library).
Is there another solution while I’m waiting for 18+ ?
If the project where you playbook (e.g the project you use for the Job Template) has a file called:
$PROJECT_ROOT/collections/requirements.yml
And the organization that the project belongs to has a Ansible Galaxy credential associated with it,
the collection will be downloaded at project update time, and your playbook should work.
This does not require changing the base image of AWX.
Ahh… okay that makes more sense as to why I’m having such troubles!
In looking at preparing the virtualenvs, I am not sure the best way to proceed… I can connect to my awx instance through Openshift, but the awx local user is not configured with a known password, and from what i can tell, there needs to be an $AWX_ADMIN_USER and $AWX_ADMIN_PASSWORD variables set somewhere ( according to the config map)…
I also see the K8s custom virtualenvs… is that a better option? Add the virtual environment through the initial deployment, and then assign it to the organization, project, and job template?
Also - I also don’t fully understand the idea of how to implement the PATCH as indicated at the bottom of the document.
I am not an expert on custom venvs in awx deployed on k8s, but I think that is the section of the docs you want to use.
The PATCH request are describing how to associate the custom venv with organizations, projects, job templates, etc through the API. You can do this through the browsable API. I’m not sure if it is implemented in the new UI, since it is going away in the upcoming release.
Okay - the patch request makes sense after browsing the api on my awx install…thank you for the pointers there!
Do I have to put the venv under a specific folder? (I know I can change the folder through the custom_venv_dir in my inventory file, but is that actually supported?
I managed to make it through! I had to modify the roles/kubernetes/templates/deployment.yml.j2 and add:
@ line 153 (before the pip install, but after teh /bin/activate &&
Sorry - my initial ask was using an older version of AWX (17.1.0) - for newer versions, the recommended approach nowadays is to use ansible-builder (stolen answer from a different post) - I’m sorry I don’t have more information than that, as i’m still using 17.1.0 in my environment.