rails初心者です。
的外れな質問してたらすみません。
宜しくお願いします。
Ubuntu
ruby 3.0.0
rails 6.1.0
puma 5.0
前提・実現したいこと
action cableを使ったチャットを行うためwebsocketを使いたい。
cloud9(Amazon linux2)/ rails5で動作していたプログラムを
Ubuntu/rails6に移行したところチャットが動作しなくなった。
rails6環境でチャットが動作しないため、ログを見るとそもそもwebsocketに関する情報が出力されていませんでした。
websocketが起動していない?
発生している問題
rails s でサーバを起動しても、
ログにwebsokcketの情報が出力されません。
つまりwebsokcketが動作してないようです。
※特にエラーは出力されてません
通常であれば、rails sの実行でwebsocketが起動すると思ってます。
と言うのは、websocketが動作してるrails5環境ではrails sで以下が毎回出力されてたからです。
Started GET "/cable/" [WebSocket] for 58.13.43.197 at 2021-03-01 23:31:59 +0000 Successfully upgraded to WebSocket (REQUEST_METHOD: GET, HTTP_CONNECTION: upgrade, HTTP_UPGRADE: websocket)
該当のソースコード
rails5環境(websocketが起動)では、rails s で
「ChatChannel subscribed」が出力されます。
\app\channels\chat_channel.rb
ruby
1class ChatChannel < ApplicationCable::Channel 2 def subscribed 3 4 Rails.logger.debug("ChatChannel subscribed") 5 stream_from "chat_channel_#{params['room']}" 6 7 end 8 9 def unsubscribed 10 # Any cleanup needed when channel is unsubscribed 11 end 12 13 def post(data) 14 # Rails.logger.debug("server post data:") 15 # Rails.logger.debug(data) 16 Message.create! text: data['message'], user_id: current_user.id, room_id: data['room'] 17 end 18end 19
\app\channels\application_cable\channel.rb
ruby
1module ApplicationCable 2 class Channel < ActionCable::Channel::Base 3 end 4end 5
app\channels\application_cable\connection.rb
ruby
1 class Connection < ActionCable::Connection::Base 2 identified_by :current_user 3 4 def connect 5 self.current_user = find_verified_user 6 end 7 8 protected 9 def find_verified_user 10 11 if current_user = User.find_by(id: cookies.encrypted[:user_id]) 12 current_user 13 else 14 reject_unauthorized_connection 15 end 16 end 17 end 18end 19
試したこと
websoketに関するパッケージがrails6側には入っていないのかと考えました。
「radis」というものを使ってそうなので、こちらがインストールされているか確認しましたが、rails5,6ともに見当たりませんでした。
websocketを動作させるには、何か事前準備が必要なのでしょうか?
分かる方教えて下さい。
宜しくお願い致します。
回答1件
あなたの回答
tips
プレビュー
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。