🎄teratailクリスマスプレゼントキャンペーン2024🎄』開催中!

\teratail特別グッズやAmazonギフトカード最大2,000円分が当たる!/

詳細はこちら
Amazon RDS

Amazon RDSは、米アマゾン社が提供しているRDBMSサービス。クラウド上でのリレーショナルデータベースの構築および運用が可能です。MySQL/PostgreSQL/Oracle/SQL Serverのインストールを容易にすることができます。

Ruby

Rubyはプログラミング言語のひとつで、オープンソース、オブジェクト指向のプログラミング開発に対応しています。

MySQL

MySQL(マイエスキューエル)は、TCX DataKonsultAB社などが開発するRDBMS(リレーショナルデータベースの管理システム)です。世界で最も人気の高いシステムで、オープンソースで開発されています。MySQLデータベースサーバは、高速性と信頼性があり、Linux、UNIX、Windowsなどの複数のプラットフォームで動作することができます。

Ruby on Rails

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

Q&A

解決済

1回答

2477閲覧

RailsでDB(レプリカ)の自動切り替えが正常に動作しない

sk_73

総合スコア8

Amazon RDS

Amazon RDSは、米アマゾン社が提供しているRDBMSサービス。クラウド上でのリレーショナルデータベースの構築および運用が可能です。MySQL/PostgreSQL/Oracle/SQL Serverのインストールを容易にすることができます。

Ruby

Rubyはプログラミング言語のひとつで、オープンソース、オブジェクト指向のプログラミング開発に対応しています。

MySQL

MySQL(マイエスキューエル)は、TCX DataKonsultAB社などが開発するRDBMS(リレーショナルデータベースの管理システム)です。世界で最も人気の高いシステムで、オープンソースで開発されています。MySQLデータベースサーバは、高速性と信頼性があり、Linux、UNIX、Windowsなどの複数のプラットフォームで動作することができます。

Ruby on Rails

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

0グッド

0クリップ

投稿2019/12/25 11:26

編集2019/12/26 05:55

前提

Ruby on RailsでWebアプリケーションを作っています。
DBをRDS for Mysql(リードレプリカ無し)からRDS Aurora Mysql(Auroraレプリカ有り)へ変更した際、問題が発生しました。

アプリケーションをAuroraレプリカに対応させるため、

Railsガイド v6.0 Active Record で複数のデータベース利用
https://railsguides.jp/active_record_multiple_databases.html

を参考に実施しました。

発生している問題

これまで正常に動作していた下記の処理がエラーを起こすようになりました(トークンを使用する処理を行うとpublic/500.htmlが表示される)。 ・アカウント有効化処理(Ruby on Rails Turorialとほぼ同様) ※ユーザーデータをDBに保存することはできる ・パスワードリセット処理(Ruby on Rails Turorialとほぼ同様) ・omniauth-twitterによるtwitter認証処理

実現したいこと

上記「発生している問題」を解消する。

該当のソースコード

# database.yml(一部抜粋) production: primary: adapter: mysql2 encoding: utf8mb4 pool: <%= ENV.fetch('RAILS_MAX_THREADS') { 5 } %> timeout: 5000 database: <%= ENV['DB_NAME'] %> username: <%= ENV['DB_USERNAME'] %> password: <%= ENV['DB_PASSWORD'] %> host: <%= ENV['DB_HOSTNAME'] %> port: <%= ENV['DB_PORT'] %> primary_replica: adapter: mysql2 encoding: utf8mb4 pool: <%= ENV.fetch('RAILS_MAX_THREADS') { 5 } %> timeout: 5000 database: <%= ENV['DB_NAME'] %> # primaryとは別のusername username: <%= ENV['DB_READ_USERNAME'] %> password: <%= ENV['DB_PASSWORD'] %> host: <%= ENV['DB_REPLICA_HOSTNAME'] %> port: <%= ENV['DB_PORT'] %> # レプリカ明示 replica: true
# application_record.rb(全て) class ApplicationRecord < ActiveRecord::Base self.abstract_class = true if Rails.env.production? connects_to database: { writing: :primary, reading: :primary_replica } end end
# production.rb (一部抜粋) config.active_record.database_selector = { delay: 2.seconds } config.active_record.database_resolver = ActiveRecord::Middleware::DatabaseSelector::Resolver config.active_record.database_resolver_context = ActiveRecord::Middleware::DatabaseSelector::Resolver::Session

試したこと

・production.rbの上記3行を削除
→問題なく動作する。
→「コネクションの自動切り替え」が正常に動作できていない?

・DB再作成
→変化無し

最後に

できれば、switch_point等のgemは使用せずに解決したいと思っています。

解決の糸口となるアドバイスを頂けたらと思います。

どうぞよろしくお願い致します。

補足情報(FW/ツールのバージョンなど)

Ruby on Rail:6.0.1
ruby:2.5.1
Mysql:5.7.28
Aurora Mysql:5.7.mysql_aurora.2.07.0

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

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

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

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

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

guest

回答1

0

自己解決

該当するコントローラーのアクションに

def
ActiveRecord::Base.connected_to(role: :writing) do

end

end

と追記し、コネクションを手動切り替えすることで解決しました。

投稿2020/01/03 16:02

sk_73

総合スコア8

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.36%

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

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

質問する

関連した質問