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

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

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

Action Cableは、WebSocketをRailsに組み込む機能。Rails4でオプションとして存在していたWebSocketをRails5で標準機能したものです。Railsアプリケーションと同様のスタイルで、Rubyを用いたリアルタイム機能を記述できます。

Ruby on Rails 6

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

Heroku

HerokuはHeroku社が開発と運営を行っているPaaSの名称です。RubyやNode.js、Python、そしてJVMベース(Java、Scala、Clojureなど)の複数のプログラミング言語をサポートしている。

Q&A

解決済

1回答

3051閲覧

Action Cableが本番環境で非同期にならない

max3252

総合スコア4

Action Cable

Action Cableは、WebSocketをRailsに組み込む機能。Rails4でオプションとして存在していたWebSocketをRails5で標準機能したものです。Railsアプリケーションと同様のスタイルで、Rubyを用いたリアルタイム機能を記述できます。

Ruby on Rails 6

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

Heroku

HerokuはHeroku社が開発と運営を行っているPaaSの名称です。RubyやNode.js、Python、そしてJVMベース(Java、Scala、Clojureなど)の複数のプログラミング言語をサポートしている。

0グッド

0クリップ

投稿2020/09/18 08:50

前提・実現したいこと

リアルタイムチャットの機能をAction cableを使って実装しています。
ローカル環境では非同期でリアルタイムに問題なく動くのに本番環境になると再読み込みをしないと反映されません。
本番環境でも非同期で実装するためにお力を借りたいです。
アプリはheroku上にアップしています。

発生している問題・エラーメッセージ

ターミナルにてログを見てみると下記の通りにエラーが出ています。

2020-09-18T08:06:33.015455+00:00 app[web.1]: [f87b85ba-b644-4ced-97b7-be54d88e4320]Completed 500 Internal Server Error in 28ms (ActiveRecord: 18.4ms | Allocations: 1766) 2020-09-18T08:06:33.017267+00:00 app[web.1]: [f87b85ba-b644-4ced-97b7-be54d88e4320] 2020-09-18T08:06:33.017268+00:00 app[web.1]: [f87b85ba-b644-4ced-97b7-be54d88e4320] Gem::LoadError (Error loading the 'redis' Action Cable pubsub adapter. Missing a gem it depends on? redis is not part of the bundle. Add it to your Gemfile.):

該当のソースコード

エラー文にはGemの読み込みがうまく行っていない感じのエラーが出ています。今回Action Cableでリアルタイムチャット機能を実装するためにGemを入れてはいませんが念の為、Gemfileのソースコードを添付します。

Gemfile

1source 'https://rubygems.org' 2git_source(:github) { |repo| "https://github.com/#{repo}.git" } 3 4ruby '2.6.5' 5 6# Bundle edge Rails instead: gem 'rails', github: 'rails/rails' 7gem 'rails', '~> 6.0.0' 8# Use mysql as the database for Active Record 9gem 'mysql2', '>= 0.5.3' 10# Use Puma as the app server 11gem 'puma', '~> 3.11' 12# Use SCSS for stylesheets 13gem 'sass-rails', '~> 5' 14# Transpile app-like JavaScript. Read more: https://github.com/rails/webpacker 15gem 'webpacker', '~> 4.0' 16# Turbolinks makes navigating your web application faster. Read more: https://github.com/turbolinks/turbolinks 17gem 'turbolinks', '~> 5' 18# Build JSON APIs with ease. Read more: https://github.com/rails/jbuilder 19gem 'jbuilder', '~> 2.7' 20# Use Redis adapter to run Action Cable in production 21# gem 'redis', '~> 4.0' 22# Use Active Model has_secure_password 23# gem 'bcrypt', '~> 3.1.7' 24 25# Use Active Storage variant 26# gem 'image_processing', '~> 1.2' 27 28# Reduces boot times through caching; required in config/boot.rb 29gem 'bootsnap', '>= 1.4.2', require: false 30 31group :development, :test do 32 # Call 'byebug' anywhere in the code to stop execution and get a debugger console 33 gem 'byebug', platforms: [:mri, :mingw, :x64_mingw] 34 gem 'rspec-rails', '~> 4.0.0' 35 gem 'factory_bot_rails' 36end 37 38group :development do 39 # Access an interactive console on exception pages or by calling 'console' anywhere in the code. 40 gem 'web-console', '>= 3.3.0' 41 gem 'listen', '>= 3.0.5', '< 3.2' 42 # Spring speeds up development by keeping your application running in the background. Read more: https://github.com/rails/spring 43 gem 'spring' 44 gem 'spring-watcher-listen', '~> 2.0.0' 45end 46 47group :test do 48 # Adds support for Capybara system testing and selenium driver 49 gem 'capybara', '>= 2.15' 50 gem 'selenium-webdriver' 51 # Easy installation and use of web drivers to run system tests with browsers 52 gem 'webdrivers' 53end 54 55# Windows does not include zoneinfo files, so bundle the tzinfo-data gem 56gem 'tzinfo-data', platforms: [:mingw, :mswin, :x64_mingw, :jruby] 57 58gem 'pry-rails' 59 60gem 'devise' 61 62gem "aws-sdk-s3", require: false 63 64gem 'jquery-rails' 65 66gem 'active_hash' 67 68gem 'rails-i18n' 69 70gem 'mini_magick' 71gem 'image_processing', '~> 1.2' 72 73 74gem 'omniauth-google-oauth2' 75 76gem 'kaminari' 77 78 79group :production do 80 gem 'rails_12factor' 81end

試したこと

以下の記事のエラー状況が似ていたので参考にしました。
参考記事

production.rbを以下のように編集(コメントを解除し編集)

production.rb

1コメントアウトを外し、編集 2config.action_cable.allowed_request_origins = [ /http://.*/ ]

config/cable.ymlを以下のように編集
production:に書かれているものをコメントアウトして、adapter: asyncを追加。

config/cable.yml

1production: 2 # adapter: redis 3 # url: redis://localhost:6379/1 4 # channel_prefix: *****_production 5 adapter: async

*****はアプリ名が入っています。

上記の方法を試しましたが、変わらずでした。
変化が無かったので編集した所は元のコードに戻しています。

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

上記のソースコードでは情報が足りない場合は教えていただけると幸いです。
宜しくお願い致します。

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

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

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

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

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

guest

回答1

0

自己解決

cable.ymlのproductionの部分をdevelopmentと同じコードにしてみたら行けました!
Herokuの環境だとうまくいかないみたいな問題だったので、AWSとかの場合はまた違うかも知れません。
お騒がせしました。

投稿2020/09/18 09:24

max3252

総合スコア4

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問