0

我正在开发一个小型 Rub​​y 程序,该程序将连接到远程 MySQL Bugzilla 数据库,执行记录查询,并每天将这些记录的详细信息通过电子邮件发送给一个组。

到目前为止,我已经能够通过 SSH 连接到数据库服务器并使用 net-ssh 执行命令。这是一个例子:

require 'net/ssh'

Net::SSH.start("db.example.com", "sroach", :password => "secret") do |ssh|
result = ssh.exec!("ls -l")
puts result
end

那输出就好了。

使用 ActiveRecord 3.0.3,我想测试该establish_connection方法,因此我建立了与本地 MySQL 数据库的连接,并且能够使用 ActiveRecord 执行命令。例子:

require 'active_record'

ActiveRecord::Base.establish_connection(
    :adapter  => "mysql2",
    :host     => "localhost",
    :database => "list_tool_development",
    :username => "my_username",
    :password => "secretpassword"
)

class MailingList < ActiveRecord::Base
end

MailingList.first  #=> Successfully retrieves first record from the table

所以,我遇到麻烦的地方是将它们整合在一起并将其应用到我的远程 MySQL 数据库中。到目前为止,这是我最好的尝试:

require 'net/ssh'

Net::SSH.start("db.example.com", "sroach", :password => "secret") do |ssh|
ssh.forward.local(3307, "127.0.0.1", 3306)
ssh.loop { true }
end

但所做的只是让我的 IRB 会话挂起(这可能是完全正常的......不知道)。如果挂起正常的,我打开了一个新的 IRB 会话并尝试建立与远程数据库的连接,如下所示:

require 'active_record'

ActiveRecord::Base.establish_connection(
    :adapter => "mysql2",
    :host => "127.0.0.1",
    :port => 3307,
    :reconnect => false,
    :database => "bugs",
    :pool => 5,
    :username => "my_username",
    :password => "secret",
    :socket => "/tmp/mysql.sock"
)

class Bug < ActiveRecord::Base  #=> the table name in the "bugs" db is "bugs"
end                             #=> so I made the model singular

Bug.first  #=> the IRB session hangs at this point

所以,我不知道出了什么问题或如何对其进行调试。任何和所有建议都会有所帮助。

我在 Mac OSX 上。我尝试连接的数据库位于 FreeBSD 7.0 上,并且是 MySQL 版本 Ver 14.12 Distrib 5.0.67。

4

1 回答 1

0

您是否尝试过直接从 ActiveRecord 连接到数据库服务器,而不是尝试在 SSH 中建立 ActiveRecord 连接?这是通过网络连接的正常方式,并且由 ActiveRecord 直接支持。

将主机 ID 替换为服务器主机 IP 或 DNS 条目,可以允许端口默认为 MySQL 驱动程序的默认值 3306,并且不需要套接字,因为 DB 在远程主机上。

如果数据库主机与您的不在同一个网络上,并且您正在穿越防火墙,您可能需要打开该端口以允许连接。如果它在同一个网络上,它应该可以在根本不需要 ssh 的情况下工作。

于 2011-02-06T01:11:26.497 回答