Rails 開発環境で、Sinatra アプリをミドルウェアとして追加しようとしています。Sinatra アプリは、ユーザーの IP アドレスを処理し、都市とともに json を返すgeoip gemを使用します。
返された json を表示するには、ブラウザーでサンプル URL に直接アクセスするか、コマンド ラインで curl を使用しhttp://local.fqdn.org/geoip/locate.json?ip=24.18.211.123
ます。ただし、Rails コントローラー内から wget を使用して URL を呼び出そうとすると、Rails アプリが応答を停止し、ブラウザーが頻繁にクラッシュし、Rails サーバーが control+C コマンドを使用して終了しません。
ここで何が起こっているかの手がかりはありますか?ブラウザーで URL に直接アクセスすると適切な応答が返されるのに、コントローラーで呼び出しを行うとタイムアウトになるのはなぜですか?
sinatra-geoip.rb
require 'sinatra'
require 'geoip'
require 'json'
# http://localhost/geoip/locate.json?ip=24.18.211.123
#
# {
# latitude: 47.684700012207
# country_name: "United States"
# area_code: 206
# city: "Seattle"
# region: "WA"
# longitude: -122.384803771973
# postal_code: "98117"
# country_code3: "USA"
# country_code: "US"
# dma_code: 819
# }
class GeoIPServer < Sinatra::Base
get '/geoip/locate.json' do
c = GeoIP.new('/var/www/mywebsite.org/current/GeoLiteCity.dat').city(params[:ip])
body c.to_h.to_json
end
end
ルート.rb
mount GeoIPServer => "/geoip"
config/environments/development.rb
Website::Application.configure do
require "sinatra-geoip"
config.middleware.use "GeoIPServer"
...
end
コントローラ
raw_geo_ip = Net::HTTP.get(URI.parse("http://#{geoip_server}/geoip/locate.json?ip=#{request.ip}"))
@geo_ip = JSON.parse(raw_geo_ip)