質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.48%
unicorn

Unicornは、汎用のRackアプリケーションサーバ。RackとWebサーバーの機能を併せ持ちます。レスポンス処理や、Nginx単体がRackの機能をサポートしていない事から、一般的にはNginx+Unicorn+Railsの構成を取って用います。

Ruby on Rails 5

Ruby on Rails 5は、オープンソースのWebアプリケーションフレームワークです。「同じことを繰り返さない」というRailsの基本理念のもと、他のフレームワークより少ないコードで簡単に開発できるよう設計されています。

Ruby on Rails

Ruby on Railsは、オープンソースのWebアプリケーションフレームワークです。「同じことを繰り返さない」というRailsの基本理念のもと、他のフレームワークより少ないコードで簡単に開発できるよう設計されています。

Active Record

Active Recordは、一つのオブジェクトに対しドメインのロジックとストレージの抽象性を結合するデザインパターンです。

Q&A

0回答

703閲覧

ActiveRecordのconnection_poolについて

altb

総合スコア104

unicorn

Unicornは、汎用のRackアプリケーションサーバ。RackとWebサーバーの機能を併せ持ちます。レスポンス処理や、Nginx単体がRackの機能をサポートしていない事から、一般的にはNginx+Unicorn+Railsの構成を取って用います。

Ruby on Rails 5

Ruby on Rails 5は、オープンソースのWebアプリケーションフレームワークです。「同じことを繰り返さない」というRailsの基本理念のもと、他のフレームワークより少ないコードで簡単に開発できるよう設計されています。

Ruby on Rails

Ruby on Railsは、オープンソースのWebアプリケーションフレームワークです。「同じことを繰り返さない」というRailsの基本理念のもと、他のフレームワークより少ないコードで簡単に開発できるよう設計されています。

Active Record

Active Recordは、一つのオブジェクトに対しドメインのロジックとストレージの抽象性を結合するデザインパターンです。

0グッド

0クリップ

投稿2018/10/31 05:04

編集2018/10/31 05:05

お世話になっております。
表題の件です。ここやRails4.2ですがここのサイトなどを見て、ActiveRecordのconnection_poolが実際どのように動いているか試してみました。DBがpostgresなので、接続数の確認のためSELECT * FROM pg_stat_activityを使っています。
pumaを使って(プロセスは一つ)

10.times{|n| Thread.new{ Model.find_by(code: '1111') }} sleep(15)

とした時は期待通りにdatabase.ymlのpoolの制限が効いているのがわかりました。

Railsではコネクションプール数を設定していても、1スレッドあたり1コネクションしか使いません。つまり、シングルスレッドのUnicornでは、1ワーカープロセス = 1コネクションとなります。

とあるので、unicorn.rbを以下のようにして同じように試してみたところ、各プロセスにつき5つ接続されていました。この時、poolは3に設定していました。

rails_root = File.expand_path('../', __dir__) worker_processes 3 working_directory rails_root timeout 30 stderr_path File.expand_path('../../log/unicorn_stderr.log', __FILE__) stdout_path File.expand_path('../../log/unicorn_stdout.log', __FILE__) listen 3000 pid File.expand_path('../../tmp/pids/unicorn.pid', __FILE__) preload_app true

Thread.newが悪いのかと思い単純にfind_byを10回に変更してみましたが、なぜか各プロセスごとに2つ接続されていました。
原因がさっぱりわかりません。1ワーカープロセス = 1コネクションなら各プロセスにつき1つの接続でいいはずですし、Thread.newが悪いのであればpoolを3にしているのだから各プロセスにつき3つの接続までに制限できていいはずです。
unicornではActiveRecordのconnection_poolは使えないのですか?
また、実際はpassengerで動かしたいと思っているのですが、passengerでActiveRecordのconnection_poolを利用している方はいらっしゃるでしょうか...

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだ回答がついていません

会員登録して回答してみよう

アカウントをお持ちの方は

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問