node.js – 在Docker容器中安装Web应用程序:拨打unix /var/run/docker.sock:没有这样的文件或目录

我正在尝试在Docker容器中安装Web应用程序.

我正在使用OS X Yosemite版本10.10.1

我一直在这里关注Dockerizing Node.js Web App的教程:https://docs.docker.com/examples/nodejs_web_app/

>我下载并设置了boot2docker osx-installer:github.com/boot2docker/osx-installer/releases/tag/v1.4.1
>我按以下顺序在控制台中输入了这些命令:

$boot2docker init
$boot2docker启动
$(boot2docker shellinit)
>然后我按照终端的指示,使用以下命令设置环境变量:

$export DOCKER_TLS_VERIFY = 1
$export DOCKER_HOST = tcp://192.168.59.103:2376
$export DOCKER_CERT_PATH = / Users / myusername / .boot2docker / certs / boot2docker-vm

在这一点上,一切似乎都正常.

>然后,按照Dockerizing Node.js应用程序的教程,我得到了这一点:https://docs.docker.com/examples/nodejs_web_app/#building-your-image,您输入命令:

$sudo docker build -t<您的用户名> / centos-node-hello.
>然后要求输入密码,然后输入后我不断收到此错误消息:

将构建上下文发送到Docker守护程序
FATA [0000]发布http:///var/run/docker.sock/v1.16/build?rm = 1& t = myusername / centos-node- hello:拨打unix /var/run/docker.sock:否这样的文件或目录

这是我的env变量:

`TERM_PROGRAM=Apple_Terminal
TERM=xterm-256color
SHELL=/bin/bash
TMPDIR=/var/folders/vb/vmd78vk57mqd6fv7sqb544pc0000gn/T/
DOCKER_HOST=tcp://192.168.59.103:2376
Apple_PubSub_Socket_Render=/private/tmp/com.apple.launchd.BBIW525XNA/Render
TERM_PROGRAM_VERSION=343
OLDPWD=/Users/myusername/Desktop
TERM_SESSION_ID=FAD1F3F1-35DF-4183-A47A-08749EAFEACB
USER=myusername
SSH_AUTH_SOCK=/private/tmp/com.apple.launchd.A6ZjHwx8eq/Listeners
__CF_USER_TEXT_ENCODING=0x1F5:0x0:0x0
DOCKER_TLS_VERIFY=1
PATH=/Users/myusername/.rbenv/shims:/usr/local/bin:/usr/bin:/bin:/usr/sbin:/sbin:/opt/X11/bin
PWD=/Users/myusername/Desktop/docker
LANG=en_CA.UTF-8
vXPC_FLAGS=0x0
XPC_SERVICE_NAME=0
DOCKER_CERT_PATH=/Users/myusername/.boot2docker/certs/boot2docker-vm
HOME=/Users/myusername
SHLVL=1
LOGNAME=myusername
DISPLAY=/private/tmp/com.apple.launchd.IesbS7VdCy/org.macosforge.xquartz:0
SECURITYSESSIONID=186a5
_=/usr/bin/env`

我的Docker版本:

`Client version: 1.4.1
Client API version: 1.16
Go version (client): go1.3.3
Git commit (client): 5bc2ff8
OS/Arch (client): darwin/amd64
Server version: 1.4.1
Server API version: 1.16
Go version (server): go1.3.3
Git commit (server): 5bc2ff8`

任何帮助将非常感激.谢谢

最佳答案
您具体案例的简短回答:不要使用sudo.

原因如下:

使用boot2docker时,docker守护程序在VM中运行,主要在另一台计算机上运行.要与另一台计算机上的docker守护程序通信,必须使用TLS连接(通过HTTPS连接到守护程序的REST API).这就是你必须设置DOCKER_HOST和DOCKER_CERT_PATH的原因.由于守护程序在不同的计算机上运行,​​因此您不需要是root用户与之通信,因为传出的http连接不需要root,这与尝试与unix:///var/run/docker.sock进行通信不同插座.

但是当你运行sudo docker时,突然间你是一个不同的用户,你就是root用户.您设置为常规帐户的环境变量未设置.因此,docker CLI使用其默认通信方法:unix套接字.套接字不存在,因为守护程序在另一台机器上运行(boot2docker vm).因此错误消息.

相关文章

最近一直在开发Apworks框架的案例代码,同时也在一起修复Apw...
最近每天都在空闲时间努力编写Apworks框架的案例代码WeText。...
在《Kubernetes中分布式存储Rook-Ceph部署快速演练》文章中,...
最近在项目中有涉及到Kubernetes的分布式存储部分的内容,也...
CentOS下Docker与.netcore(一) 之 安装 CentOS下Docker与.ne...
CentOS下Docker与.netcore(一) 之 安装 CentOS下Docker与.ne...