What are some general strategies for handling caching in a situation
Fragment caching sounds like the way to go.
For index views, I cache my "standard" data on a per row basis, but not
the edit/destroy links, as those depend on the user viewing the data and
their rights/permissions. The caching still helps with performance
since the "standard" data includes columns assembled from other models
in the database, and I don't use eager loading.
Naming your fragments specifically makes the cache management easier in
a complicated case (I use a modeltype.id.cachetype naming scheme like
project.1.show, project.1.relateds, project.1.related.scenarios, etc).
I wouldn't bother caching the banner.
You could cache all but the voting link on the index view (just make
that the first or last item on the row for simplicity).
I wouldn't cache your sidebar, as it would change frequently (unless it
can be broken into chunks like profile, recent this, recent that).
My sidebar in a 'show' method shows all the models related to the
current model grouped by model type (a project can have related
scenarios, images, applications, modules, and areas). I cache the whole
'related' sidebar, as well as the sidebar components -- related models
of type X. When a new scenario gets related to a project, for example,
that expires the project's 'related scenarios' fragment, and the overall
'related models' fragment. Next time the project is viewed, the missing
'related models' fragment means that it has to check each related model
fragment. In this case only the related scenarios would have to be
re-read and a new cache fragment generated -- the other 4 fragments are
All that kind of work and logic is coded in a GenericModel class that
sits between ActiveRecord::Base and my real models like Project,
Scenario, etc, so it's easy to have new models adopt the caching