railsでコメント数の実装の悩み - komagataのブログ
コメント欄で色々アドバイスいただきました。ありがとうございます。
そもそも独立した二つの問題を一度に扱っていました。
- count数が遅い問題。
削除時のdependent: destory
が遅い問題。
counter_cacheやredis云々は1の話で僕の直近の問題である2とは関係無いですね。
2についてはdependent: :delete_all
使え!で答えかと思います。(user → post → commentのように多段になってる場合はdelete_allではcallbackが動かないので手でやるべき)
1の方が大きなサービスを作っている方々が気になる問題かと思いますが怖話の規模ではconditional_counter_cacheで十分なので問題になったら考えたいと思います。
逆にdependent: destroy
って面倒な処理が宣言的に書けてスゴイなとおもいます。この自動感を追い求めてDBのトリガーとかに解決策を見出してしまうと筋悪臭がすごいので素直に手で書きます。