Немного пред истории. После обновления приложения неожиданно в логе появились ошибки вида ActiveModel::MissingAttributeError: missing attribute: произвольное свойство объекта.
Проблема первая первая ActiveModel::MissingAttributeError: missing attribute
Немного о окружение
две базы 1 мастер для записи и 1 slave для чтения
Фреймворк Ruby On Rails 3
Гем для деления коннектов ar-octopus
Сервер Passenger
все дело оказалось банально в настройке:
verify_connection: true
Почему это работало раньше и вдруг перестало не совсем ясна, но добавление строчки немного помогло
octopus:
replicated: true
verify_connection: true
environments:
- production
Почему немного? остались еще ошибки.
Проблема вторая Lost connection to MySQL server during query
Ошибка возникала на произвольных запросах. Для решения проблемы достаточно добавить скрипт инициализация для Passenger.
config/initializers/phusion_passenger.rb
if defined?(PhusionPassenger)
PhusionPassenger.on_event(:starting_worker_process) do |forked|
if forked
# the following is *required* for Rails + "PassengerSpawnMethod smart".
if defined?(ActiveRecord::Base)
# force reconnect to "master" connection.
ActiveRecord::Base.connection_pool.disconnect!
# force reconnect to our octopus "slave" pools. This may include the "master" pool above.
if defined?(Octopus)
ActiveRecord::Base.connection_proxy.instance_variable_get(:@shards).each { |name, pool| pool.disconnect! }
end
end
end
end
end