使用ruby远程连接到mysql2

时间:2017-05-21 22:30:27

标签: mysql ruby rake mysql2

我正在尝试从另一台VM2连接到安装在VM1中的mysql2。 vm2使用ssh和coonnection wroks连接到vm1。 当我尝试连接到mysql时,我得到了这个错误:

No connection. Check your internet connection.

我的config.yaml文件包含:

# SQL connection
:adapter: mysql2
:database: project
:username: bochra
:password: 'password'
:host: ip_@_VM1

我的Rakefile的一部分看起来像这样:

config = YAML.load(File.open('config.yaml'))
puts 'Clearing the database of all data.'
  begin
    client = Mysql2::Client.new(config)
    client.query('DROP TABLE IF EXISTS Employees')
    client.query('CREATE TABLE Employees(id INT, age INT, salary TEXT NOT NULL, PRIMARY KEY(id))')

  rescue
    ErrorHandler.new.show_error :no_connection
  end

1 个答案:

答案 0 :(得分:0)

问题是我在我的默认Ubuntu上安装了MySQL默认安装后没有真正改变任何设置。 在默认安装中,绑定地址设置为127.0.0.1,所以我对它进行了评论。在那之后我得到另一个errot它说: Mysql2::Error: Host 'xxxxxx' is not allowed to connect to this MySQL server。因此,从服务器(VM1)我使用以下方法授予我的用户(bochra)privelleges:

CREATE USER 'bochra'@'%' IDENTIFIED BY 'root';
GRANT ALL PRIVILEGES ON *.* TO 'bochra'@'%' WITH GRANT OPTION; and that worked fine for me