Skip to content
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

detect if inside Docker container #428

Closed
wants to merge 1 commit into from
Closed

Conversation

paulczar
Copy link
Contributor

No description provided.

@lamont-granquist
Copy link
Contributor

@tduffield review?

@tduffield
Copy link
Contributor

I haven't tried it personally but it makes sense. +1

@sersut
Copy link

sersut commented Oct 14, 2014

Cool. @paulczar can you share the verification that you've done for this? As long as we're comfortable with the existing coverage we can get this in.

@@ -170,9 +174,9 @@ def lxc_version_exists?
# Kernel docs, https://www.kernel.org/doc/Documentation/cgroups
if File.exists?("/proc/self/cgroup")
if File.read("/proc/self/cgroup") =~ %r{^\d+:[^:]+:/(lxc|docker)/.+$}
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

There's a set of users who may be using certain versions of docker and are switching on these values returning LXC who would be broken by this (presuming they exist).

Do we know if previous to Docker 0.9, when Docker used LXC, if it said docker or lxc here? What about Docker 0.9+ with libcontainer? I'd like to see a unit test for each case that makes it clear what happens in those cases.

@atomic-penguin, any thoughts on this ?

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

@btm the check for the files /.dockerenv or /.dockerinit look more reliable than what we did in the past. It looks like /.dockerinit was added around July 2013, and has been around since v0.5.1. It wasn't something that I knew about when I submitted the original pull request to add to Ohai. As far as I can tell examining the code in this PR, this would provide better Docker detection that what we currently have, and I do not see that it breaks backwards compatibility.

Had to look back at my OHAI-551 notes. Prior to 0.9, Docker used the cgroup namespace /lxc/. Post 0.9, it used the cgroup namespace /docker/. The spec test removed in this PR appears to be incorrect, and is certainly my fault. There may have been good reason for it at the time, since we didn't yet have the virtualization.systems hash.

For docker guests, the presence of the /.dockerinit || /.dockerenv should detect most Docker instances excepting early first six month alpha builds (<= v0.5.0) of Docker.

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

The theoretically backward compat concern would be that if you were using docker and it's reporting docker in /etc/self/cgroup, so virtualization[:system] is getting set to lxc, and you've got recipes that are switching on that. Once we ship this, virtualization[:system] is going to report docker instead and that code won't run.

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

@tduffield @atomic-penguin @paulczar so, I think this only would affect a couple people, if any, but it's a breaking change and therefore semver says we should wait to ship it. Could you give this a second thought and potentially disagree?

The alternative maybe is to leave this part of the code alone for now (adding in the dockerinit feature), then separately changing this code to work this way. I'm not sure how useful that is to anyone, but perhaps if the dockerinit stuff is more reliable than cgroups, i.e. maybe sometimes the cgroup file doesn't exist, we at least get better coverage.

@btm
Copy link
Contributor

btm commented Oct 15, 2014

I'm a little concerned there may be a breaking change in changing the existing lxc detection code, otherwise looks good.

@tjsoftworks
Copy link

Just another opinion. This is minor version and is intending to work "provide better Docker detection that what we currently have". The lxc concern - is there a test that can be done to see if there is an issue?

@btm
Copy link
Contributor

btm commented Oct 27, 2014

@tjsoftworks regarding testing, the code is pretty clear that the ohai used to report "lxc" when it saw docker there, and now it will report docker. I don't know how many people that would affect, and I agree that the behavior in this patch is more correct, but that change technically needs to wait.

In the interim we could take the dockerinit patch as that happens later and wouldn't change that behavior, but if /proc/self/cgroup still contains docker on those systems, you're going to keep getting lxc from ohai until the next major release of ohai.

@btm
Copy link
Contributor

btm commented Oct 27, 2014

@paulczar if you would split the added dockerinit feature into a separate pull request, I think we'd take that now.

@btm
Copy link
Contributor

btm commented Oct 27, 2014

This could go into master, as we now have a 7-stable branch of ohai. Then if someone wanted the dockerinit stuff to go into a 7.x.y release, they could provide a separate pull request for just that code. @tyler-ball and I have reasoned about this and think this is probably good to go into master now that we have a new 7-stable branch. @sersut, agree?

@sersut
Copy link

sersut commented Oct 27, 2014

Currently master is the branch for 7.8.0 and 7-stable is the branch for 7.6.0. I'm 👍 on merge to master.

@paulczar
Copy link
Contributor Author

Some confusion here from all the comments, do I need to change anything? or is it okay as is?

@tyler-ball
Copy link
Contributor

@sersut Because this is a breaking change, can we bump master to 8.0.0 when we merge this to master?

@paulczar If we merge this to a new greater version (like 8.0.0) the whole change can go in. If we want to merge this to a 7.x.x branch, we would have to make changes to maintain backwards compatibility.

@btm
Copy link
Contributor

btm commented Oct 28, 2014

@paulczar it would be convenient to have this branch as two separate commits. One would add the .dockerinit feature, and the second change the existing cgroup behavior.

@paulczar
Copy link
Contributor Author

paulczar commented Nov 4, 2014

rereading the code, I don't think it makes sense to break it out into two commits. the .dockerinit feature is unlikely to ever be used because it should be matched by the cgroup checks, it's just there to extend coverage for when/if docker supports something weird like solaris zones.

@btm
Copy link
Contributor

btm commented Nov 12, 2014

After a bunch of discussion in office hours and in chef's hipchat, we should just ship this. The matrix of possible semver compliance options is just absurd and this isn't going to break a lot of people. The number of people it may break is less horrible than the semver options IMHO.

@btm btm closed this in 3376e7f Feb 17, 2015
@chef chef locked and limited conversation to collaborators Nov 16, 2017
Sign up for free to subscribe to this conversation on GitHub. Already have an account? Sign in.
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

10 participants