Thursday, April 15, 2010

Multiple Database Connection in Ruby on Rails

Multiple Database Connection in Ruby on Rails


Ruby on Rails sets up the connection depending on your application’s database.yml file. In database.yml file you set up configration environmentwise.

As I active record allow to access single database but you want to access more than one databases than it required to have multiple connection at a time. Now you think that how this possible. So Rails provides gem to implement you need. Follow the below steps:

1. Install gem
sudo gem install magic_multi_connections

2. After installing gem there is one patch required in connected.rb(/usr/lib/ruby/gems/1.8/gems/magic_multi_connections-1.2.1/lib/magic_multi_connections/connected.rb)
replace

raise NameError.new ( "uninitialized constant # (const_id)") unless
target_class

with

return unless target_class

3. Now edit the config/database.yml file to create some more databases:

development:

adapter: mysql
encoding: utf8
database: app_development
username: tester
password: testerpwd
host: localhost

development_clonex:

adapter: mysql
encoding: utf8
database: appx_development
username: tester
password: testerpwd
host: localhost

Default in rails main application database has read-write permission , and the other databases than you default application database have read-only pemission.

4. Now in environment.rb ,you have to add end of environment.rb:

require 'magic_multi_connections'
connection_names = ActiveRecord::Base.configurations.keys.select do |name|
name =~ /^#{ENV['RAILS_ENV']}_clone/
end

@@connection_pool = connection_names.map do |connection_name|
Object.class_eval <<-EOS
module #{connection_name.camelize}
establish_connection :#{connection_name}
end
EOS

connection_name.camelize.constantize
end

5. Next, you create same clone for databases which you have access by following below steps.

cp config/environments/development.rb config/environments/development_clonex.rb

6. Now, You want to migrate the new databaseclone than only follow below step.

rake db:migrate RAILS_ENV=development_clonex

7. Lets check whether multiple pool created or not and we are able to access data from different database or not through console.
$ ruby script/console

· Check for connection pool

>> @@connection_pool
=> [DevelopmentClonex]

As we create clonex than it listed here. If you create more than one then you have array with multiple clone.

· Now access table from other database by
>> DevelopmentClonex::Model_name.model_methods

Example: @users = DevelopmentClonex::User.find(:all)
puts'qadexnsdev', @users.size ##It access database 1
@uses = User.find(:all)
puts'qadex_test', @uses.size ##It access database 2
Now use other features of multi_magic_connection.

Hope this article will help you. If you have any suggestion or query than just leave comment here.

No comments: