【RoR】Ruby on Rails Part13
レス数が900を超えています。1000を超えると表示できなくなるよ。
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/
0814nobodyさん
2012/02/03(金) 18:00:44.99ID:???もしくは
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色々試した結果、postsコントローラに @topic = Topic.find(params[:topic_id])
を作っていなかった事が原因みたいでした
リンク先のurlはセオリー道理に作れていたのにrouting error だったのですごく悩んでしまいました。
回答ありがとうございました。
0817nobodyさん
2012/02/04(土) 08:28:37.17ID:Prkek0Dn申し訳ありません、レスありがとうございました
調べてみます
>>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:WPtHudN40819nobodyさん
2012/02/04(土) 08:49:46.88ID:???ログが肥大化してんじゃないの?
developmentなら再読み込みでCPU使用率急に上がるのは特に変じゃない。
以前は重くなかったって言ってるけど、「以前」というのが開発スタートしたてとかだったら、実装が悪い。
0820nobodyさん
2012/02/04(土) 08:53:05.62ID:Prkek0Dnググッて来ましたが違うようです
>>819
ありがとうございます。
本番環境もローカルもダメです
本番サーバーでいきなりMysqlのメモリ増やす→あれなんか重い
ローカルで確認の為にMysqlのメモリ増やす→あれなんか重くなった
両方設定戻しても重さは元に戻らず
両方Productionで動かしても変わらないです
ログは定期的に消してます
”重くなった”は、2日前と比べてです
データ量も殆ど変わってないですし、別サーバー持ってくとサクサク動くので
Mysqlのメモリをいじったのが引き金になったようです
0821nobodyさん
2012/02/04(土) 09:03:56.06ID:Prkek0Dnどうやら問題はMysqlにあるようです
そうなると、Mysqlスレになるのかな?
アドバイスありがとうございました
0822nobodyさん
2012/02/04(土) 09:04:47.54ID:???メモリの設定もいろいろあるから、どこを500MBに変えたかだな
0823nobodyさん
2012/02/04(土) 09:12:14.59ID:Prkek0Dnえ
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:CRUXYrszMySQLにメモリ割り当てすぎてスワップ使ってるとかなんじゃないかなぁ。
0825nobodyさん
2012/02/04(土) 11:58:01.12ID:???今まではどこかのサンプルで見たIndexControllerって名前でずっとやってきてました。
root to: 'index#home'
みたいな感じで。
特に不都合はないですが、もっと良い方法とか命名とかありますか?
0826nobodyさん
2012/02/04(土) 11:59:11.63ID:???0828nobodyさん
2012/02/04(土) 13:46:13.35ID:???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同じサーバーで動かしています
どうやらそのようでした
再起動したら少しましになりました
>>828
ありがとうございます。
InnoDBを使っていたので全く見当違いのメモリを増やしておりました
インデックスを貼ろうと思ったのですが、ちょっと初心者もいいとこでどこに貼っていいのか……
Railsの効率の悪いSQLを探知してくれるプラグイン?あったと思うのですが3になってから使えなくなってしまいまして……
0830nobodyさん
2012/02/04(土) 17:05:32.58ID:s47e9LRe0831nobodyさん
2012/02/04(土) 17:16:05.77ID:Prkek0Dnですね、痛感しました
しかし、スロークエリログを吐き出す設定にしているのにファイルが出力されません
なんででしょう
とりあえず色々いじってみたいと思います
0833nobodyさん
2012/02/05(日) 00:35:52.53ID:83n8dgCihogehoge**************************
みたいになりますが、application.jsという形で生成はされないですか?
アクセスのたびに毎回ライブコンパイルが走り困っております
0834nobodyさん
2012/02/05(日) 02:48:02.82ID:???初心者にはどちらが向いてますか?
railsの場合はレンタルサーバーの環境ごと考えなきゃいけないから
面倒くさいのかな?という認識
0835nobodyさん
2012/02/05(日) 07:21:14.51ID:???使いたいサーバで選んだらいいんじゃない?
OSがWindowsでVMとか使う気ないならPHPの方が気楽に開発環境整えられるかもな。
Railsの場合は使えない鯖ではそもそも考えるだけ無駄だから
鯖が決まってないならそんなに悩む必要はないと思う。
0836nobodyさん
2012/02/05(日) 09:32:04.84ID:5hDTMn6/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:???0839nobodyさん
2012/02/05(日) 10:34:13.56ID:???気になる部分は全部検討するぐらいのフットワークの軽さが必要だと思うよ。
0840nobodyさん
2012/02/05(日) 10:51:12.27ID:???使えるけど使いたくない
0841nobodyさん
2012/02/05(日) 11:01:19.14ID:???ただ頭数の揃えやすさやとりあえずの速さでいくとそう悪い言語じゃなくなっちゃうんだよな・・・
0842nobodyさん
2012/02/05(日) 11:10:38.58ID:83n8dgCi画像1個読み込むのにもRails呼ばれるのは重すぎやん
0843nobodyさん
2012/02/05(日) 11:38:38.62ID:???nginxとかApacheとかで
0844nobodyさん
2012/02/05(日) 11:46:16.72ID:83n8dgCiプリコンパイルすると
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:83n8dgCiimage_tag使っても表示されないのはなぜなんでしょ……
そんな設定とかあります?
0847nobodyさん
2012/02/05(日) 12:15:39.78ID:83n8dgCiRailsを途中で3.1→3.2にしたのが原因のようです
新しいの作ってフレームワーク部分以外移動したら全部動きました
連レスごめんなさい
0849nobodyさん
2012/02/05(日) 18:42:15.47ID:yrFQBJuzIndexControllerだったらだいぶマシ。
0850nobodyさん
2012/02/05(日) 22:06:59.42ID:???サーバの画面でenter押せば進むんだけどなんでだろう。
0851nobodyさん
2012/02/05(日) 23:41:33.56ID:???0852nobodyさん
2012/02/06(月) 00:56:50.86ID:???0853nobodyさん
2012/02/06(月) 01:02:33.33ID:???apache再起動の方が10倍くらい早い
おれだけ?
0854nobodyさん
2012/02/06(月) 12:39:14.01ID:6CAJ3kKyWinで開発していたアプリを
本番環境を想定した仮想CentOS上で動かそうとしたんですけど
winでは動いていたものが、CentOS上だと
ActionView::Template::Error (invalid byte sequence in UTF-8):
というエラーをはいて動かなくなってしまいました。
エラー箇所はapp/views/layouts/application.html.erbの
<%= stylesheet_link_tag 'application', :media => 'all' %>
<%= javascript_include_tag "application" %>
なんですけど、この二行をコメントアウトすると、表示は崩れますが動きます。
文字コードが何かおかしいのかとも思い
app/assets/stylesheets
app/assets/javascripts
内も調べたんですが、これといっておかしなところも見つかりませんでした。
仮想CentOS上で適当に作ったアプリは普通に動くんですけど
これってどのような原因が考えられるのでしょうか?
環境はruby1.9.3、rails3.2.1です。
0855nobodyさん
2012/02/06(月) 13:50:54.28ID:tyxpRyp2書いてある通り
CSSやJSがUTF8になってない
0856854
2012/02/06(月) 14:02:57.33ID:???app/assets/stylesheets
app/assets/javascripts
内のファイルを全部エディタで開いてみる限りUTF8(BOM無し)のようですし
ディレクトリ内を試しに全削除しても同様のエラーが出てしまいます。
それとも、もっと違ったところが間違っているのでしょうか?
0858nobodyさん
2012/02/06(月) 15:50:12.13ID:???もしくは precompileしたのが残ってる。
0860854
2012/02/06(月) 16:41:25.32ID:???おっしゃるとおり、precompileしたものはしていて消しててなかったです。
public/assets
.sass-cache
などそれっぽいものを削除して再起動してみたのですが同じエラーが
precompileは上記以外にも消すものってありますか?
0861nobodyさん
2012/02/06(月) 17:27:45.73ID:???0862nobodyさん
2012/02/06(月) 17:41:08.00ID:???はい、そこらへんは確認しました。
あと、さきほどprecompileのヒントをいただいたので
試しにrake assets:precompile --traceしてみたら
** Execute assets:precompile:primary
rake aborted!
invalid byte sequence in UTF-8
/usr/local/rvm/gems/ruby-1.9.3-p0/gems/hike-1.2.1/lib/hike/index.rb:80:in `block in entries'
/usr/local/rvm/gems/ruby-1.9.3-p0/gems/hike-1.2.1/lib/hike/index.rb:80:in `reject'
/usr/local/rvm/gems/ruby-1.9.3-p0/gems/hike-1.2.1/lib/hike/index.rb:80:in `entries'
みたいに出ました。
hike/index.rb:80を見てみたんですが自分の能力では、どうしてなのかちょっとわからなかったです。
0863nobodyさん
2012/02/06(月) 18:07:42.98ID:???resources :samples
によって定義されたルートたちを
"admin/samples"のようなURLに一括して置き換える方法ってありますか?
できれば元のルートも無効にしたいのですが。
0864863
2012/02/06(月) 18:13:46.83ID:???resources :samples, :path => "admin/samples"
と変更することでうまく行きました。
0865nobodyさん
2012/02/06(月) 20:15:58.58ID:FI1AngH7>hike-1.2.1/lib/hike/index.rb
ブロックの中で例外になってて、ブロックの中身は
entry.to_s =~ /^¥.|~$|^¥#.*¥#$/
entryはPathname.new(path)の中にある個々のファイルの名前文字列。
正規表現のほうはスクリプトエンコーディングになってるはず。
ファイル名のエンコーディングって面倒くさそうだな。
とりあえずブロックの中にいるときにentryのエンコーディングやバイト列を
検分してみたらどうか。
0866nobodyさん
2012/02/06(月) 21:42:42.42ID:???ありがとうございます。
@entries[key] ||= Pathname.new(path).entries.reject { |entry|
p entry.to_s
entry.to_s =~ /^\.|~$|^\#.*\#$/
}.sort
にしたら
"images"
"mark.png"
"h1.png"
"favicon.ico"
"blank.png"
"ico.ico"
"\x83R\x83s\x81[ \x81` h2.png"
と出力されて一番下の名前文字列でエラーが出ているようです。
なんでこんな変な文字が入り込んでいるのか。。
ちなみに>>854のも
<%= stylesheet_link_tag %>
にするとエラーが出ず
<%= stylesheet_link_tag 'foo' %> #fooは存在しないファイル名
とするとinvalid byte sequence in UTF-8が出ます。
ファイル名を呼び出そうとすると何故かエラーになります。
0867nobodyさん
2012/02/06(月) 22:02:32.25ID:FI1AngH7"¥x83R¥x83s¥x81[ ¥x81` h2.png".force_encoding('Shift_JIS').encode('UTF-8')
=> "コピー 〜 h2.png"
これってどう対応するベッキー?
0868854
2012/02/06(月) 22:46:51.46ID:???あわぁぁ、そうだったのかー!
そんなファイルを作ったのすっかり忘れていました。。
ありがとうございます。
"コピー 〜 h2.png"を消すとweb表示もprecompileもうまくいきました。
それにしてもstylesheet_link_tagやjavascript_include_tagで画像まで読み込んでいるんですね。
app/assets/stylesheets
app/assets/javascripts
はさんざん検証したんですが、
app/assets/images
は全くのノーマークでした。
でも2日間悩んでいたものが皆さんのおかげで動くようになりました。
本当にありがとうございました。
0869nobodyさん
2012/02/06(月) 22:47:53.84ID:???アップロードしたものなら、日本語入らないようにする、もしくはアップロード後UTF8にする。
そうでないなら普通にファイル名をUTF8にする。
0870nobodyさん
2012/02/06(月) 23:25:29.54ID:FI1AngH70872nobodyさん
2012/02/07(火) 07:50:38.92ID:???apache再起動という全然違うものと比べてるのもおかしい話。
あとは単に自分のマシンが遅いんじゃないのかな。
あとWindows使ってるとか。rubyが1.8系とか。
0873nobodyさん
2012/02/07(火) 07:51:21.34ID:???0874nobodyさん
2012/02/07(火) 17:21:53.23ID:T0i5g/PH編集が完了したらロックかけて、ページキャッシュにしたいのだけど
どうやってすればいいのか……
0875nobodyさん
2012/02/07(火) 20:51:41.88ID:???Twitter Bootstrapが大幅バージョンアップ!して凄まじいことに・・・ | IDEA*IDEA
http://www.ideaxidea.com/archives/2012/02/twitter_bootstrap_v2.html
https://github.com/seyhunak/twitter-bootstrap-rails
gem 'twitter-bootstrap-rails'
https://github.com/twitter/bootstrap/
0876nobodyさん
2012/02/08(水) 06:55:10.76ID:???ubuntuとgmateで満足してたんですけど、Windowsならvimかaptanaですか?
0877nobodyさん
2012/02/08(水) 07:45:14.37ID:???好みでgmateをvimかemacsに変える程度で。
自分の見た範囲だとRailsやってる会社はMacが多かった。
事務方以外は全員Macとかザラ。
フリーランスの人とかはほぼ全員Mac。
たまにLinux。
Windowsでもどうせ仮装マシンにLinux入れて、ターミナル繋いで使うし。
0878nobodyさん
2012/02/08(水) 08:06:30.84ID:???0879nobodyさん
2012/02/08(水) 09:44:42.41ID:???ZENBOOKが欲しくなっちゃってきいてみたのです
Mac+textMate人気ですよね
MBAにしようか悩む
0880nobodyさん
2012/02/08(水) 12:12:49.63ID:???なんかいろいろ妙だなそれは…。
本番と同じにするという意味でVMにLinuxまでは分かるとして、単にターミナルで繋げばええやん。
TextMateは2.0待った方が良いのでは。
日本語出せても変なので。
0881nobodyさん
2012/02/08(水) 12:25:39.46ID:v8bninoxRUby1.9にしたほうが早くなる?
0883nobodyさん
2012/02/08(水) 15:26:37.24ID:???878だけど
ターミナルから動かすviよりMacVimの方が色々と楽なので
Linux使ってる理由はご明察
0884nobodyさん
2012/02/08(水) 18:45:18.40ID:???0885nobodyさん
2012/02/08(水) 21:11:23.84ID:5Y0ckqblブラウザでページを見るとログに
cache: [GET /] miss
cache: [GET /ルート] miss
みたいに出るのですが、これはキャッシュ関係の設定に
何か問題とかがあるのでしょうか?
0886nobodyさん
2012/02/08(水) 22:33:39.50ID:???rake db:fixtures:load FIXTURES=hoge
でhoge.csvを読み込ませたいのだけれど、No such file or directory - /test/fixtur
es/hoge.yml
ってなります。ファイルは配置してあるんですが、ymlファイルを探してるようで、csvを読んでくれません。
どうしたらcsvを読んでくれますか?
ruby 1.9.3 rails 3.2.1です。
0887nobodyさん
2012/02/08(水) 22:38:34.82ID:???どうしても使いたかったらデータベースからインポートするのが早いとおもう
0889nobodyさん
2012/02/09(木) 09:44:07.71ID:???何使ってるか知らないけど、画像ファイルが見つかってない。image_tag に空文字列渡したりするとそうなる。
0890nobodyさん
2012/02/09(木) 09:51:25.59ID:???3だからと言ってそんなに変わらない。
あちこちにまとめ的な記事あるし、基本は「rspec 写経」でググって出てくるのをそのままやる。
0891nobodyさん
2012/02/09(木) 11:00:16.66ID:???http://blog.tkmr.org/tatsuya/show/268-ruby-on-rails-10-tips
findメソッドはパワフルだけど基本SELECT * FROMなので場合によっては:selectで必要なカラムだけ読み込む、また:limitや:offsetを活用する
ごくごく基本的な Ruby on Rails のパフォーマンスチューニング
http://jijixi.azito.com/cgi-bin/diary/index.rb?date=20071114
:conditions オプションでキーに使われるようなカラムにはインデックスを作成すべし
:selectで取得するカラムを絞ったらパフォーマンスが倍に
http://brass.to/blog/active_record_select_option.html
レコード件数は110万件くらい
カラム数は30程度
インデックスは効いている(explainで確認済み)
Rails で MySQL を使うときの注意点 | METAREAL
http://www.metareal.org/2007/07/24/notes-on-rubyonrails-with-mysql/
SQL を二段階に分けるといい
まず、最初の SQL でレコードの ID だけを SELECT する(int だけなので、このときの一時テーブルはメモリ上に作られる)
次に、その ID で必要な TEXT や BLOB を SELECT するんだ(これは ID による単純な検索なので一時テーブルは使われない)
MySQLパフォーマンスチューニングのためのインデックスの基礎知識
http://d.hatena.ne.jp/kiyo560808/20101117/1289952549
これを知っておかないと、MySQLサーバの再起動でDBデータの不整合が発生するかもしれません! - よかろうもん!
http://d.hatena.ne.jp/interu/20100817/1282041840
0892nobodyさん
2012/02/09(木) 11:01:32.22ID:???http://d.hatena.ne.jp/tkng/20080811/1218442298
SpecialWarningというプラグイン
http://d.hatena.ne.jp/authorNari/20090205/1233840189
N+1問題などを監視してパフォーマンスを改善するRailsプラグインBullet
http://blog.digital-squad.net/article/149685338.html
複合キー
compositekeys ActiveRecord Composite Primary Keys
http://compositekeys.rubyforge.org/
Martin Fowler's Bliki in Japanese - エンタープライズRails
http://capsctrl.que.jp/kdmsnr/wiki/bliki/?EnterpriseRails
MOONGIFT: ? Railsを見える化「RailRoad」:オープンソースを毎日紹介
http://www.moongift.jp/2007/07/railroad/
Unexpected Run: Rails3.0でモデルのER図を簡単に出力する方法
http://sawada0903.blogspot.com/2010/10/rails30er.html
「has_many :through の関連テーブル名には、relation_ の接頭辞を用いる」
http://d.hatena.ne.jp/hichiriki/20100622#1277195810
0893nobodyさん
2012/02/09(木) 11:54:06.77ID:???英国政府、新ポータルGov.ukをクラウド、アジャイル、Rubyで開発。ソースはGithubで公開 − Publickey
http://www.publickey1.jp/blog/12/govukrubygithub.html
https://github.com/alphagov/
https://www.gov.uk/
0894nobodyさん
2012/02/09(木) 13:23:36.79ID:???http://togetter.com/li/254340
0895884
2012/02/09(木) 15:46:45.01ID:???ありがとうございます
このスレでも何度かrspecって出てきてますね
標準のやつより良いんでしょうか
試してみます
0896nobodyさん
2012/02/09(木) 18:41:05.78ID:???0897nobodyさん
2012/02/09(木) 18:53:25.76ID:???http://code.google.com/p/gchartrb/
chart
http://blog.deepak.jois.name/search/label/gchartrb
http://gchartrb.rubyforge.org/
0898nobodyさん
2012/02/10(金) 15:50:30.54ID:???単純にcreateのマイグレーションファイルを削除してrake db:resetとかで良いんでしょうか?
0899nobodyさん
2012/02/10(金) 16:47:44.94ID:???0900nobodyさん
2012/02/10(金) 21:15:56.80ID:7+rOXV6+def self.up
drop_table :hogehoge
end
ってマイグレーションを作る
0901nobodyさん
2012/02/10(金) 21:20:36.67ID:tpz3bLVT最近だとup/downはインスタンスメソッドになってる。
downで空テーブルを作成して過去のマイグレーションまで戻れるようにするか
IrreversibleMigrationを投げて戻れないようにするといいんじゃないですかね。
0902nobodyさん
2012/02/10(金) 23:19:25.62ID:Kq6N05B2どうすれば早くなります?
RubyがCPU100%になってるので、DB周りでは無いと思うのですが
フレームワーク部分を高速化する方法ありませんか?
0903nobodyさん
2012/02/10(金) 23:24:37.69ID:???0904nobodyさん
2012/02/10(金) 23:26:29.38ID:Kq6N05B2確かにそれはそうなんですが
お金が……
サクラの4GBプラン使ってるのでもうしばらくは大丈夫だと思うのですが……
サイトはユーザー数2300人、同時接続が多い時で600人程度のSNSです
0905nobodyさん
2012/02/11(土) 01:34:10.27ID:???もしくはページの内容。
あとテーブルにインデックス張ってないとか。
他にはセッションをDBにしてたりとか。
0906nobodyさん
2012/02/11(土) 02:19:50.84ID:???railsで作ってる場合は
assets/jquery.js
って出てきて恥ずかしいったら
ありゃしないw
0907nobodyさん
2012/02/11(土) 07:09:52.27ID:???CPUってだけじゃどうしようもない
テストで時間がかかってる処理を見つけるとか
書き込みなのか読み込みなのかくらい分からないと対処できないのでは
0908nobodyさん
2012/02/11(土) 10:43:35.38ID:???SQL に適切にインデックス張ってない
キャッシュすべき場所をキャッシュしていない
無駄なデータを引きすぎてる
http://d.hatena.ne.jp/secondlife/20110919/1316438465
0909nobodyさん
2012/02/11(土) 10:49:44.48ID:94FnLoOGインデックスは貼ってます
セッションはクッキーです
多分ページの内容か実装ですね
>>907
時間がかかるのは書き込み<<<<読み込みです
というのもSNSなので読み込まれる量が書き込まれる量の何十倍にもなるので……
>>908
それは既に読んでみたのですが
あまり具体性が無かったので
データは必要なものだけひっぱってますし、Find_by_sqlも行なっています
変更が緩やかなものはキャッシュしてsweeperかけてます
0910nobodyさん
2012/02/11(土) 13:15:56.55ID:???N+1 クエリー問題を解消する
http://www.ibm.com/developerworks/jp/opensource/library/os-railsn1/
現実の世界の Rails、第 3 回: ActiveRecord を最適化する
一般的なパフォーマンスの問題を解決する
http://www.ibm.com/developerworks/jp/web/library/wa-rails3/
eager loadingって何? - おもしろWEBサービス開発日記
http://d.hatena.ne.jp/willnet/20090303/1236093728
0911nobodyさん
2012/02/11(土) 13:22:20.40ID:???http://dev.ariel-networks.com/articles/workshop/rails-activerecord/
[Rails] query-reviewerでRailsアプリのボトルネックを見つける
http://d.hatena.ne.jp/tkng/20080811/1218442298
SpecialWarningというプラグイン
http://d.hatena.ne.jp/authorNari/20090205/1233840189
N+1問題などを監視してパフォーマンスを改善するRailsプラグインBullet
http://blog.digital-squad.net/article/149685338.html
0912nobodyさん
2012/02/11(土) 14:26:30.53ID:???Rails で MySQL を使うときの注意点 | METAREAL
http://www.metareal.org/2007/07/24/notes-on-rubyonrails-with-mysql/
SQL を二段階に分けるといい
まず、最初の SQL でレコードの ID だけを SELECT する(int だけなので、このときの一時テーブルはメモリ上に作られる)
次に、その ID で必要な TEXT や BLOB を SELECT するんだ(これは ID による単純な検索なので一時テーブルは使われない)
0913nobodyさん
2012/02/11(土) 20:08:10.98ID:???生産性の違いってどのくらいあるのでしょうか?
お手軽なものを作るなら、コーディング量が少なくて住むRoR、
パフォーマンスや、セキュリティ要件が厳しい場合は、Spring等が
一般的なのでしょうか??#言語によるパフォーマンスはあまり
気にしなくてもよい、とかの記事も見かけます
開発要員の集めやすさ等は考慮外として、それなりのスキルレベルを
持った人だけで作成した場合の生産性についてを知りたいと思っています。
(ある程度、規模が大きい場合は、あまり変わらない?)
レス数が900を超えています。1000を超えると表示できなくなるよ。