mysql-无法连接到Docker容器
作者:互联网
我有一个使用Restify构建的Node.js服务,我正在尝试使用Docker对其进行包装.我的Dockerfile似乎工作正常,并且我的数据库和服务启动,并且使用docker exec我可以卷曲REST端点.但是,端口似乎没有暴露.如果重要的话,我在Mac上.这是我的Dockerfile:
FROM ubuntu:14.04
MAINTAINER Oscar Godson
RUN apt-get update
RUN apt-get install -y nodejs-legacy
RUN apt-get install -y npm
RUN apt-get install -y mysql-server
RUN apt-get install -y mysql-client
COPY . /src
WORKDIR /src
RUN cd /src;npm install
EXPOSE 4000
CMD ./bin/installer.sh
这是installer.sh:
service mysql start
mysql -u root < ./bin/demo-data.sql
node index.js
注意:MySQL DB仅用于测试和本地开发.我们将AWS RDS用于生产,因此这就是为什么它使用root访问权限的原因.
现在,如果我这样做:
docker run -p 4000:4000 86d57dae4522
接着:
curl http://localhost:4000/blah/ECC4E1D9-0E3C-4CE4-9D5B-2F2649A8F2FD
我得到:
curl: (7) Failed to connect to localhost port 4000: Connection refused
如果我用exec这样在容器内执行此操作:
docker exec -i 86d57dae4522 curl http://localhost:4000/blah/ECC4E1D9-0E3C-4CE4-9D5B-2F2649A8F2FD
我得到了(这是预期的,因为我还没有登录我的服务):
{"message":"You don't have permissions to do that"}
在我的Restify服务器中,我也为主机做了0.0.0.0,因为我看到一些有关需要设置Rails应用程序的评论,所以我想我可以在Node / Restify中尝试它,但是没有运气.
server.listen(process.env.PORT || 4000, "0.0.0.0", function() {
console.log('%s listening at %s', server.name, server.url);
});
我还尝试了以下朋友建议:
docker run --net="host" 7500cdb
我读到–hostname将您传递给它的IP放入/ etc / hosts中,所以我尝试了(这是我的计算机IP)
docker run --hostname="192.168.2.6" 7500cdb
这些都没有运气.有任何想法吗?
解决方法:
是的,在Mac上,这非常重要.
Docker不能在Mac上本地运行,因此您正在运行boot2docker,它正在设置一个基于VirtualBox的虚拟机.是运行Docker的VM.转发某些主机端口时,就是将VM上的端口转发到容器.在容器上安装本地路径时,它是VM上的本地路径.
在您的示例中,
http://localhost:4000/blah/ECC4E1D9-0E3C-4CE4-9D5B-2F2649A8F2FD
你需要跑步
http://$(boot2docker ip):4000/blah/ECC4E1D9-0E3C-4CE4-9D5B-2F2649A8F2FD
如果愿意,还可以运行boot2docker ip并将该地址以友好名称保存在/ etc / hosts文件中. (如果您的容器要提供SSL证书,这将很有帮助).
标签:docker,node-js,networking,restify,mysql 来源: https://codeday.me/bug/20191028/1953759.html