【问题标题】:Error conecting a ruby script to a Mysql database running on Ec2将 ruby​​ 脚本连接到在 Ec2 上运行的 Mysql 数据库时出错
【发布时间】:2013-08-20 06:17:40
【问题描述】:

我在 Ruby 中创建了一个小脚本,以查看是否可以在 Amazon Ec2 AMI (Ubuntu 64b) 上操作 mysql 数据库中的数据。我在实例的安全组下的权限中添加了 SSH 和 MYSQL。我能够将脚本连接到数据库(使用 mysql2 gem),但它不再起作用,我不明白为什么我一直有错误:

mysql2/client.rb:58:in `connect': 无法连接到 MySQL 服务器 'XX.XXX.XX.XXX (60) (Mysql2::Error)

这是我正在使用的脚本

require 'rubygems'
require 'mysql2'
require 'net/ssh/gateway'


gateway = Net::SSH::Gateway.new('ec2-XX-XX-XX-XX.compute-1.amazonaws.com',
           'ec2-user',
           :keys => ['/XXXX/XXXXX.pem'])
port = gateway.open("XX.XXX.XX.XXX",3306,3307)

baseDeDatos= Mysql2::Client.new(:host => "XX.XXX.XX.XXX", :database=> "x" ,:username => "x", :password => "x")

puts "I made it!"

baseDeDatos.close

gateway.close(port)
gateway.shutdown!' 

有没有人可以解决我的问题?我很困惑,因为它几天前有效,但没有(我没有更改任何权限或任何东西)。当然我检查了MYSQL数据库是否正常工作。

提前致谢。

【问题讨论】:

    标签: mysql ruby linux amazon-ec2 mysql2


    【解决方案1】:

    您是否可能没有在 mysql db 端授予远程权限?默认情况下,这些权限不可用。

    编辑: 如果连接是从 ec2 实例内部而不是外部建立的,那么您肯定没有对用户进行授予权限。

    【讨论】:

    • 感谢您的回答。我为我的远程 IP 添加了权限,但不幸的是它仍然显示相同的错误。
    猜你喜欢
    • 1970-01-01
    • 2015-09-25
    • 1970-01-01
    • 2017-12-08
    • 1970-01-01
    • 1970-01-01
    • 2020-04-12
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多