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

Flag --dns does not set /etc/resolv.conf when using another containers network #3553

Closed
space88man opened this issue Jul 11, 2019 · 9 comments · Fixed by #3579
Closed

Flag --dns does not set /etc/resolv.conf when using another containers network #3553

space88man opened this issue Jul 11, 2019 · 9 comments · Fixed by #3579
Assignees
Labels
kind/bug Categorizes issue or PR as related to a bug. locked - please file new issue/PR Assist humans wanting to comment on an old issue or PR with locked comments.

Comments

@space88man
Copy link

Is this a BUG REPORT or FEATURE REQUEST? (leave only one on its own line)

/kind bug

Description

I am creating a container with --dns <MYDNS1> -- dns <MYDNS2> --network container:another.

/etc/resolv.conf is written with 1.1.1.1 and 1.0.0.1, instead of the expected <MYDNS1>, <MYDNS2>

Steps to reproduce the issue:

podman run -d --rm --name sharp_sutherland pause
podman run --rm -a stdin,stdout,stderr -it --entrypoint /bin/bash --dns 192.168.15.1 --name jovial_brown  --network container:sharp_sutherland centos:7
podman exec jovial_brown cat /etc/resolv.conf
nameserver 192.168.20.1
# ^^^^ this is the nameserver used by the host
# not intended for the container

Describe the results you received:
The dependent container uses the nameserver of the host.

Describe the results you expected:
The dependent container uses the nameserver specified with --dns X.X.X.X

Additional information you deem important (e.g. issue happens only occasionally):

Output of podman version:

Version:            1.4.5-dev
RemoteAPI Version:  1
Go Version:         go1.12.6
OS/Arch:            linux/amd64

Output of podman info --debug:

debug:         
  compiler: gc                  
  git commit: ""                                                                                
  go version: go1.12.6
  podman version: 1.4.5-dev
host:         
  BuildahVersion: 1.9.0
  Conmon: 
    package: podman-1.4.4-1.fc30.x86_64
    path: /usr/libexec/podman/conmon
    version: 'conmon version 0.2.0, commit: 41010e63c287618b1dc34ee11d10d268e2feeefe'
  Distribution:  
    distribution: fedora                                                                        
    version: "30"
  MemFree: 39088803840
  MemTotal: 67458465792
  OCIRuntime:
    package: runc-1.0.0-93.dev.gitb9b6cc6.fc30.x86_64
    path: /usr/bin/runc       
    version: |-
      runc version 1.0.0-rc8+dev
      commit: e3b4c1108f7d1bf0d09ab612ea09927d9b59b4e3
      spec: 1.0.1-dev
  SwapFree: 0                             
  SwapTotal: 0   
  arch: amd64 
  cpus: 16                
  hostname: podman.localhost
  kernel: 5.1.16-300.fc30.x86_64      
  os: linux                             
  rootless: false
  uptime: 23h 46m 46.69s (Approximately 0.96 days)
registries:                     
  blocked: null            
  insecure: null          
  search:    
  - docker.io 
  - registry.fedoraproject.org        
  - quay.io                                                                                     
  - registry.access.redhat.com
  - registry.centos.org  
store:               
  ConfigFile: /etc/containers/storage.conf
  ContainerStore:
    number: 22
  GraphDriverName: overlay
  GraphOptions:             
  - overlay.mountopt=nodev,metacopy=on
  GraphRoot: /var/lib/containers/storage
  GraphStatus:   
    Backing Filesystem: btrfs                                                                   
    Native Overlay Diff: "false"
    Supports d_type: "true"
    Using metacopy: "true"
  ImageStore:
    number: 26
  RunRoot: /var/run/containers/storage
  VolumePath: /var/lib/containers/storage/volumes   

Additional environment details (AWS, VirtualBox, physical, etc.):

@openshift-ci-robot openshift-ci-robot added the kind/bug Categorizes issue or PR as related to a bug. label Jul 11, 2019
@mheon
Copy link
Member

mheon commented Jul 11, 2019

I'm assuming you're running rootless?

@mheon
Copy link
Member

mheon commented Jul 11, 2019

Ahhh - I think I know what we might be seeing here.

--network container: forces the use of the other container's resolv.conf, and AFAIK overrides --dns (this should probably generate a warning or error, though - it's not really clear if that's actually what happened, hence this bug).

I'd make some changes to resolv.conf in one container and see if they're reflected in the other container. That would be a surefire way to tell.

@space88man
Copy link
Author

space88man commented Jul 11, 2019

The following scenarios are as root:

Original test: leading pause container has no usable network/DNS; command line --dns is ignored for dependent container and 1.1.1.1 and 1.0.0.1 are injected.

If I create the pause container with a working /etc/resolv.conf; the command line --dns is ignored and the DNS from the leading container is injected.

Is this the intended behaviour?

@mheon
Copy link
Member

mheon commented Jul 11, 2019

This sounds intended, though the way we're handling --dns for the second container is definitely not correct. We either need to refuse to create the container on the grounds that --dns and --net=container: are incompatible, or we need to respect the DNS flag for --net=container:.

@space88man
Copy link
Author

If the behaviour for --dns for network-dependent containers is not yet cast in stone, I vote for the latter 😄!

@rhatdan
Copy link
Member

rhatdan commented Jul 11, 2019

What does Docker do?

@rhatdan
Copy link
Member

rhatdan commented Jul 11, 2019

What do we do with Pods?

@space88man
Copy link
Author

Docker follows @mheon first option:

# docker run -a stdin -a stdout -a stderr --tty -i  --name test_2  --network container:test_1 --dns 192.168.12.4 centos:7 /bin/bash
/usr/bin/docker-current: Error response from daemon: Conflicting options: dns and the network mode.
See '/usr/bin/docker-current run --help'

@rhatdan
Copy link
Member

rhatdan commented Jul 11, 2019

@QiWang19 Could you make all of the --dns commands conflict with --net = container:* calls.

QiWang19 added a commit to QiWang19/podman that referenced this issue Jul 18, 2019
Close containers#3553
This PR makes --dns, --dns-option, --dns-search, and --network not set to host flag mutually exclusive for podman build and create. Returns conflict error if both flags are set.

Signed-off-by: Qi Wang <[email protected]>
@github-actions github-actions bot added the locked - please file new issue/PR Assist humans wanting to comment on an old issue or PR with locked comments. label Sep 24, 2023
@github-actions github-actions bot locked as resolved and limited conversation to collaborators Sep 24, 2023
Sign up for free to subscribe to this conversation on GitHub. Already have an account? Sign in.
Labels
kind/bug Categorizes issue or PR as related to a bug. locked - please file new issue/PR Assist humans wanting to comment on an old issue or PR with locked comments.
Projects
None yet
Development

Successfully merging a pull request may close this issue.

5 participants