Last active
          June 23, 2025 11:39 
        
      - 
            
      
        
      
    Star
      
          
          (535)
      
  
You must be signed in to star a gist 
- 
              
      
        
      
    Fork
      
          
          (77)
      
  
You must be signed in to fork a gist 
- 
      
- 
        Save BretFisher/5e1a0c7bcca4c735e716abf62afad389 to your computer and use it in GitHub Desktop. 
Revisions
- 
        BretFisher revised this gist Jan 19, 2021 . 1 changed file with 1 addition and 1 deletion.There are no files selected for viewingThis file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters. Learn more about bidirectional Unicode charactersOriginal file line number Diff line number Diff line change @@ -1,6 +1,6 @@ ## 2021 Update: Easiest option is Justin's repo and image Just run this from your Mac terminal and it'll drop you in a container with full permissions on the Docker VM. **This also works for Docker for Windows for getting in Moby Linux VM** (doesn't work for Windows Containers). `docker run -it --rm --privileged --pid=host justincormack/nsenter1` 
- 
        BretFisher revised this gist Jan 18, 2021 . No changes.There are no files selected for viewing
- 
        BretFisher revised this gist Jan 18, 2021 . 1 changed file with 1 addition and 1 deletion.There are no files selected for viewingThis file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters. Learn more about bidirectional Unicode charactersOriginal file line number Diff line number Diff line change @@ -24,6 +24,6 @@ Phil Estes (Docker Maintainer) says: `nsenter` installed), with pid=host (so you are in the process space of the mini VM running Docker4Mac), and then nsenter says “whatever is pid 1, use that as context, and enter all the namespaces of that, and run a shell there" ## Option 3 (easist): run nsenter from a pre-built image. From Justin Cormack (Docker Maintainer) `docker run -it --rm --privileged --pid=host justincormack/nsenter1` 
- 
        BretFisher revised this gist Jan 18, 2021 . 1 changed file with 6 additions and 31 deletions.There are no files selected for viewingThis file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters. Learn more about bidirectional Unicode charactersOriginal file line number Diff line number Diff line change @@ -1,4 +1,4 @@ ## 2021 Update: Easiest option is Justin's repo and image Just run this from your Mac terminal and it'll drop you in a container with full permissions on the Moby VM. **This also works for Docker for Windows for getting in Moby Linux VM** (doesn't work for Windows Containers). @@ -8,47 +8,22 @@ more info: https://github.com/justincormack/nsenter1 --- ## Option 1 (hard way): use netcat `nc -U ~/Library/Containers/com.docker.docker/Data/debug-shell.sock` Exit the shell with `exit`. ## Option 2 (easier): Use nsenter in priviledged container `docker run -it --privileged --pid=host debian nsenter -t 1 -m -u -n -i sh` Phil Estes (Docker Maintainer) says: > it’s running a container (using the debian image. nothing special about it other than it apparently has `nsenter` installed), with pid=host (so you are in the process space of the mini VM running Docker4Mac), and then nsenter says “whatever is pid 1, use that as context, and enter all the namespaces of that, and run a shell there" ### Option 3 (easist): run nsenter from a pre-built image. From Justin Cormack (Docker Maintainer) `docker run -it --rm --privileged --pid=host justincormack/nsenter1` 
- 
        BretFisher revised this gist Jun 24, 2019 . 1 changed file with 1 addition and 1 deletion.There are no files selected for viewingThis file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters. Learn more about bidirectional Unicode charactersOriginal file line number Diff line number Diff line change @@ -16,7 +16,7 @@ the job done. Using the ctrl- options prevents garbled text on reconnect. connect to tty on Docker for Mac VM `screen ~/Library/Containers/com.docker.docker/Data/vms/0/tty` disconnect that session but leave it open in background 
- 
        BretFisher revised this gist Mar 11, 2018 . No changes.There are no files selected for viewing
- 
        BretFisher revised this gist Mar 11, 2018 . No changes.There are no files selected for viewing
- 
        BretFisher revised this gist Mar 11, 2018 . 1 changed file with 1 addition and 1 deletion.There are no files selected for viewingThis file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters. Learn more about bidirectional Unicode charactersOriginal file line number Diff line number Diff line change @@ -1,6 +1,6 @@ ## 2018 Update: Easiest option is Justin's repo and image Just run this from your Mac terminal and it'll drop you in a container with full permissions on the Moby VM. **This also works for Docker for Windows for getting in Moby Linux VM** (doesn't work for Windows Containers). `docker run -it --rm --privileged --pid=host justincormack/nsenter1` 
- 
        BretFisher revised this gist Mar 11, 2018 . 1 changed file with 2 additions and 0 deletions.There are no files selected for viewingThis file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters. Learn more about bidirectional Unicode charactersOriginal file line number Diff line number Diff line change @@ -1,5 +1,7 @@ ## 2018 Update: Easiest option is Justin's repo and image Just run this from your Mac terminal and it'll drop you in a container with full permissions on the Moby VM. `docker run -it --rm --privileged --pid=host justincormack/nsenter1` more info: https://github.com/justincormack/nsenter1 
- 
        BretFisher revised this gist Mar 11, 2018 . 1 changed file with 3 additions and 1 deletion.There are no files selected for viewingThis file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters. Learn more about bidirectional Unicode charactersOriginal file line number Diff line number Diff line change @@ -42,9 +42,11 @@ Phil Estes (Docker Maintainer) says: `nsenter` installed), with pid=host (so you are in the process space of the mini VM running Docker4Mac), and then nsenter says “whatever is pid 1, use that as context, and enter all the namespaces of that, and run a shell there" ### Or even easier, from Justin Cormack (Docker Maintainer) `docker run -it --rm --privileged --pid=host justincormack/nsenter1` Justin Says: > Personally I mostly use screen, but then I also use the above too. That's my minimal nsenter image. 
- 
        BretFisher revised this gist Mar 11, 2018 . 1 changed file with 12 additions and 1 deletion.There are no files selected for viewingThis file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters. Learn more about bidirectional Unicode charactersOriginal file line number Diff line number Diff line change @@ -1,39 +1,50 @@ ## 2018 Update: Easiest option is Justin's repo and image `docker run -it --rm --privileged --pid=host justincormack/nsenter1` more info: https://github.com/justincormack/nsenter1 --- ## Option 1: use Screen (not as easy as nsenter) Note this isn't a list of commands to run in order. The first one gets you in the VM (hit return twice to see a prompt). Then other commands are for managing that connection. Not a great CLI expirence but gets the job done. Using the ctrl- options prevents garbled text on reconnect. connect to tty on Docker for Mac VM `screen ~/Library/Containers/com.docker.docker/Data/com.docker.driver.amd64-linux/tty` disconnect that session but leave it open in background `Ctrl-a d` list that session that's still running in background `screen -ls` reconnect to that session (don't open a new one, that won't work and 2nd tty will give you garbled screen) `screen -r` kill this session (window) and exit `Ctrl-a k` ## Option 2 (easier): Use nsenter in priviledged container `docker run -it --privileged --pid=host debian nsenter -t 1 -m -u -n -i sh` Phil Estes (Docker Maintainer) says: > it’s running a container (using the debian image..nothing special about it other than it apparently has `nsenter` installed), with pid=host (so you are in the process space of the mini VM running Docker4Mac), and then nsenter says “whatever is pid 1, use that as context, and enter all the namespaces of that, and run a shell there" ## Or from Justin Cormack (Docker Maintainer) `docker run -it --rm --privileged --pid=host justincormack/nsenter1` > Personally I mostly use screen, but then I also use the above too. That's my minimal nsenter image. 
- 
        BretFisher revised this gist Mar 11, 2018 . 1 changed file with 9 additions and 9 deletions.There are no files selected for viewingThis file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters. Learn more about bidirectional Unicode charactersOriginal file line number Diff line number Diff line change @@ -1,39 +1,39 @@ ## 2018 Update: Easiest option is Justin's repo and image `docker run -it --rm --privileged --pid=host justincormack/nsenter1` more info: https://github.com/justincormack/nsenter1 --- ## Option 1: use Screen (not as easy as nsenter) Note this isn't a list of commands to run in order. The first one gets you in the VM (hit return twice to see a prompt). Then other commands are for managing that connection. Not a great CLI expirence but gets the job done. Using the ctrl- options prevents garbled text on reconnect. connect to tty on Docker for Mac VM `screen ~/Library/Containers/com.docker.docker/Data/com.docker.driver.amd64-linux/tty` disconnect that session but leave it open in background `Ctrl-a d` list that session that's still running in background `screen -ls` reconnect to that session (don't open a new one, that won't work and 2nd tty will give you garbled screen) `screen -r` kill this session (window) and exit `Ctrl-a k` ## Option 2 (easier): Use nsenter in priviledged container `docker run -it --privileged --pid=host debian nsenter -t 1 -m -u -n -i sh` Phil Estes (Docker Maintainer) says this does: > it’s running a container (using the debian image..nothing special about it other than it apparently has `nsenter` installed), with pid=host (so you are in the process space of the mini VM running Docker4Mac), and then nsenter says “whatever is pid 1, use that as context, and enter all the namespaces of that, and run a shell there" ## Or from Justin Cormack (Docker Maintainer) `docker run -it --rm --privileged --pid=host justincormack/nsenter1` > Personally I mostly use screen, but then I also use the above too. That's my minimal nsenter image. 
- 
        BretFisher revised this gist Mar 11, 2018 . 1 changed file with 25 additions and 30 deletions.There are no files selected for viewingThis file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters. Learn more about bidirectional Unicode charactersOriginal file line number Diff line number Diff line change @@ -1,44 +1,39 @@ ## 2018 Update: Easiest option is Justin's repo and image ==================== `docker run -it --rm --privileged --pid=host justincormack/nsenter1` more info: https://github.com/justincormack/nsenter1 --- ## Option 1: use Screen (not easy like nsenter) Note this isn't a list of commands to run in order. The first one gets you in the VM (hit return twice to see a prompt). Then other commands are for managing that connection. Not a great CLI expirence but gets the job done. Using the ctrl- options prevents garbled text on reconnect. ### connect to tty on Docker for Mac VM `screen ~/Library/Containers/com.docker.docker/Data/com.docker.driver.amd64-linux/tty` ### disconnect that session but leave it open in background `Ctrl-a d` ### list that session that's still running in background `screen -ls` ### reconnect to that session (don't open a new one, that won't work and 2nd tty will give you garbled screen) `screen -r` ### kill this session (window) and exit `Ctrl-a k` ## Option 2 (easier): Use nsenter in priviledged container other option to connect w/o screen `docker run -it --privileged --pid=host debian nsenter -t 1 -m -u -n -i sh` Phil Estes (Docker Maintainer) says this does: > it’s running a container (using the debian image..nothing special about it other than it apparently has `nsenter` installed), with pid=host (so you are in the process space of the mini VM running Docker4Mac), and then nsenter says “whatever is pid 1, use that as context, and enter all the namespaces of that, and run a shell there" ## Or from Justin Cormack (Docker Maintainer) > Personally I mostly use screen, but then I also use the below too. That's my minimal nsenter image `docker run -it --rm --privileged --pid=host justincormack/nsenter1` 
- 
        BretFisher renamed this gist Mar 11, 2018 . 1 changed file with 1 addition and 1 deletion.There are no files selected for viewingThis file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters. Learn more about bidirectional Unicode charactersOriginal file line number Diff line number Diff line change @@ -9,7 +9,7 @@ docker run -it --rm --privileged --pid=host justincormack/nsenter1 # # Note this isn't a list of commands to run in order. The first one gets you in the VM (hit return twice # to see a prompt). Then other commands are for managing that connection. Not a great CLI expirence but gets # the job done. Using the ctrl- options prevents garbled text on reconnect. # connect to tty on Docker for Mac VM screen ~/Library/Containers/com.docker.docker/Data/com.docker.driver.amd64-linux/tty 
- 
        BretFisher revised this gist Mar 11, 2018 . 1 changed file with 24 additions and 6 deletions.There are no files selected for viewingThis file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters. Learn more about bidirectional Unicode charactersOriginal file line number Diff line number Diff line change @@ -1,3 +1,16 @@ ## 2018 Update: Easiest option is Justin's repo and image ==================== docker run -it --rm --privileged --pid=host justincormack/nsenter1 # more info: https://github.com/justincormack/nsenter1 # ## Option 1: use Screen (not easy like nsenter) # # Note this isn't a list of commands to run in order. The first one gets you in the VM (hit return twice # to see a prompt). Then other commands are for managing that connection. Not a great CLI expirence but gets # the job done. # connect to tty on Docker for Mac VM screen ~/Library/Containers/com.docker.docker/Data/com.docker.driver.amd64-linux/tty @@ -13,14 +26,19 @@ screen -r # kill this session (window) and exit Ctrl-a k ## Option 2 (easier): Use nsenter in priviledged container # other option to connect w/o screen docker run -it --privileged --pid=host debian nsenter -t 1 -m -u -n -i sh # Phil Estes (Docker Maintainer) says this does: # it’s running a container (using the debian image..nothing special about it other than it apparently has # `nsenter` installed), with pid=host (so you are in the process space of the mini VM running Docker4Mac), # and then nsenter says “whatever is pid 1, use that as context, and enter all the namespaces of that, and run a shell there" # --or-- # from Justin Cormack (Docker Maintainer) # Personally I mostly use screen, but then I also use docker run -it --rm --privileged --pid=host justincormack/nsenter1 # too. That's my minimal nsenter image 
- 
        BretFisher revised this gist Feb 23, 2017 . 1 changed file with 5 additions and 0 deletions.There are no files selected for viewingThis file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters. Learn more about bidirectional Unicode charactersOriginal file line number Diff line number Diff line change @@ -19,3 +19,8 @@ docker run -it --privileged --pid=host debian nsenter -t 1 -m -u -n -i sh # it’s running a container (using the debian image..nothing special about it other than it apparently has `nsenter` installed) # , with pid=host (so you are in the process space of the mini VM running Docker4Mac), and then nsenter says “whatever is pid 1, # use that as context, and enter all the namespaces of that, and run a shell there" # from Justin Cormack # Personally I mostly use screen, but then I also use docker run --privileged --pid=host justincormack/nsenter1 # too. That's my minimal nsenter image 
- 
        BretFisher renamed this gist Feb 22, 2017 . 1 changed file with 0 additions and 0 deletions.There are no files selected for viewingFile renamed without changes.
- 
        BretFisher created this gist Feb 22, 2017 .There are no files selected for viewingThis file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters. Learn more about bidirectional Unicode charactersOriginal file line number Diff line number Diff line change @@ -0,0 +1,21 @@ # connect to tty on Docker for Mac VM screen ~/Library/Containers/com.docker.docker/Data/com.docker.driver.amd64-linux/tty # disconnect that session but leave it open in background Ctrl-a d # list that session that's still running in background screen -ls # reconnect to that session (don't open a new one, that won't work and 2nd tty will give you garbled screen) screen -r # kill this session (window) and exit Ctrl-a k # other option to connect w/o screen docker run -it --privileged --pid=host debian nsenter -t 1 -m -u -n -i sh # Phil Estes says this does: # it’s running a container (using the debian image..nothing special about it other than it apparently has `nsenter` installed) # , with pid=host (so you are in the process space of the mini VM running Docker4Mac), and then nsenter says “whatever is pid 1, # use that as context, and enter all the namespaces of that, and run a shell there"