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

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

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

Redisは、オープンソースのkey-valueデータストアで、NoSQLに分類されます。すべてのデータをメモリ上に保存するため、処理が極めて高速です。

Ruby on Rails

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

VPS

VPS(バーチャル・プライベート・サーバ)は、仮想化されたサーバをレンタルするサービスで、共有サーバでありながら専門サーバと同等の機能を果たします。物理的な専門サーバより安価で提供できるメリットがあります。

Capistrano

Rubyで書かれたサーバオーケストレーションで、複数のサーバでスクリプトを実行する際に用いられます。主な使用用途はWebアプリケーションのデプロイメントです。 アプリケーションのバージョンアップ自動化、およびデータベースの変更などもできます。

Q&A

解決済

2回答

2192閲覧

Redis::ProtocolErrorを解決できません。

s.k

総合スコア423

Redis

Redisは、オープンソースのkey-valueデータストアで、NoSQLに分類されます。すべてのデータをメモリ上に保存するため、処理が極めて高速です。

Ruby on Rails

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

VPS

VPS(バーチャル・プライベート・サーバ)は、仮想化されたサーバをレンタルするサービスで、共有サーバでありながら専門サーバと同等の機能を果たします。物理的な専門サーバより安価で提供できるメリットがあります。

Capistrano

Rubyで書かれたサーバオーケストレーションで、複数のサーバでスクリプトを実行する際に用いられます。主な使用用途はWebアプリケーションのデプロイメントです。 アプリケーションのバージョンアップ自動化、およびデータベースの変更などもできます。

0グッド

0クリップ

投稿2017/02/25 10:36

編集2017/02/27 06:00

###前提・実現したいこと
さくらのVPSにデプロイしたRailsアプリを動かしたいです。

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

I, [2017-02-25T19:20:47.772654 #17510] INFO -- : [df16f97e-a2de-4d64-a3f4-50a810953097] Completed 500 Internal Server Error in 7ms (ActiveRecord: 0.3ms) F, [2017-02-25T19:20:47.773943 #17510] FATAL -- : [df16f97e-a2de-4d64-a3f4-50a810953097] F, [2017-02-25T19:20:47.774007 #17510] FATAL -- : [df16f97e-a2de-4d64-a3f4-50a810953097] Redis::ProtocolError ( Got 'H' as initial reply byte. If you're in a forking environment, such as Unicorn, you need to connect to Redis after forking. ): F, [2017-02-25T19:20:47.774051 #17510] FATAL -- : [df16f97e-a2de-4d64-a3f4-50a810953097] F, [2017-02-25T19:20:47.774113 #17510] FATAL -- : [df16f97e-a2de-4d64-a3f4-50a810953097] app/controllers/works_controller.rb:22:in `show'

開発環境ではRedisを動かせたのですが、
本番環境で動かすことができません。

###該当のソースコード

【config/production.rb】

・・・省略・・・ ENV["REDIS"] = "http://candate.tk/:6379" ・・・省略・・・

candate.tkは私のサイトURLです。

おそらく、このポート番号が間違っているのが原因かと思うのですが、、、
ご経験ある方御指南お願いします。

confファイルのlistenは80番ポートを使用しています。

##追加

$ ps -ef | grep redis redis 17247 1 0 Feb25 ? 00:01:06 /usr/sbin/redis-server /etc/redis.conf
cat /etc/redis.conf | grep -v "#" | grep port port 6379

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

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

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

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

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

IPU

2017/02/27 05:25

ENV["REDIS"] = "http://candate.tk/:6379" これは、何のために設定しているのですか?すでにあるRedisを共有して使うため?
s.k

2017/02/27 05:30

Redisを使うにはhostとそのポート番号の指定をしなければならないと思っていました!
guest

回答2

0

ベストアンサー

Railsサーバ(さくらのVPS)と Radisサーバ(candate.tk が動作している)は、同一筐体(同一サーバ)でしょうか?

Yes
ENV["REDIS"] = "localhost:6379"

No なら
Redisサーバで、
・ネットワークレベルで ポート6379の解放
iptables コマンドで 6379 ポートを開ける必要があります

・Redis 設定(redis.conf)で接続するIPアドレスを bind で設定
接続元を受け側で許可してあげる必要があります

同筐体では無い(=No)の場合は、IP固定で解放してあげる必要があります。
そうしないと、どのサーバからもRedisに接続できてしまうので攻撃対象とされる可能性があります。

こちらを参考にしてください。
http://qiita.com/KurosawaTsuyoshi/items/f8719bf7c3a10d22a921#crackitcrackredisio

投稿2017/02/27 06:14

kurosawa

総合スコア780

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

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

s.k

2017/02/27 06:55

kurosawaさん ありがとうございます! 試します!
s.k

2017/02/27 08:53

Yesだと思っていたのですが、繋がらないので、Noで試してみます!
kurosawa

2017/02/27 12:30

Noだとしても  ENV["REDIS"] = "candate.tk:6379" のように、ドメインとポート指定は必要です。 ※ 先頭に "http://" は不要なのでご注意ください 下記が参考になるかもしれませんね http://qiita.com/u651601f/items/a0624601047db4f02808
s.k

2017/02/27 13:44

ありがとうございます!! ドメインの調子がおかしくなったので修正し次第取り組みます!
s.k

2017/02/28 13:59

yesで解決しました! ありがとうございます!
guest

0

もしかして、ただのタイプミスかな?

Ruby

1ENV["REDIS"] = "http://candate.tk:6379"

ポートの前に/が余計に入ってるだけかも。

投稿2017/02/27 05:39

IPU

総合スコア283

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

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

s.k

2017/02/27 05:39

試してみます!
s.k

2017/02/27 05:46

変わりませんでした。。。 ポート番号が間違えてる可能性がありますね。 http://candate.tk/works/1
IPU

2017/02/27 05:48

redisの設定を特にかえてないのだとしたら、「6379」であってますよ。
IPU

2017/02/27 05:52

candate.tkにログインして、 ps -ef | grep redis 打ってみましょう。 そしたら、ポート何使っているかわかるはず。
IPU

2017/02/27 05:57

こっちでも、一応わかりますよ。 cat /etc/redis.conf | grep -v "#" | grep port あと、自分はredis一緒のところでたててたので、意識してなかったけど、redis側で接続許可設定が必要みたいですね。 http://qiita.com/LowSE01/items/328cd598c0b7d8f325b2
s.k

2017/02/27 05:57

あ、そうなんですね!
s.k

2017/02/27 05:59

redisの情報を追加しました!
s.k

2017/02/27 06:00

ポート番号あってますね!
s.k

2017/02/27 06:02

すみません。貼っていただいたリンクですがnot foundと出てきます!
s.k

2017/02/27 06:55

確認します!ありがとうございます!
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問