-
Notifications
You must be signed in to change notification settings - Fork 128
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Add support for read-only root filesystem and enable by default #235
Conversation
… other services may write to ephemeral volume
Support for read only root-filesystem for Kiali-Operator
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
This will also require changes to the OLM metadata for those who install the operator via OLM (as opposed to helm). So this means a PR over in the kiali-operator repo. See the checklist here.
The files where you will want to make similar changes will be here:
- https://github.com/kiali/kiali-operator/blob/master/manifests/kiali-upstream/1.78.0/manifests/kiali.v1.78.0.clusterserviceversion.yaml
- https://github.com/kiali/kiali-operator/blob/master/manifests/kiali-community/1.78.0/manifests/kiali.v1.78.0.clusterserviceversion.yaml
- https://github.com/kiali/kiali-operator/blob/master/manifests/kiali-ossm/manifests/kiali.clusterserviceversion.yaml
kiali-operator/values.yaml
Outdated
# localAnsibleTmpPath is the path of the local Ansible temp directory. This sets the ANSIBLE_LOCAL_TEMP variable which | ||
# in turn sets the DEFAULT_LOCAL_TMP configuration. An emptyDir is mounted to /tmp for the kiali-operator container. | ||
# Ansible needs write access on this directory so modifying it might have implications if read-only root filesystem is enabled. | ||
localAnsibleTmpPath: /tmp/ansible/tmp | ||
|
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Do we really need this? Why would someone need to change this?
IMO, this should be fixed/hardcoded. I don't see a need for anyone to change this, and it just invites users to misconfigure something.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I agree. I'll remove it from values.
I'll run tests over here but the changes look good
Created PR in kiali-operator. Let me know if I'm missing anything. Thanks! kiali/kiali-operator#729 |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Testing locally ... operator is failing to install Kiali.
Here is how I tested and what I see:
- First build the helm charts from this PR:
make build-helm-charts
- Use
make
from kiali repo to push and deploy the operator using the new helm chart:
make -e CLUSTER_TYPE=minikube -e HELM_CHARTS_REPO_PULL=false build build-ui cluster-push operator-create
- Confirm securityContext has read-only fs:
$ kubectl get pods -n kiali-operator -l app.kubernetes.io/name=kiali-operator -o jsonpath='{..spec.containers..securityContext}' | jq
{
"allowPrivilegeEscalation": false,
"capabilities": {
"drop": [
"ALL"
]
},
"privileged": false,
"readOnlyRootFilesystem": true,
"runAsNonRoot": true
}
- Check the tmp volume mount exists:
$ kubectl get pods -n kiali-operator -l app.kubernetes.io/name=kiali-operator -o jsonpath='{..spec.containers..volumeMounts}' | jq
[
{
"mountPath": "/tmp",
"name": "tmp"
},
{
"mountPath": "/var/run/secrets/kubernetes.io/serviceaccount",
"name": "kube-api-access-nt5qq",
"readOnly": true
}
]
- Check the env var:
$ kubectl get pods -n kiali-operator -l app.kubernetes.io/name=kiali-operator -o jsonpath='{..spec.containers..env}' | jq
...
{
"name": "ANSIBLE_LOCAL_TEMP",
"value": "/tmp/ansible/tmp"
}
- Now install Kiali to make sure the operator still works (this assumes istio is installed in istio-system):
make -e CLUSTER_TYPE=minikube -e HELM_CHARTS_REPO_PULL=false kiali-create
Kiali fails to install because the operator gets this internal error:
$ kubectl logs -n kiali-operator -l app.kubernetes.io/name=kiali-operator
TASK [default/kiali-deploy : Update CR status progress field with any additional status fields] ***
fatal: [localhost]: UNREACHABLE! => {"changed": false, "msg": "Failed to create temporary directory.In some cases, you may have been able to authenticate and did not have permissions on the target directory. Consider changing the remote tmp path in ansible.cfg to a path rooted in \"/tmp\", for more error information use -vvv. Failed command was: ( umask 77 && mkdir -p \"` echo /opt/ansible/.ansible/tmp `\"&& mkdir \"` echo /opt/ansible/.ansible/tmp/ansible-tmp-1701351578.757277-149-226722000580315 `\" && echo ansible-tmp-1701351578.757277-149-226722000580315=\"` echo /opt/ansible/.ansible/tmp/ansible-tmp-1701351578.757277-149-226722000580315 `\" ), exited with result 1", "unreachable": true}
PLAY RECAP *********************************************************************
localhost : ok=11 changed=0 unreachable=1 failed
@eli-gc please provide testing procedures for this - the commands you use to test (compare to what I posted in my review above). It isn't working for me, so I am curious what I did differently than you. |
@eli-gc I think I fixed it. Add another env var... |
add ANSIBLE_REMOTE_TEMP env var
PR updated with requested changes. Thanks for finding that. |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
lgtm - testing shows this working
resolves kiali/kiali#6888