-
-
Notifications
You must be signed in to change notification settings - Fork 109
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
docs(docker): mount /sys/class/powercap
and /proc
read-only
#57
base: main
Are you sure you want to change the base?
Conversation
Hi, Thanks a lot for the PR and the suggestion. I tried it and ran into an issue with apparmor:
It seems like apparmor, in the container, needs to write on /proc, so this is a blocker. However, you raise an important topic. We need to find a way to make the configuration of the container less "invasive". I wonder if there is a "clean" way to mount only the parts of /proc that we need for tracking the other processes on the host. We could then maybe mount them RO. Any thoughts ? |
Hi, nice catch, I've not tested on an host with apparmor. I usually run my containers read-only. Another way to be less invasive, running the image as non-root like node_exporter: https://github.com/prometheus/node_exporter/blob/master/Dockerfile#L11 |
You're right. We have to optimize on that part too. I may give it a try next week. Regarding the RO volumes, we need to find a solution to do that without crashing apparmor or any other service that needs access to some /proc subset at a given time to crash. Maybe mounting the /proc/self files as RW and the rest as RO could work here ? |
Another possibility is to mount /proc:/host/proc:ro and /sys:/host/sys:ro with a prefix like netdata. To be able to do this scaphrandre probably need a small modification to accept an option flag to set a prefix for /proc and /sys (null by default) https://learn.netdata.cloud/docs/agent/packaging/docker edit: metricbeat seem to do the same https://www.elastic.co/guide/en/beats/metricbeat/current/running-on-docker.html |
Good idea. It shouldn't be a problem to implement that. I'll try to start working on it next week then, if nobody jumps on it first. |
to ask scaph to look in PREFIX/proc and PREFIX/sys/class/powercap instead of the default paths. This enables to run scaph in docker with only RO mountpoins. (see discussion #57 for more details)
trying a PR for that topic: #64 |
I'm building a new image to try the use case you thought about. |
Nice job 👍 |
It will be a bit more complex than anticipated, because we use the procfs crate to get metrics from /proc and will need to find a way to tell it to consider the prefix too... I'll update here about the progress. |
An appropriate feature has been implemented in procfs. I should be able to fix this for release 0.5 Stay tuned ! |
Hi! Really cool tool!
Here is a small suggestion: it's probably "better" to mount
/sys/class/powercap
and/proc
in containterro