トップページphp
1001コメント368KB

【RoR】Ruby on Rails Part13

■ このスレッドは過去ログ倉庫に格納されています
0001nobodyさん2011/11/04(金) 17:06:24.32ID:???
■前
【Ruby】Ruby on Rails Part12
http://hibari.2ch.net/test/read.cgi/php/1311050686/

■参考サイト
<英語>
本家:http://rubyonrails.org
API document:http://api.rubyonrails.com/
開発者のblog:http://weblog.rubyonrails.org/
参考wiki:http://wiki.rubyonrails.org/rails
http://ruby-toolbox.com/
http://rubygems.org/
http://agilewebdevelopment.com/plugins/top_rated

<日本語>
Rails' wiki: http://wiki.fdiary.net/rails/

http://twitter.com/dhh
http://www.loudthinking.com/
0749nobodyさん2012/01/24(火) 18:08:32.06ID:/isHqZPr
>>748

そ、そんな
だめなんですか

特例でおしえていただきたいんですが
0750nobodyさん2012/01/24(火) 18:13:03.92ID:/isHqZPr
とりあえずかきこんじゃいます。

今ちいさなアプリケーションをrailsで作っているのですが、

formにメッセージを書き込む際に
あわせて書いた人のユーザーid を取得したいのですが、
どこに記述してよいかわかりません。

formの一部を抜粋するとこうなってます↓

<div class="field">
<%= f.label :message %><br />
<%= f.text_area :massage %>
</div>

お願いいたします
0751nobodyさん2012/01/24(火) 18:14:55.52ID:???
押しが強くてワロタ
0752nobodyさん2012/01/24(火) 18:16:14.91ID:???
massage エロス
あとユーザIDってのは自分で入力させるの?
それともセッションかどっかに入ってるの?
0753nobodyさん2012/01/24(火) 18:22:49.82ID:/isHqZPr
押し強くてごめんなさいw
分からなくてすごく困ってたんですw

ユーザーのidは書いているユーザー一人一人が持っていて、
<%= current_user.id %>
とかけば出力されます。

理想としてはメッセージを送ると自動でuser_idもDBに送られるようにしたいです。。
0754nobodyさん2012/01/24(火) 18:54:33.22ID:???
Railsでは普通、idは入力させたり、フォームから送るものではない。
セーブした時にDBから割り当てられるもの。

もし、任意のid(初心者ならこのカラム名はやめた方が良い)を入力させるなら、
重複が無いかなどを調べないといけない。
0755nobodyさん2012/01/24(火) 18:57:49.67ID:???
んーと、送り主のidはフォームからは普通送らない。
コントローラで current_user.id とかやって、メッセージにセットする。
0756nobodyさん2012/01/24(火) 19:16:19.62ID:/isHqZPr
idはuserテーブルののidをとりあえずmessageテーブルにuser_idとしてながしこみたいのです…

コントローラーでやるんですね、
ちょっといろいろためしてみます!
0757nobodyさん2012/01/24(火) 19:31:55.63ID:/isHqZPr
書き方がわからなかったので、フィーリングで、
コントローラーのdef createところに
@message = Message.new(params[:Message])
params[:user_id] = current_user.id

とかいたのですが、うまく動かず…orz
0758nobodyさん2012/01/24(火) 19:33:23.03ID:???
params に渡してどうするのよ。
message に渡しなよ。
@message.user_id = current_user.id
0759nobodyさん2012/01/24(火) 19:38:15.04ID:/isHqZPr
うおおお ちゃんと登録されました!

た、助かりました…!ありがとうございます
0760nobodyさん2012/01/25(水) 01:09:22.67ID:???
そういや>>736あたりの話なんだけど、
Railsでは /foo/123 には /foo/123.xml とか /foo/123.json とか :format がつけられるじゃん?
これって、コンテナリソースにはつけられるの?
つまり /foo/.xml とか /foo/.json とかはできるわけ?
それともコンテナリソースに対して xml や json を要求する場合はまた違う方法になるの?
0761nobodyさん2012/01/25(水) 07:42:06.57ID:???
index.json
0762nobodyさん2012/01/25(水) 08:11:31.32ID:CoUa4Jns
foos.xml とか foos.json
0763nobodyさん2012/01/25(水) 10:11:00.50ID:???
config/route.rbでどうとでもできるからな
0764nobodyさん2012/01/25(水) 11:16:46.09ID:???
テーブルの、あるフィールドの最大値を取得したいのですが、うまくいきません。。。

たとえばFooというテーブルのbarというフィールドの最大値を取得したいときは、以下のように書けば良いらしいのですが・・・

Foo.maximum('bar')

しかしながら、こう書くと『no method error』になるのです。
こちらの環境はRuby1.9.3、Rails3.1.3です。

maximumメソッドについては、以下のサイトで見つけました。
http://railsdoc.com/references/maximum

これによると3.1.0までは対応しているようですが、3.1.3にはもうmaximumはないということでしょうか?
0765nobodyさん2012/01/25(水) 13:21:04.50ID:???
普通に取れるけど。3.1.3と3.2.0で試した。
そのフィールド無いんじゃないの?
0766nobodyさん2012/01/25(水) 14:04:53.51ID:T66svPqt
user
friend
entry
があります。
user にはstatusがあって、statusがwarningの物は友人でなくとも無条件で表示したいです

entry.joins( :user => :friend ).("users.status = ? OR friends.post_user_id = ?" , "warning" , session[:user_id] )

これで取れるかと思ったのですが、users.status = ?がスルーされているのか
後のfriendの記事しか取れません

joinについて何か大きな勘違いをしているのかもしれませんorz
どうすればとれますか?
0767nobodyさん2012/01/25(水) 14:19:09.42ID:???
>>765
すみません、説明不足でした。
正確には、ある条件でデータを絞った後で、その中でのフィールドの最大値を取得したいということなのです。

まずFooというテーブルにbar、bazという2つのフィールドがあるとします。
イメージ的には、やりたい内容は以下のようなことです。
-------------------------------------
f = Foo.find_by_bar(○○○)

puts f.maximum('baz')
-------------------------------------

このやり方ですと、undefined method になります。

確かに、Foo.maximum('bar')という風に、絞り込んだものに対してではなく、直接最大値を取得するやり方ならうまく取れました。
絞り込んだものに対しては、maximumは使えないのでしょうか?
0768nobodyさん2012/01/25(水) 14:54:10.77ID:???
>>767です。
すみません、自己解決しました。
以下の方法で、条件を絞ったうえでの最大値を取得できました。

Foo.maximum(:bar, :conditions => {:baz => ○○○})

お騒がせしてすみませんでした;;
0769nobodyさん2012/01/25(水) 20:32:05.37ID:CoUa4Jns
>>767
ところでFoo.find_by_barだとfはFooのインスタンス1つになるわけだが。

0770nobodyさん2012/01/25(水) 21:57:29.42ID:???
railsの
model = Model.new(param[:prefix])
model.save()
ってやり方は、悪意あるユーザがフォームにないパラメータを送ると
意図しない属性も変更されてしまうと思うのですが、そんなことないですか。
0771nobodyさん2012/01/25(水) 22:04:45.35ID:???
mass assignできなくすれば大丈夫
0772nobodyさん2012/01/26(木) 05:29:31.01ID:WYeK+tHX
みなさんは高速化のためにどんな方法をとってますか?

例えば、ブログなんかで
最新のコメント

なーんてものがありますよね?

ああいう、頻繁に更新される可能性がある一箇所のせいで結構つらい思いをすることもあります
ログイン→ようこそ◯◯さん等もそうですが

いくつか考えたのですが、ページキャッシュしてしまい
そういった部分を全てAjax等で非同期読み込み

上でも出てたJavascriptでCookieを調べて割り振り
どちらも、Rails外での話なのでどうしても面倒くささを感じてしまいます……
0773nobodyさん2012/01/26(木) 07:00:43.56ID:LIf9fd2V
フラグメントキャッシュ使えし


ところで、フラグメントキャッシュって一定時間で破棄って出来ない?
5分で破棄したいのだけど……
0774nobodyさん2012/01/26(木) 11:45:32.46ID:???
>>771
>mass assignできなくすれば大丈夫
ありがとうございます。でもこれってデフォルトでは作る側がいちいち設定する必要があるんですよね。
設定しなかった場合は、悪意あるユーザからの攻撃をいとも簡単に受けてしまう。

なんでデフォルトで禁止してないんですかね。
ttp://d.hatena.ne.jp/halflife/20081006/1223302382
> みたいにmass assignmentを使ってしまうと、entry[user_id]=1 とか適当なパラメータを送るだけで誰か他のユーザの投稿として Entry を更新することができたりするわけで。
> もちろん手を抜くなとか忘れるのが阿呆だとかはあるかもしれないけど、わたしのような初心者には結構危なく感じた。
>
> なんでRailsはデフォルトでmass assignment不可にしないんだろう?
> デフォルト不許可にしてしまうと、スキーマが変更されるたびに合わせて attr_accessible を修正しなきゃいけないとかDRYじゃねえよウゼーという感じなんだろうか。
0775nobodyさん2012/01/26(木) 11:55:04.00ID:???
findした段階で大体防げるからなぁ。
@enty = current_user.entries.find(params[:id])
みたいに。
そう書いてないとダメだが。
0776nobodyさん2012/01/26(木) 12:28:43.36ID:???
>>772
最近ならそういった情報で更新されにくいものは
クライアントサイドのlocalStorageにいれてしまうってのもありだな
サーバーへアクセスされないからAJAXの負荷が無い
0777nobodyさん2012/01/26(木) 16:01:35.70ID:???
>>775
なんでそれで防げたことになるんですか?
今問題にしているのはcreateやupdateの話であって、findは関係ないような。
0778nobodyさん2012/01/26(木) 16:30:47.72ID:???
updateの時は初めにfindするし、
createでは
@entry.user_id = current_user.id
するだろ。
しなければもちろん外からセットされる。プロテクトしてなければ。

Railsに限った話ではなくて、そう作ればそうなるよという事。

0779nobodyさん2012/01/26(木) 18:58:14.63ID:???
>>778
もしかしてuser idのことだけ言ってますか?>>775
>findした段階で大体防げるからなぁ。
と言っているのが不思議だったんですけど、user id *だけ* みればそうかもしれません。
しかし774などで指摘していることは任意のフィールドに当てはまることであり、
「findした段階で大体防げる」ようなものではないんじゃないですか。

0780nobodyさん2012/01/26(木) 20:03:46.49ID:RmSk4BIq
rails3.2でcsvのfixtureを読み込まなくなって
移行しようにも苦労しているのですが
おすすめのcsv読み込みツールってありますか?
0781nobodyさん2012/01/27(金) 11:02:32.60ID:???
> >mass assignできなくすれば大丈夫
> ありがとうございます。でもこれってデフォルトでは作る側がいちいち設定する必要があるんですよね。
> 設定しなかった場合は、悪意あるユーザからの攻撃をいとも簡単に受けてしまう。

これで終わりじゃん
0782nobodyさん2012/01/27(金) 14:38:18.12ID:lH99fQFB
Riding Rails: Rails 3.2.1 has been released
http://weblog.rubyonrails.org/2012/1/26/rails-3-2-1-has-been-released
0783nobodyさん2012/01/27(金) 18:06:51.09ID:???
route.rbに関しての質問です。
pages/:idの:idの部分を、ユーザの名前にしたくて困っています。
route.rbを
match "'pages/:username" => "pages#show", :via => :get, :path => :name
にしてrake route すると、
pages/usernameというルートしかできず…
方法ご存知な方いらっしゃいますか?
0784nobodyさん2012/01/27(金) 22:26:17.58ID:50WK7S02
class Page
def to_param; name; end
end

rails c
>> helper.controler = app
>> app.page_path(Page.create(:name => 'foobar'))

デフォルトのルーティングだと、名前であろうとパラメータ的にはあくまで
:idというパラメータとして渡されてくるので、:idだがnameとして扱うこと。
0785nobodyさん2012/01/28(土) 05:39:03.61ID:???
>>779
なぜわざわざ770みたいな脆弱な書き方を覚えてしまったのか
それは「横着な書き方」であって脆弱なのは当たり前だし、それでもRailsにはその脆弱さを防ぐ方法がいくつも備わってる

ちなみに775の言ってる事は俺も的外れだと思う
0786nobodyさん2012/01/28(土) 10:17:16.60ID:???
>>785
scaffoldが
foo = Foo.find(params[:id])
foo.update_attributes(params[:foo])
foo.save
みたいなコードを吐く以上、それがRailsの標準的なやり方と見なされてもしょうがない。
ところで
>それでもRailsにはその脆弱さを防ぐ方法がいくつも備わってる
って言ってるけど、具体的にはどんな方法があるの?
いくつもあるなんて知らなかった。
0787nobodyさん2012/01/28(土) 18:10:10.01ID:???
>>764

このサイト知らなかったな
微妙に間違っているが、すごい解説の量だ!
0788nobodyさん2012/01/28(土) 20:25:27.97ID:kusQOV3z
attr_accessible と attr_protected
http://blog.digital-squad.net/article/106792109.html

Use attr_protected or we will hack you - Blog Articles - LessEverything
http://lesseverything.com/blog/archives/2008/03/11/use-attr_protected-or-we-will-hack-you/





0789nobodyさん2012/01/28(土) 21:31:22.30ID:kusQOV3z
attr_accessibleは、ActiveModel::MassAssignmentSecurityの機能で、
newやらupdate_attributesやらでレコードの属性を「一括設定してもよい」属性を
指定するもの。逆に「一括設定を禁止」するattr_protectedとペアで考える。
http://read2ch.com/r/php/1292032736/#t508
0790nobodyさん2012/01/28(土) 21:47:54.91ID:kusQOV3z
assign_attributes
http://www.oiax.jp/rails/zakkan/assign_attributes.html

update_attributes
http://blog.livedoor.jp/sasata299/archives/51485638.html
0791nobodyさん2012/01/29(日) 14:01:57.04ID:???
れいるず、速習のコツを教えてくだされ。
0792nobodyさん2012/01/31(火) 07:44:07.71ID:???
RailsによるアジャイルWEBアプリケーション開発っていうすばらしい本が出てるからその通りにショッピングサイトを作ればオッケー
0793nobodyさん2012/01/31(火) 11:18:03.40ID:???
翻訳者宣伝乙
0794nobodyさん2012/01/31(火) 19:00:01.98ID:???
>>792
で、やってる途中で新バージョンが出る
0795nobodyさん2012/01/31(火) 21:42:32.22ID:J/mA32Fb
Rails Guidesでええやん。
0796nobodyさん2012/01/31(火) 22:06:34.42ID:Nhw8SxC0
When I did all the programming for the original version of Basecamp back in 2003,
we ended up shipping with just about 2,000 lines of code.
http://37signals.com/svn/posts/3094-code-statistics-for-basecamp-next

37signalsのBasecampは米国企業上位500社の321社が利用中 ? SEO Japan
http://www.seojapan.com/blog/37signals-and-fortune500

Ruby on Rails開発者のDavid Heinemeier Hanssonによる「起業の学校」講演!
http://toshio.typepad.com/b3_annex/2008/04/ruby-on-railsda.html
2000人の顧客が月40ドルを12か月払えば、100万ドルになる。

0797nobodyさん2012/01/31(火) 22:10:27.23ID:Nhw8SxC0

Getting Real by 37signals
http://gettingreal.37signals.com/GR_jpn.php
0798nobodyさん2012/01/31(火) 23:23:30.79ID:Nhw8SxC0
http://twitter.com/#!/ike728/statuses/164164168839204865

http://www.sponichi.co.jp/gravure/special/ir_2010/ir_ikezawaasuka/KPhotoNormal20100731176_p.html

0799nobodyさん2012/02/01(水) 09:50:30.32ID:???
ActiveRecordで取得したレコードに対してeachメソッドみたいに全カラムにループでアクセスする方法ってありますか?

Test.find(1).each do |key, value|
#処理
end

このような処理はできないんでしょうか?
0800nobodyさん2012/02/01(水) 10:24:09.07ID:???
自己解決しました。
attributesメソッドでハッシュが返ってきますね。
0801nobodyさん2012/02/01(水) 21:36:14.66ID:MwDJMjTg
Twitter Bootstrapが大幅バージョンアップ!して凄まじいことに・・・ | IDEA*IDEA
http://www.ideaxidea.com/archives/2012/02/twitter_bootstrap_v2.html

http://twitter.github.com/bootstrap/index.html
https://github.com/twitter/bootstrap/
0802 忍法帖【Lv=13,xxxPT】 2012/02/01(水) 23:04:02.37ID:???
!test
0803nobodyさん2012/02/02(木) 11:31:58.44ID:ppveFy64
サイト重すぎてヤバイんですが、何かおぬぬめのてくにっくやとりあえずここみとけ!って対処法あります?

調べたところ
データベースアクセス周りが7割くらい占めてました

かるく調べたんですが
めむきゃっしゆ?
find_by_sql
インデックスをはる

あたりが王道のようですが、これでどのくらいかわるものですか?
0804nobodyさん2012/02/02(木) 13:06:40.10ID:???
インデックスはってないなら、まずはそこから
データ量によっては10倍以上効く
0805nobodyさん2012/02/02(木) 13:07:29.66ID:???
ケースバイケース
0806nobodyさん2012/02/02(木) 13:25:21.92ID:nGOtgXLd
>>804
ありがとうございます

find_byでしょっちゅう検索するものに貼ってみます

snsで、データはユーザー数が500くらい、コメント数が2万くらいです

>>804
確かにそうですよね……
うーんと、それじゃあ

twitterのようなリアルタイム性があるページキャッシュの効かないサイトを運営した場合
どのようなアプローチが考えられますか?
毎読み込みごとに結構な数のクエリが発行されるでしょうし、人数もとても多く、拡散などでリアルたいむに個々のつぶやきの情報もかわる
似たような機能があり、そこがボトルネックとなっております


例えば、ヘッダーフッターサイドバーと言った外枠だけをページキャッシュして、jqueryで内側を非同期読み込みー

などという方法で、とりあえずレスポンス速度のみは劇的に改善できるとも考えたのですが
すごくクールじゃないですよねー……
0807nobodyさん2012/02/02(木) 14:24:52.03ID:???
いやー、別にクールじゃないわけじゃないと思うけどね
github なんかそんな感じじゃん
0808nobodyさん2012/02/02(木) 15:27:49.48ID:???
泥臭くてもレスポンスよくなりゃ正義だと思うよ。
メンテナの間で同意とれてりゃだけど。
0809nobodyさん2012/02/02(木) 17:34:08.38ID:???
ruby eeとかも考えられるけど
それ以前にパンクする規模じゃない気がするなあ
mysqlあたりのメモリ設定とかも見直したら?
0810nobodyさん2012/02/02(木) 19:03:48.10ID:79jXgfNj
>>807
言われてみれば……!

>>808
ですよねー……
中でなにやってようが早ければユーザーさんはかまいやしないですよね

>>809
なんとこんなものが……

Mysqlのメモリをデフォルトの16MBから500MB(搭載は4GB)まで増やしたらそれだけでかなり快適になりました
ありがとうございました
0811nobodyさん2012/02/02(木) 19:26:54.19ID:???
>>810
それ、スモールサーバの設定だったんじゃないかな
MySQLのチューニングは探せばいろんなページに設定例あるし本も出てるよ
0812nobodyさん2012/02/03(金) 12:11:30.89ID:NPWpUqid
ページキャッシュのディレクトりってどこで指定できますか?
Rails2では
Actioncontroller::Base.page_cache_directory = "/var/www/hoge/public/page_cache" こんな感じ?
だったようですが、3だとうまくいきません。

やりたいことは、「一定時間でのキャッシュの削除を簡単にする」です。
10分毎にページキャッシュをクリーンしたいので、cron で rm * で一括で消したいと考えております
0813nobodyさん2012/02/03(金) 17:24:14.90ID:hJMEWrmo
ものすごい初心者なので質問のレベルが低いかも知れませんが、質問させてください。
勉強をかねて掲示板を作成しようと思ったのですが、
resourcesのネストでうまく行かなくなってしまいました
rails3.1.3
ruby1.9.2

スレッドをtopic,レスをpostという名前でモデルをscaffoldで作って、モデルで一対多の関係を持たせて
routes.rbに
resources :topics do
resources :posts
end
の様なルーティングを作り、post周りのビューのpathヘルパーをtopic_post_pathの様に変えました
http://localhost:3000/topics/1/posts へのアクセスはうまく行くのですが
http://localhost:3000/topics/1/posts/new へのアクセスは
Routing Error No route matches {:controller=>"posts", :format=>nil}
の様にエラーが出てしまいます
どこをどの様に変更したらhttp://localhost:3000/topics/1/posts/new でpostを作成できるでしょうか?
どなたか回答していただけたらうれしいです よろしくお願いします
0814nobodyさん2012/02/03(金) 18:00:44.99ID:???
new_topic_post_path(@topic)
もしくは
new_topic_post_path(topic_id: @topic.id)
みたいにしてないのでは
0815nobodyさん2012/02/03(金) 18:21:28.06ID:???
コマンドラインから
rake routes
実行して、できるパスを確認しよう
0816nobodyさん2012/02/03(金) 20:29:33.95ID:hJMEWrmo
>>814 >>815 お二方ご回答ありがとうございます!

色々試した結果、postsコントローラに @topic = Topic.find(params[:topic_id])
を作っていなかった事が原因みたいでした
リンク先のurlはセオリー道理に作れていたのにrouting error だったのですごく悩んでしまいました。
回答ありがとうございました。
0817nobodyさん2012/02/04(土) 08:28:37.17ID:Prkek0Dn
>>811
申し訳ありません、レスありがとうございました
調べてみます


>>810の「MySQLのメモリを大きくする」を行なってから
Railsがめちゃくちゃ重くなってしまいました

webrickサーバーでのテストでは
F5を2,3回押すだけでRuby1.8のCPU使用率が90%近くまで跳ね上がり1分近くフリーズします

ちょっと重めのTOP(以前はローカル環境なら1秒程度で表示)が、20秒ほどかかるようになってしまいました
更に10秒くらいの間Mysqldの使用率が100%に張り付きます

PHPmyadminから直でSQL打つと一瞬で帰ってきます

メモリ変更に関してはバックアップに戻したのですが速度は元に戻りません

原因がMysqlにあるのか、Rubyにあるのか、Railsにあるのかわからなくなってしまったのですが
どういった対処がとれますでしょうかorz


1.Apache+Passengerで起動してもページ表示時Rubyの使用率90%
2.このアプリを別サーバーに持って行くとサクサク動く

ということで、Mysqlとの接続周りで問題が発生している?
development.log production.logを見ても特にエラーは出てません
どこを確認すればよろしいですか?
よろしくお願いします
0818nobodyさん2012/02/04(土) 08:47:22.10ID:WPtHudN4
Focus 100% on your code, and never think about servers, instances, or VMs again.
0819nobodyさん2012/02/04(土) 08:49:46.88ID:???
なに、ローカル環境だけで重いってこと?
ログが肥大化してんじゃないの?

developmentなら再読み込みでCPU使用率急に上がるのは特に変じゃない。

以前は重くなかったって言ってるけど、「以前」というのが開発スタートしたてとかだったら、実装が悪い。
0820nobodyさん2012/02/04(土) 08:53:05.62ID:Prkek0Dn
>>818
ググッて来ましたが違うようです

>>819
ありがとうございます。
本番環境もローカルもダメです

本番サーバーでいきなりMysqlのメモリ増やす→あれなんか重い
ローカルで確認の為にMysqlのメモリ増やす→あれなんか重くなった


両方設定戻しても重さは元に戻らず
両方Productionで動かしても変わらないです
ログは定期的に消してます

”重くなった”は、2日前と比べてです
データ量も殆ど変わってないですし、別サーバー持ってくとサクサク動くので
Mysqlのメモリをいじったのが引き金になったようです
0821nobodyさん2012/02/04(土) 09:03:56.06ID:Prkek0Dn
すいません、今Sqliteで同じものを動かした所めちゃくちゃさくさく動きました
どうやら問題はMysqlにあるようです
そうなると、Mysqlスレになるのかな?

アドバイスありがとうございました
0822nobodyさん2012/02/04(土) 09:04:47.54ID:???
なんでただの英語ぐぐってるんだよ…
メモリの設定もいろいろあるから、どこを500MBに変えたかだな
0823nobodyさん2012/02/04(土) 09:12:14.59ID:Prkek0Dn
>>822


key_buffer?を増やしてみました
その後色々いじったので何がなにやら……

PHPMYadminで赤いところを見ると

Innodb_buffer_pool_reads 526 InnoDB がバッファプールの内容を利用できず、シングルページ読み込みを行わなければならなかった論理読み込みの回数
Handler_read_rnd_next  86 G データファイルの次の行を読み込んだリクエストの数。この値が高いのはテーブルスキャンを大量に実行しているためです。一般にこれはテーブルのインデックスが不適切か、クエリがインデックスを利用するように書かれていないことを意味します
Created_tmp_disk_tables 1,598 k ステートメント実行中にサーバがディスク上に自動生成した一時テーブル数。Created_tmp_disk_tables の値が大きい場合は tmp_table_size の値を増やしてディスク上ではなくメモリ上に一時テーブルを構築した方がよいかもしれません
Opened_tables 414 開いているテーブルの数。開いているテーブルが多い場合はおそらくテーブルキャッシュの値が小さすぎます

82Gのところがなんかおかしい気がします
0824nobodyさん2012/02/04(土) 11:37:03.61ID:CRUXYrsz
MySQLとrails同じサーバーで動かしてるの?
MySQLにメモリ割り当てすぎてスワップ使ってるとかなんじゃないかなぁ。
0825nobodyさん2012/02/04(土) 11:58:01.12ID:???
アプリのルートで表示させるページのコントローラーってどうするのが定石ですか?

今まではどこかのサンプルで見たIndexControllerって名前でずっとやってきてました。
root to: 'index#home'
みたいな感じで。
特に不都合はないですが、もっと良い方法とか命名とかありますか?
0826nobodyさん2012/02/04(土) 11:59:11.63ID:???
別にそれで何の問題もないのでは。
0827nobodyさん2012/02/04(土) 13:06:37.78ID:???
>>825
俺はmain#indexにしてる
0828nobodyさん2012/02/04(土) 13:46:13.35ID:???
>>812
config/environments/production.rbが設定ファイルで、
config.action_controller.page_cache_directory = "ここで設定"

参考) http://railsdoc.com/cookie_cache


>>823
状況がよくわからんので箇条書きで色々と書くね
鵜呑みにせずに参考程度にしてください

・インデックスをはってないのは間違いないし、そこが絶対にボトルネックになってると思う
>Handler_read_rnd_next  86 G から察するにインデックスを適切に張ってないのは間違いなくて、データを全スキャンしてる

・Railsには一つのSQLクエリごとに何秒かかったかをログにしてくれているのでそれを見る
 あなたの場合はこれをまず詳細に分析するべきだと思う
 表示はms(マイクロ秒)での表示 1000ms=1秒 適切なクエリなら数msから数十msで返って来ているはず
 インデックスを適切に張っていないと遅いクエリ(スロークエリ)が頻出しているはず

・MySQLのストレージエンジンにはInnoDBとMyISAMがある
 MySQL5.5以降はデフォルトがInnoDBで、それ以前のバージョンならMyISAM
 で、「MySQLに割り当てられるメモリを大きくする」という場合に、MyISAM使ってるのにInnoDBの割当メモリを大きくしても意味が無い 逆もしかり

以上です
とにかくインデックスきちんとすれば4Gもメモリ積んでるサーバーなら余裕で捌けるはずなので頑張ってください
0829nobodyさん2012/02/04(土) 16:07:59.57ID:Prkek0Dn
>>824
同じサーバーで動かしています
どうやらそのようでした

再起動したら少しましになりました

>>828
ありがとうございます。
InnoDBを使っていたので全く見当違いのメモリを増やしておりました
インデックスを貼ろうと思ったのですが、ちょっと初心者もいいとこでどこに貼っていいのか……

Railsの効率の悪いSQLを探知してくれるプラグイン?あったと思うのですが3になってから使えなくなってしまいまして……

0830nobodyさん2012/02/04(土) 17:05:32.58ID:s47e9LRe
とりあえずmysqlのスロークエリログくらい見ないと。
0831nobodyさん2012/02/04(土) 17:16:05.77ID:Prkek0Dn
>>830
ですね、痛感しました
しかし、スロークエリログを吐き出す設定にしているのにファイルが出力されません
なんででしょう

とりあえず色々いじってみたいと思います
0832nobodyさん2012/02/04(土) 19:18:04.98ID:???
>>831
バックアップしとけよ
あといきなり本番サーバさわるな
0833nobodyさん2012/02/05(日) 00:35:52.53ID:83n8dgCi
プリコンパイルしたファイルって
hogehoge**************************
みたいになりますが、application.jsという形で生成はされないですか?

アクセスのたびに毎回ライブコンパイルが走り困っております
0834nobodyさん2012/02/05(日) 02:48:02.82ID:???
railsとcakephp
初心者にはどちらが向いてますか?
railsの場合はレンタルサーバーの環境ごと考えなきゃいけないから
面倒くさいのかな?という認識
0835nobodyさん2012/02/05(日) 07:21:14.51ID:???
どっちも習得の手間はかわらないと思う。
使いたいサーバで選んだらいいんじゃない?
OSがWindowsでVMとか使う気ないならPHPの方が気楽に開発環境整えられるかもな。

Railsの場合は使えない鯖ではそもそも考えるだけ無駄だから
鯖が決まってないならそんなに悩む必要はないと思う。
0836nobodyさん2012/02/05(日) 09:32:04.84ID:5hDTMn6/
404 Blog Not Found:そろそろPHPに関して一言いっとくか
http://blog.livedoor.jp/dankogai/archives/50835571.html
0837nobodyさん2012/02/05(日) 10:13:56.63ID:???
ずいぶん古い記事をひっぱってきたな。
個人的にはRuby(っていうかRails)もPHPも両方触って気に入ったほう使えばいいと思うよ。
先のことを考えると両方触っといて損はないと思うし。
0838nobodyさん2012/02/05(日) 10:27:25.69ID:???
今からPHPはないだろ…
0839nobodyさん2012/02/05(日) 10:34:13.56ID:???
言語の一つや二つ覚えるのに時間の無駄とかないから。
気になる部分は全部検討するぐらいのフットワークの軽さが必要だと思うよ。
0840nobodyさん2012/02/05(日) 10:51:12.27ID:???
今までC, C++, Java, Perl, VB, Prolog, (PHP,) Rubyと触ってきたけどPHPだけは性に合わなかった
使えるけど使いたくない
0841nobodyさん2012/02/05(日) 11:01:19.14ID:???
PHPはうんこだと思うけど一応触った上でうんこと蔑むのが最低限の礼儀だと思う。

ただ頭数の揃えやすさやとりあえずの速さでいくとそう悪い言語じゃなくなっちゃうんだよな・・・
0842nobodyさん2012/02/05(日) 11:10:38.58ID:83n8dgCi
Pipelineのファイルをサーバーから直接返すのってどうやるん?
画像1個読み込むのにもRails呼ばれるのは重すぎやん
0843nobodyさん2012/02/05(日) 11:38:38.62ID:???
Webサーバ側でそのように設定する。
nginxとかApacheとかで
0844nobodyさん2012/02/05(日) 11:46:16.72ID:83n8dgCi
>>843
プリコンパイルすると

hoge.***********.js
とかになるやないですか?

でも、生成されるソースでは
application.css
とか
hoge_image.**********.png
になってるので

サーバーから呼んでも勿論存在しないと言われるのでRailsに一度投げるしか無い
って感じです

方法としては、ソースコード生成時に<img src="hoge_image.png">を<img src="hoge_image.************.png">
って手打ちする方法が一つ

そもそも、digestを付けないようにプリコンパイルするが一つ

だと思うのですがどっちも上手くいかんです

congig.assets.digest = false
にしてもtrueにしても効果ないし

きちんとimage_tagから画像呼んでもdigestが付加されないでござった
どうしようもないので、Assets以下をPublicに移動したら「そこにCss置くなks」って起動すらしてくれない



0845nobodyさん2012/02/05(日) 11:47:13.32ID:83n8dgCi
>でも、生成されるソースでは
>application.css
>とか
>hoge_image.png
>になってるので


でござった
0846nobodyさん2012/02/05(日) 12:03:52.32ID:83n8dgCi
なんか調べると、image_tagを使うと自動で後ろの-************:がくっつくらしいですね
image_tag使っても表示されないのはなぜなんでしょ……

そんな設定とかあります?
0847nobodyさん2012/02/05(日) 12:15:39.78ID:83n8dgCi
すんません自己解決です

Railsを途中で3.1→3.2にしたのが原因のようです
新しいの作ってフレームワーク部分以外移動したら全部動きました
連レスごめんなさい
08488252012/02/05(日) 14:14:38.14ID:???
>>826 >>827
ありがとうございます
なんかindexって名前に違和感をおぼえて
■ このスレッドは過去ログ倉庫に格納されています