我正在尝试从另一台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
答案 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