我正在尝试对一个简单的Sinatra应用程序进行Docker化,但是当Docker启动时,我无法通过公开的端口4567访问API。
这是我的Dockerfile:
FROM ruby:2.7
RUN apt-get update -qq && apt-get install -y build-essential
RUN mkdir /app
WORKDIR /app
COPY Gemfile /app/Gemfile
COPY Gemfile.lock /app/Gemfile.lock
RUN bundle install
COPY . /app
EXPOSE 4567
CMD [ "bundle", "exec", "ruby", "main.rb", "-p", "4567" ]
然后:
docker build -t my-application .
docker run -p 4567:4567 my-application
当我访问localhost:4567
时:
但是如果我访问该容器并发出curl
请求,它将起作用:
docker exec -it bdcbfcaa57aa bash
我看不到我在做什么错。
[您的Sinatra应用程序很可能在127.0.0.1
上进行监听。您需要将其绑定到0.0.0.0
。
在经典的Sinatra中,它是通过以下方式完成的:
require 'sinatra'
set :port, 4567
set :bind, '0.0.0.0'
# ... rest of the app
我不确定您的main.rb
中有什么,但是您可能想添加对--host 0.0.0.0
或--bind 0.0.0.0
的支持。
这里是一个功能齐全的示例:
Dockerfile:
FROM dannyben/alpine-ruby
WORKDIR /app
COPY . .
RUN gem install puma sinatra
EXPOSE 3000
CMD ruby server.rb
server.rb:
require 'sinatra'
set :port, 3000
set :bind, '0.0.0.0'
get '/' do
"we are the champions"
end
然后运行:
$ docker build -t temp .
$ docker run --rm -it -p 3000:3000 temp