如何从docker连接到主机上的mysql?

quhf5bfb  于 2021-06-17  发布在  Mysql
关注(0)|答案(2)|浏览(395)

我的本地主机上有mysql,可以使用root登录:

[root@pocnnr1n1 etc]# mysql -u root -p
Enter password:
Welcome to the MariaDB monitor.  Commands end with ; or \g.
Your MariaDB connection id is 8
Server version: 5.5.52-MariaDB MariaDB Server

Copyright (c) 2000, 2016, Oracle, MariaDB Corporation Ab and others.

Type 'help;' or '\h' for help. Type '\c' to clear the current input statement.

MariaDB [(none)]> show databases;
+--------------------+
| Database           |
+--------------------+

现在,我在这个主机上有一个docker,它的ip地址是'172.17.0.2'
从docker ping到主机没有问题:

root@eaa90c1059f2:/app/airflow/dags# ping 192.168.211.251
PING 192.168.211.251 (192.168.211.251): 56 data bytes
64 bytes from 192.168.211.251: icmp_seq=0 ttl=64 time=0.208 ms

在docker中,如果我手动运行pymysql来创建连接:

conn= pymysql.connect(host='192.168.211.251', port=3306, user='root',
passwd='root', db='airflow')

我有以下错误:
pymysql.err.operationalerror:(1045,“拒绝访问用户'root'@'172.17.0.2'(使用密码:yes)”)
如果我将ip地址更改为“172.17.0.2”,如下所示:

conn= pymysql.connect(host='172.17.0.2', port=3306, user='root',
passwd='root', db='airflow')
I have the following error:

pymysql.err.operationalerror:(2003,“无法连接到'172.17.0.2'上的mysql服务器([errno 111]连接被拒绝)”)
更新:my.cnf如下:

[mysqld]
transaction-isolation = READ-COMMITTED

# Disabling symbolic-links is recommended to prevent assorted security risks;

# to do so, uncomment this line:

# symbolic-links = 0

key_buffer = 16M
key_buffer_size = 32M
max_allowed_packet = 32M
thread_stack = 256K
thread_cache_size = 64
query_cache_limit = 8M
query_cache_size = 64M
query_cache_type = 1

max_connections = 550

# expire_logs_days = 10

# max_binlog_size = 100M

# log_bin should be on a disk with enough free space. Replace '/var/lib/mysql/mysql_binary_log' with an appropriate path for your system

# and chown the specified folder to the mysql user.

log_bin=/var/lib/mysql/mysql_binary_log

# explicit_defaults_for_timestamp = 1

binlog_format = mixed

read_buffer_size = 2M
read_rnd_buffer_size = 16M
sort_buffer_size = 8M
join_buffer_size = 8M

# InnoDB settings

innodb_file_per_table = 1
innodb_flush_log_at_trx_commit  = 2
innodb_log_buffer_size = 64M
innodb_buffer_pool_size = 4G
innodb_thread_concurrency = 8
innodb_flush_method = O_DIRECT
innodb_log_file_size = 512M

[mysqld_safe]
log-error=/var/log/mariadb/mariadb.log
pid-file=/var/run/mariadb/mariadb.pid
bihw5rsg

bihw5rsg1#

我只是整理了一下:
此问题与未授予用户权限有关airflow@172.17.0.2
我要做的是在主机的mysql上,

GRANT ALL TO 'airflow'@'172.17.0.2' IDENTIFIED BY 'airflow' ;
FLUSH PRIVILEGES;

如果您这样做,这一点非常清楚: select User, Host, Password from mysql.user; 现在可以使用pymysql创建连接。
为了方便测试,不必在dag中进行测试,这只能使用python进行测试(但需要导入pymysql)
希望这有帮助。

dohp0rv5

dohp0rv52#

这是mysql文档里的
确保服务器未配置为忽略网络连接,或者(如果您尝试远程连接)未配置为仅在其网络接口上本地侦听。如果服务器以--skip networking启动,它将根本不接受tcp/ip连接。如果服务器是以--bind address=127.0.0.1启动的,它将只在环回接口上本地侦听tcp/ip连接,而不接受远程连接。
当docker网络中的某些东西试图连接本地主机时:它也试图从远程访问mysql。
找到 my.cnf (通常 /etc/mysql/my.cnf )评论这行 bind-address=127.0.0.1

相关问题