User Tools

Site Tools


docu:csheet:sysadm:venv:docker:netns_exec

This is an old revision of the document!


Execute a command on the docker container network namespace


Tired of having to install ping/curl/telnet/netcat to test connectivity on docker containers to other hosts? This is probably the most useful thing i've learn on container technologies

container_name=your-example-container
 
# Get the PID of docker container main command
docker inspect -f '{{.State.Pid}}' $container_name
 
# Execute whatever command you want (you must have it installed on host)
#  example:
nsenter -t PID -n host techdoku.nogafam.es
nsenter -t PID -n telnet 2.3.4.5 80
nsenter -t PID -n iptables -A OUTPUT -d 1.2.3.4 -p udp --dport 53 -j ACCEPT 
# or whatever network-related command you want to exec

Keep in mind this won't execute commands on the container, so things like for example querying /etc/resolv.conf file WON'T WORK

cat /etc/resolv.conf

Technically, network namespaces are a technology on *nix operating systems that allows to create separated or/and isolated network stacks on the hosts


More information on: https://en.wikipedia.org/wiki/Linux_namespaces#Network_(net)

docu/csheet/sysadm/venv/docker/netns_exec.1602602596.txt.gz · Last modified: 2020/10/13 15:23 by admin