I'm trying to upgrade our production server to rails 2. I've already
done this on my dev machine (osx) and it worked fine. But now, with
everything at the same version, but running in production mode, the
production machine - a CentOS5 box - is getting loads of:
ActiveRecord::StatementInvalid (Mysql::Error: Lost connection to MySQL
server during query
errors.
i"ve looked around but not found any valid reason why this should be
happening. the mysql is version 5.0.22. Ruby 1.8.6 rails 2.0.2.
Without solving this I guess we are going back to Rails 1.2.6, but the
real problem is that it is causing my boss and team to question the
entire stability of Rails!
I've just set the server to run in development mode and it works a
treat!!! What is up with that?
I'm trying to upgrade our production server to rails 2. I've already
done this on my dev machine (osx) and it worked fine. But now, with
everything at the same version, but running in production mode, the
production machine - a CentOS5 box - is getting loads of:
ActiveRecord::StatementInvalid (Mysql::Error: Lost connection to MySQL
server during query
errors.
i"ve looked around but not found any valid reason why this should be
happening. the mysql is version 5.0.22. Ruby 1.8.6 rails 2.0.2.
Without solving this I guess we are going back to Rails 1.2.6, but the
real problem is that it is causing my boss and team to question the
entire stability of Rails!
I've just set the server to run in development mode and it works a
treat!!! What is up with that?
what else have you tried?
you tried running in production mode locally?
you tried "ruby script/console production" on the box?
is this mongrel and apache?
or what?
is it every query?
or just some special long queries?
I think this is more of an ActiveRecord problem, because I was getting the same thing when I was using my IRC bot to log channels into a database through ActiveRecord. It usually happened for no apparent reason, but every few mintues it would drop a query, very annoying. Switched over to sqlite3 which seemed to work fine, but I’m guessing you don’t want to do this.
The only thing I can suggest is changing database servers, perhaps to postgres?
Correct, I perhaps did not give enough details.
From the console in production mode on that machine it works fine.
It is from the mongrel that it doesn't. It is essentially every query
from the mongrel, as far as I can tell. Just trying something now, it
is actually failing on occasion, in mongrel, even in development.
I've never seen these errors before:
!\ FAILSAFE /!\ Fri May 16 08:22:19 +0200 2008 Status: 500 Internal
Server Error
You have a nil object when you didn't expect it!
The error occurred while evaluating nil.all_hashes /usr/local/lib/
ruby/gems/1.8/gems/activerecord-2.0.2/lib/active_record/
connection_adapters/mysql_adapter.rb:482:in `select'
And the same query that I get this on:
ActiveRecord::StatementInvalid (Mysql::Error: Lost connection to MySQL
server during query:
I can run from the console.
So it definitely seem to be how mongrel is connecting to mysql. I am
not using the mysql gem (I wasn't before under 1.2.6 either) I am
connecting with the builtin mysql adaptor.
And the same query that I get this on:
ActiveRecord::StatementInvalid (Mysql::Error: Lost connection to MySQL
server during query:
I can run from the console.
So it definitely seem to be how mongrel is connecting to mysql. I am
not using the mysql gem (I wasn't before under 1.2.6 either) I am
connecting with the builtin mysql adaptor.
The pure ruby mysql stuff is completely obsolete. Give the gem ago.