2016-05-08 4 views
2

Я пытаюсь достичь параллелизма в сервере puma pils при разработке, но у меня проблемы.Rails Ошибка параллельной работы Puma

Моя конечная точка выглядит следующим образом:

def show 
     (1..10).each do |i| 
     Rails.logger.info "I!! #{i}" 
     sleep(1) 
     end 
     render json: {health: "hihi"} 
    end 

Я бегу ударил эту конечную точку дважды, один за другим, и они работают последовательно. Могу ли я заставить их быть более параллельными?

Log:

puma -t 2:16 -p 3000 
    [20186] Puma starting in cluster mode... 
    [20186] * Version 3.4.0 (ruby 2.2.2-p95), codename: Owl Bowl Brawl 
    [20186] * Min threads: 2, max threads: 16 
    [20186] * Environment: development 
    [20186] * Process workers: 2 
    [20186] * Preloading application 
    [20186] * Listening on tcp://0.0.0.0:3000 
    [20186] Use Ctrl-C to stop 
    [20186] - Worker 0 (pid: 20217) booted, phase: 0 
    [20186] - Worker 1 (pid: 20218) booted, phase: 0 

    Started GET "/v1/address-service/addresses/1" for 127.0.0.1 at 2016-05-07 19:00:38 -0700 
     ActiveRecord::SchemaMigration Load (0.5ms) SELECT `schema_migrations`.* FROM `schema_migrations` 
    Processing by Api::V1::AddressService::AddressesController#show as JSON 
     Parameters: {"id"=>"1"} 
    I!! 1 
    I!! 2 
    I!! 3 
    I!! 4 
    I!! 5 
    I!! 6 
    I!! 7 
    I!! 8 
    I!! 9 
    I!! 10 
    Completed 200 OK in 10143ms (Views: 0.9ms | ActiveRecord: 0.0ms | Elasticsearch: 0.0ms) 


    Started GET "/v1/address-service/addresses/1" for 127.0.0.1 at 2016-05-07 19:00:49 -0700 
    Processing by Api::V1::AddressService::AddressesController#show as JSON 
     Parameters: {"id"=>"1"} 
    I!! 1 
    I!! 2 
    I!! 3 
    I!! 4 
    I!! 5 
    I!! 6 
    I!! 7 
    I!! 8 
    I!! 9 
    I!! 10 
    Completed 200 OK in 10031ms (Views: 0.3ms | ActiveRecord: 0.0ms | Elasticsearch: 0.0ms) 

development.rb:

config.cache_classes=false 
    config.allow_concurency = true 
+0

Моя версия рельсов: Rails 4.2.5.2 – Gary

ответ

0

Я понимаю, что я использовал хром, чтобы проверить и он посылает только один запрос в то время, по какой либо причине. Я использовал завиток, и он работает, как ожидалось.

Смежные вопросы