OperationalError: (OperationalError) (2003, “无法连接到 MySQL 服务器上的 '192.168.129.139' (111)") 无 无 [英] OperationalError: (OperationalError) (2003, "Can't connect to MySQL server on '192.168.129.139' (111)") None None

查看:33
本文介绍了OperationalError: (OperationalError) (2003, “无法连接到 MySQL 服务器上的 '192.168.129.139' (111)") 无 无的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

我正在尝试在运行 12.04 的 Ubuntu 机器上使用 mysql 创建远程数据库.

I am trying to create a remote database using mysql on an Ubuntu machine running 12.04.

它有一个启用远程登录且没有密码的 root 用户.我已经启动了服务器.

It has a root user with remote login enabled and no password.I have started the server.

输出

sudo netstat -tap | grep mysql

节目

tcp        0      0 localhost:mysql         *:*                     LISTEN      13246/mysqld

我创建了一个名为 nwtopology 的数据库(如前所述,root 还没有密码.)

I have created a database called nwtopology using (as mentioned root doesn't have a password yet.)

 create database nwtopology
 grant all privileges on *.* to root@192.168.129.221
 FLUSH PRIVILEGES;

在同样运行 Ubuntu 12.04 的客户端机器上,我使用 python 脚本通过 sqlalchemy 连接到远程 mysql 数据库.

From the client machine that also runs Ubuntu 12.04 I use a python script to connect to the remote mysql database using sqlalchemy.

from pox.core import core
import pox.openflow.libopenflow_01 as of
import re
import datetime
import time
from sqlalchemy import create_engine, ForeignKey
from sqlalchemy import Column, Date, Integer, String
from sqlalchemy.ext.declarative import declarative_base
from sqlalchemy.orm import relationship, backref
from sqlalchemy import create_engine
from sqlalchemy.orm import sessionmaker
from sqlalchemy.sql.expression import exists

log = core.getLogger()
engine = create_engine('mysql://root@192.168.129.139/nwtopology', echo=False)
Base = declarative_base()
Session = sessionmaker(bind=engine)
session = Session()

class SourcetoPort(Base):
    """"""
    __tablename__ = 'source_to_port'
    id = Column(Integer, primary_key=True)
    port_no        = Column(Integer)
    src_address    = Column(String,index=True)

    #-----------------------------------------
    def __init__(self, src_address,port_no):
        """"""
        self.src_address = src_address
        self.port_no     = port_no

create_engine() 调用失败并出现以下错误.

The create_engine() call is failing with the following error.

POX 0.1.0 (betta) / Copyright 2011-2013 James McCauley, et al.
Traceback (most recent call last):
  File "/home/karthik/ms_thesis/pox/pox/boot.py", line 89, in do_import2
    __import__(name, globals(), locals())
  File "/home/karthik/ms_thesis/pox/custom/tutorial.py", line 39, in <module>
    Base.metadata.create_all(engine)
  File "/usr/lib/python2.7/dist-packages/sqlalchemy/schema.py", line 2515, in create_all
    tables=tables)
  File "/usr/lib/python2.7/dist-packages/sqlalchemy/engine/base.py", line 2230, in _run_visitor
    conn = self.contextual_connect(close_with_result=False)
  File "/usr/lib/python2.7/dist-packages/sqlalchemy/engine/base.py", line 2340, in contextual_connect
    self.pool.connect(),
  File "/usr/lib/python2.7/dist-packages/sqlalchemy/pool.py", line 210, in connect
    return _ConnectionFairy(self).checkout()
  File "/usr/lib/python2.7/dist-packages/sqlalchemy/pool.py", line 371, in __init__
    rec = self._connection_record = pool._do_get()
  File "/usr/lib/python2.7/dist-packages/sqlalchemy/pool.py", line 697, in _do_get
    con = self._create_connection()
  File "/usr/lib/python2.7/dist-packages/sqlalchemy/pool.py", line 174, in _create_connection
    return _ConnectionRecord(self)
  File "/usr/lib/python2.7/dist-packages/sqlalchemy/pool.py", line 256, in __init__
    self.connection = self.__connect()
  File "/usr/lib/python2.7/dist-packages/sqlalchemy/pool.py", line 316, in __connect
    connection = self.__pool._creator()
  File "/usr/lib/python2.7/dist-packages/sqlalchemy/engine/strategies.py", line 80, in connect
    return dialect.connect(*cargs, **cparams)
  File "/usr/lib/python2.7/dist-packages/sqlalchemy/engine/default.py", line 280, in connect
    return self.dbapi.connect(*cargs, **cparams)
  File "/usr/lib/python2.7/dist-packages/MySQLdb/__init__.py", line 81, in Connect
    return Connection(*args, **kwargs)
  File "/usr/lib/python2.7/dist-packages/MySQLdb/connections.py", line 187, in __init__
    super(Connection, self).__init__(*args, **kwargs2)
OperationalError: (OperationalError) (2003, "Can't connect to MySQL server on '192.168.129.139' (111)") None None

我不明白为什么会这样?非常感谢任何帮助?

I cannot figure out why this is happening?Any help is greatly appreciated?

推荐答案

看起来 mysql 配置为仅在 localhost 上侦听.

Looks like mysql is configured to listen only on localhost.

您可以通过从您的客户端机器运行 telnet 192.168.129.139 3306 来测试这一点.

You can test this by running telnet 192.168.129.139 3306 from your client machine.

最可能的原因 - mysqld 被配置为这样做.

Most probable reason - mysqld is configured to do so.

请尝试按照此处描述的配置步骤:

编辑 /etc/mysql/my.cnf 文件以配置 MySQL 以侦听来自网络主机的连接,将 bind-address 指令更改为服务器的 IP 地址.例如,将 192.168.0.5 替换为适当的地址.如果没有这样的条目 - 取消注释或创建新行.

Edit the /etc/mysql/my.cnf file to configure MySQL to listen for connections from network hosts, change the bind-address directive to the server's IP address. For example Replace 192.168.0.5 with the appropriate address. If there are no such entry - uncomment it or create new line.

bind-address            = 192.168.0.5

然后重启mysqld

sudo service mysql restart

然后使用 telnet 或再次运行您的应用程序进行测试.netstat 也会有 mysqld 的第二个条目.

Then test with telnet or by running your application once again. Also netstat would have second entry for mysqld.

这篇关于OperationalError: (OperationalError) (2003, “无法连接到 MySQL 服务器上的 '192.168.129.139' (111)") 无 无的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
相关文章
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆