python - Cómo abordar ''OSError: libc no encontrado'' surgido en el exeje Gunicorn de la aplicación Flask dentro del contenedor acoplador Alpine
docker sockets (5)
En tu Dockerfile:
RUN apk add binutils libc-dev
Estoy trabajando en una aplicación Flask basada en la aplicación Microblog del mega tutorial de Miguel Grinberg.
El código vive aquí:
https://github.com/dnilasor/quickgig
.
Tengo una implementación de Docker que funciona con un contenedor MySQL 5.7 vinculado.
Hoy agregué una función de Vista de administrador usando el módulo Flask-Admin.
Funciona muy bien servido localmente (OSX) en el servidor Flask a través de ''flask run'', pero cuando construyo y ejecuto la nueva imagen del acoplador (basada en python: 3.8-alpine), se bloquea al arrancar con un
OSError: libc not found
, el código para el cual parece indicar
una biblioteca desconocida
Me parece que Gunicorn no puede servir la aplicación después de mis adiciones. ¡Mi compañero de clase y yo estamos perplejos!
Originalmente recibí el error usando la imagen base python: 3.6-alpine y lo intenté con 3.7 y 3.8 en vano.
También noté que estaba agregando redundantemente PyMySQL, una vez en require.txt especificando la versión no.
y nuevamente explícitamente en el dockerfile sin especificación.
Se eliminó la entrada require.txt.
También intenté incrementar la versión Flask-Admin no.
arriba y abajo.
También intenté limpiar las migraciones de mi base de datos, ya que he visto varios archivos de migración que hacen que el contenedor no se inicie (es cierto que esto fue cuando usé SQLite).
Ahora solo hay un único archivo de migración y, según el seguimiento de la pila, parece que la
flask db upgrade
del
flask db upgrade
funciona bien.
Una cosa que aún tengo que probar es una imagen base diferente (¿menos mínima?), Puede probar pronto y actualizar esto. Pero el problema es tan misterioso para mí que pensé que era hora de preguntar si alguien más lo había visto :)
Encontré este error de socket que parecía potencialmente relevante, pero se suponía que estaba completamente solucionado en Python 3.8.
También para su información, seguí algunos de los consejos
here
sobre importaciones circulares e
create_app
mi función de controlador de administrador dentro de
create_app
.
Dockerfile:
FROM python:3.8-alpine
RUN adduser -D quickgig
WORKDIR /home/quickgig
COPY requirements.txt requirements.txt
RUN python -m venv venv
RUN venv/bin/pip install -r requirements.txt
RUN venv/bin/pip install gunicorn pymysql
COPY app app
COPY migrations migrations
COPY quickgig.py config.py boot.sh ./
RUN chmod +x boot.sh
ENV FLASK_APP quickgig.py
RUN chown -R quickgig:quickgig ./
USER quickgig
EXPOSE 5000
ENTRYPOINT ["./boot.sh"]
boot.sh:
#!/bin/sh
source venv/bin/activate
while true; do
flask db upgrade
if [[ "$?" == "0" ]]; then
break
fi
echo Upgrade command failed, retrying in 5 secs...
sleep 5
done
# flask translate compile
exec gunicorn -b :5000 --access-logfile - --error-logfile - quickgig:app
Implementación en init .py:
from flask_admin import Admin
app_admin = Admin(name=''Dashboard'')
def create_app(config_class=Config):
app = Flask(__name__)
app.config.from_object(config_class)
...
app_admin.init_app(app)
...
from app.admin import add_admin_views
add_admin_views()
...
return app
from app import models
admin.py:
from flask_admin.contrib.sqla import ModelView
from app.models import User, Gig, Neighborhood
from app import db
# Add views to app_admin
def add_admin_views():
from . import app_admin
app_admin.add_view(ModelView(User, db.session))
app_admin.add_view(ModelView(Neighborhood, db.session))
app_admin.add_view(ModelView(Gig, db.session))
requerimientos.txt:
alembic==0.9.6
Babel==2.5.1
blinker==1.4
certifi==2017.7.27.1
chardet==3.0.4
click==6.7
dominate==2.3.1
elasticsearch==6.1.1
Flask==1.0.2
Flask-Admin==1.5.4
Flask-Babel==0.11.2
Flask-Bootstrap==3.3.7.1
Flask-Login==0.4.0
Flask-Mail==0.9.1
Flask-Migrate==2.1.1
Flask-Moment==0.5.2
Flask-SQLAlchemy==2.3.2
Flask-WTF==0.14.2
guess-language-spirit==0.5.3
idna==2.6
itsdangerous==0.24
Jinja2==2.10
Mako==1.0.7
MarkupSafe==1.0
PyJWT==1.5.3
python-dateutil==2.6.1
python-dotenv==0.7.1
python-editor==1.0.3
pytz==2017.2
requests==2.18.4
six==1.11.0
SQLAlchemy==1.1.14
urllib3==1.22
visitor==0.1.3
Werkzeug==0.14.1
WTForms==2.1
Cuando ejecuto el contenedor en la terminal interactiva, veo el siguiente seguimiento de pila:
(venv) ****s-MacBook-Pro:quickgig ****$ docker run -ti quickgig:v7
INFO [alembic.runtime.migration] Context impl SQLiteImpl.
INFO [alembic.runtime.migration] Will assume non-transactional DDL.
INFO [alembic.runtime.migration] Running upgrade -> 1f5feeca29ac, test
Traceback (most recent call last):
File "/home/quickgig/venv/bin/gunicorn", line 6, in <module>
from gunicorn.app.wsgiapp import run
File "/home/quickgig/venv/lib/python3.8/site-packages/gunicorn/app/wsgiapp.py", line 9, in <module>
from gunicorn.app.base import Application
File "/home/quickgig/venv/lib/python3.8/site-packages/gunicorn/app/base.py", line 12, in <module>
from gunicorn.arbiter import Arbiter
File "/home/quickgig/venv/lib/python3.8/site-packages/gunicorn/arbiter.py", line 16, in <module>
from gunicorn import sock, systemd, util
File "/home/quickgig/venv/lib/python3.8/site-packages/gunicorn/sock.py", line 14, in <module>
from gunicorn.socketfromfd import fromfd
File "/home/quickgig/venv/lib/python3.8/site-packages/gunicorn/socketfromfd.py", line 26, in <module>
raise OSError(''libc not found'')
OSError: libc not found
Me gustaría que la aplicación arranque / sea servida por gunicorn dentro del contenedor para poder continuar desarrollando con mi equipo utilizando la implementación de Docker y aprovechando MySQL dockerizado frente al dolor de MySQL local para el desarrollo. Me puede aconsejar
Este es un problema con gunicorn 20.0.0 que actualmente se está rastreando aquí: https://github.com/benoitc/gunicorn/issues/2160
Hasta que se solucione y publique ese problema, simplemente puede agregar la siguiente línea:
RUN apk --no-cache add binutils musl-dev
Desafortunadamente, esto agrega aproximadamente 20 MB al contenedor de acopladores resultante, pero no hay ninguna otra solución conocida en este momento.
Este problema parece estar relacionado con una nueva versión de Gunicorn 20.0.0. Intenta usar uno anterior 19.9.0
He resuelto este problema:
- Dockerfile: elimine esta instalación "EJECUTAR venv / bin / pip install gunicorn"
- require.txt: agrega esta línea "gunicorn == 19.7.1"
Sí, Gunicorn 20.0.0 requiere el paquete libc-dev .
Entonces esto funciona para mí:
RUN apk --no-cache add libc-dev