Thursday, July 22, 2010

Used Honda Odyssey Minivan Shopping

In the process of looking for a minivan. I will be adding notes as I go.

First off I suggest reading this Wikipedia article all about Honda Odyssey minivans. It gives a breakout of each generation of the vehicle and also has more in depth information about the transmission issues mentioned frequently in connection with Honda Odysseys.

2001 Honda Odyssey
Recalls:

2002 Honda Odyssey
Recalls:

Reviews and Ratings:

Price Range: $5,900 - $7,000

2003 Honda Odyssey
Recalls:

Transmission Issues

From an article about the transmission problem: Honda's Unexpected Gear Shift
Of 1 million vehicles sold in the U.S. with those transmissions, Spencer said, Honda has replaced the transmissions in about 16,000, or 1.6%.
Cost to replace transmission: $3,000 - $4,000 at a Honda dealer.
Reason to replace transmission at a Honda Dealer: longer warranty on new transmission.

Motor Mount Issue
A number of consumer reviews mention they've needed to replace motor mounts around 90K miles. More information needed. May be good to ask specifically about this if you get a mechanic to inspect the vehicle prior to purchase.

Research Resources

Wednesday, July 21, 2010

The Ideal Rails Production Environment Log Level

I am learning all about Rails logs today. My objective is to determine the ideal log level to run a Rails Application in when it is in the Production Environment. The app currently runs in :info but this generates pretty hefty log files. We have a cron job setup to email the production.log contents every day. I've found that I tend to tune out repetitive emails--which is dangerous when it comes to server logs because it makes it easy to miss important messages when they come.

My first find in my quest was this article: Rails Logging Tips. It provided foundational knowledge of logging options as well some advanced logging pointers. I learned that the Rails log levels available to me are: debug, info, warn, error, and fatal. I also learned that Rails defaults to the "info" level when in the Production Environment. The section on Reducing Log File Size drew my attention. I decided to edit my config/environments/production.rb file to config.log_level = :warn. At first it looks like its going to do the trick, the log will only have warnings and errors in it from here out! But when I purposefully generate an application error I notice that the information logged about it is really not all that helpful. It does give me a backtrace. But I want to know what user actions caused the error so I can duplicate it (maybe this is possible with backtraces and I don't know it yet). The information I want is a timestamp and the url or request that was made resulting in the error. This information was available in the :info log level.

Next order of business, trying out all of the log levels to see if a different one will suit me better. Note: When changing log levels in your production.rb file you have to restart you application for the change to take effect. I couldn't remember how to restart my application. Our server is running Passenger. This wiki article: Restarting a Rails Application Using Passenger gave me the magic command I was looking for (touch /tmp/restart.txt).

Wow! :debug gives some pretty handy info. Including SQL statements. After poking around a bit more I decide none of the log levels do what I want. I'd like to get the information displayed in the :debug or :info log levels but only when the message is :warn or higher. I remember that the Rails Logging Tips article mentioned something about filtering log messages. Maybe I could set the log level to :info and apply some sort of filter. My Google searches on this don't turn up any promising leads. But I do happen upon a few blog posts about adding timestamps to the Rails logger. There are two different ways to do it. One way is to extend the logger class the other way is to initiate your own logger class. Apparently Rails changed up the logger in version 2.x.

How to modify the logger class in Rails 1.2.x:

How to modify the logger class in in Rails 2.x:

How to create your own custom logger in Rails 2.x

I add the lines of code to the end of my environment.rb file and voila I have timestamps. :)

I am not quite ready to jump into creating a custom logger. I am still interested in possibly filtering the :info log messages. Maybe I could get it to disregard logs for requests that return an status 200 ok.

Two more parting nuggets I dug up while researching this. How to rotate your rails logs and how to log to STDOUT when using the console.