Не удается подключиться к MYSQL с помощью SQLAlchemy - PullRequest
1 голос
/ 22 апреля 2019

Я не могу подключиться к моему mysql. Я использую pymysql для подключения к Mysql.

Вот мой код в колбе:

app.config["SQLALCHEMY_DATABASE_URI"] = "mysql+pymysql://"+config.get_config("MYSQL_DATABASE_USER")+":"\
                                        + config.get_config("MYSQL_DATABASE_PASSWORD")+"@"\
                                        + config.get_config("SERVER_HOST_NAME")+":"\
                                        + config.get_config("MYSQL_DATABASE_PORT")+"/"\
                                        + config.get_config("MYSQL_DATABASE_DB")

А это мой docker-compose файл

version: "3"
services:
  db:
    build: ./db
    restart: always
    ports:
      - "3308:3306"
    environment:
      - MYSQL_USER=root
      - MYSQL_ROOT_PASSWORD=root@123
  flask:
    build: ./python-backend
    links:
      - db
    depends_on:
      - db
    ports: 
      - "7000:7000"
  angular:
    build: ./angular-template
    depends_on:
      - flask
    ports:
      - "4200:4200"

Когда я еду по маршруту, это говорит

"(pymysql.err.OperationalError) (2003, \"Can't connect to MySQL server on '0.0.0.0' ([Errno 111] Connection refused)\")\n(Background on this error at: http://sqlalche.me/e/e3q8)"

Любая подсказка о том, что я здесь делаю неправильно?

А вот мой конфигурационный файл

"SERVER_SECRET":"winter is coming",
            "MYSQL_DATABASE_USER": "root",
            "MYSQL_DATABASE_PASSWORD": "root@123",
            "MYSQL_DATABASE_DB": "template",
            "MYSQL_DATABASE_HOST": "172.17.0.1", #localhost
            "MYSQL_DATABASE_CHARSET": "utf-8",
            "MYSQL_DATABASE_PORT": "3306",
            "SERVER_HOST_NAME": "0.0.0.0", #localhost
            "SERVER_PORT": 7000,
            "SERVER_DEBUG": True

1 Ответ

2 голосов
/ 22 апреля 2019

Измените имя хоста БД в вашем конфигурационном файле -

"MYSQL_DATABASE_HOST": "db", #docker compose service name

Похоже, вы используете SERVER_HOST_NAME для повторного представления хоста БД, измените ниже -

"SERVER_HOST_NAME": "db", #docker compose service name
...