簡體   English   中英

如何使用 mysql 數據庫 dockerize 我的 Flask web 應用程序? 無法連接 mysql 並且找不到渲染模板

[英]How to dockerize my flask web app with mysql database?Cannot connect mysql and cannot found render templete

我是 docker 新手,正在嘗試部署此 Web 應用程序,但找不到解決方案。 我正在運行 Windows 10 和 Docker 桌面。 我的 docker-version 是 19.03.5 和 docker-compose 版本 1.25.4,構建未知。

我的目錄結構是:

  -docker-compose.yml
  -app
     -static
          js/
            script.js
          css/
              style.css
     -templates
            -index.html
     -app.py
     -dockerfile
     -requirements.txt
  -db
    -init.sql

docker-compose.yml

version: "2"
services:
app:
  build: ./app
  links:
    - db
  ports:
    - "5000:5000"

db:
  image: mysql:5.7
  ports:
    - "32000:3306"
  environment:
    MYSQL_ROOT_PASSWORD: root
  volumes:
    - ./db:/docker-entrypoint-initdb.d/:ro

文件

FROM python:3.6
EXPOSE 5000
RUN mkdir -p /app
RUN ls /app
COPY static /app/static
COPY templates /app/templates
COPY app.py /app
COPY requirements.txt /app
WORKDIR /app
RUN pip install -r requirements.txt
CMD python app.py

要求.txt

flask
mysql-connector

應用程序

from flask import Flask, render_template, request
import mysql.connector
import os

app = Flask(__name__, template_folder='/templates', static_folder='/static')
@app.route('/')
def index():
    connection = mysql.connector.connect(
        user = 'root',
        password = 'root',
        host= 'db',
        port = '3306',
        database = 'test'
    )
    cursor = connection.cursor()
    cursor.execute("SELECT name from place")
    names = cursor.fetchall()
    return render_template('index.html', names = names)
if __name__ == '__main__':
    app.run(host='0.0.0.0')

我的 docker 命令是 –

docker-compose up

然后嘗試訪問http://0.0.0.0:5000/但得到 mysql.connector.errors.InterfaceError: 2003: Can't connect to MySQL server on 'db:3306' and jinja2.exceptions.TemplateNotFound:

jinja2.exceptions.TemplateNotFound

您的燒瓶文件夾路徑是錯誤的,它應該是像/app/templates/app/static這樣的絕對路徑,或者像templates abnd static這樣的相對路徑。

mysql.connector.errors.InterfaceError: 2003: 無法連接到 'db:3306' 上的 MySQL 服務器

如果您的 init.sql 腳本是正確的,那么您的數據庫沒有任何問題,您只需在發送第一個請求之前讓它正確初始化(等待mysqld: ready for connections消息)。

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM