gpt4 book ai didi

docker - 在Flask应用启动之前,Docker组成了使mysql数据库完全启动的功能

转载 作者:行者123 更新时间:2023-12-02 18:14:42 25 4
gpt4 key购买 nike

我刚刚开始对我的应用进行docker化。我已经建立了自己的Dockerfiledocker-compose.yml,除了一件事之外,其他一切似乎都可以正常工作。有时候我的flask应用程序启动得太快,并抛出连接拒绝错误(因为MySQL数据库未完全启动)。我正在使用healthcheck检查数据库是否已启动,但这似乎并不可靠(我什至确保可以看到show databases,但在运行状况检查通过后,mysql显然会初始化更多东西?不确定运行状况检查的目的是什么) 。在我的输出中,我看到确实首先创建了数据库,但是在flask应用程序启动时它仍在初始化。理想情况下,当我运行docker-compose up时,我希望能够首先看到此行,

db_1_eae741771281 | 2018-11-10T00:50:21.473098Z 0 [Note] mysqld: ready for connections.

然后启动我的 flask 应用程序入口点。目前,它不执行此操作。

在启动 start.sh之前,是否有更可靠的方法来确保MySQL完全启动?

Dockerfile:
FROM python:3.5-alpine

RUN apk update && apk upgrade

RUN apk add --no-cache curl python build-base openldap-dev python2-dev python3-dev pkgconfig python-dev libffi-dev musl-dev make gcc

RUN pip install --upgrade pip

RUN adduser -D user

WORKDIR /home/user

COPY requirements.txt requirements.txt
RUN python -m venv venv
RUN venv/bin/pip install -r requirements.txt

COPY app app
COPY start.sh ./
RUN chmod +x start.sh

RUN chown -R user:user ./
USER user

EXPOSE 5000
ENTRYPOINT ["./start.sh"]

docker-compose.yml:
version: "2.1"
services:
db:
image: mysql:5.7
ports:
- "32000:3306"
environment:
- MYSQL_DATABASE=mydb
- MYSQL_USER=user
- MYSQL_PASSWORD=user123
- MYSQL_ROOT_PASSWORD=user123
volumes:
- ./db:/docker-entrypoint-initdb.d/:ro
healthcheck:
test: "mysql --user=user --password=user123 --execute \"SHOW DATABASES;\""
timeout: 20s
retries: 20

app:
build: ./
ports:
- "5000:5000"
depends_on:
db:
condition: service_healthy

start.sh
#!/bin/sh

source venv/bin/activate
# Start Gunicorn processes
echo Starting Gunicorn.

exec gunicorn -b 0.0.0.0:5000 wsgi --chdir my_app --timeout 9999 --workers 3 --access-logfile - --error-logfile - --capture-output --log-level debug

最佳答案

好的,我也遇到了health_check问题...

也许不是最佳选择,但最可靠的解决方案是在启动应用程序之前使用MySQL客户端(mysqladmin)ping MySQL服务器。

1 -创建一个wait.sh脚本(db是您的MySQL服务名称):

#!/bin/sh

# Wait until MySQL is ready
while ! mysqladmin ping -h"db" -P"3306" --silent; do
echo "Waiting for MySQL to be up..."
sleep 1
done

2 -从您的 app Dockerfile获取一个MySQL客户端:
# install mysql client, will be used to ping mysql
apt-get -y install mysql-client

3 -在您的 docker-compose.yml文件中,只需将脚本添加到您的容器中(我使用了卷,但是您可以继续使用 COPY)并在 wait.sh之前运行 start.sh:
app:
build: ./
ports:
- "5000:5000"
depends_on:
db:
command: bash -c "/usr/local/bin/wait.sh && /usr/local/bin/start.sh"
volumes:
- ./start.sh:/usr/local/bin/start.sh
- ./wait.sh:/usr/local/bin/wait.sh

这应该工作。

如果您真的不想下载MySQL客户端,请尝试此操作(同样 db是您的MySQL服务名称)。它在我的大多数项目中都起作用,但并非全部起作用(可能取决于分布吗?):
#!/bin/sh

# Wait until MySQL is ready
while ! exec 6<>/dev/tcp/db/3306; do
echo "Trying to connect to MySQL at 3306..."
sleep 5
done

PS:避免将服务命名为“app”或“db”,如果其他容器具有相同的服务名称(即使在不同的网络中),以后可能会出现问题。

关于docker - 在Flask应用启动之前,Docker组成了使mysql数据库完全启动的功能,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/53235312/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com