WedX - журнал о программировании и компьютерных науках

uvicorn подавляет системный журнал python для драйвера gelf

У меня есть контейнер Docker, который ведет журнал с помощью gelf в экземпляр журнала через udp — все в порядке!

Контейнер основан на Ubuntu 18, где rsyslog работает как служба, которая работает хорошо.

Внутри контейнера находится приложение FastAPI, работающее с веб-сервером uvicorn. Он также отлично работает, и uvicorn отлично регистрируется в экземпляре журнала.

Вот то, что не работает, но обычно работает с проектами Python, отличными от FastAPI. Я использую syslog Python, чтобы регистрировать больше информации.

Приложение с системным журналом выглядит так (я создал простой пример для отладки):

from fastapi import FastAPI
import syslog

syslog.openlog(facility=syslog.LOG_LOCAL0)

app = FastAPI()

syslog.syslog(syslog.LOG_INFO, 'startup done')

@app.get("/")
async def root():
    syslog.syslog(syslog.LOG_INFO, 'get hello')
    return {"message": "Hello World"}

Журналы экземпляра ведения журнала не отображают сообщения системного журнала. Только сообщения uvicorn:

INFO:     Started server process [21]
INFO:     Waiting for application startup.
INFO:     Application startup complete.
INFO:     Uvicorn running on https://0.0.0.0:80 (Press CTRL+C to quit)
INFO:     172.17.0.1:35346 - "GET / HTTP/1.1" 200 OK

Для дальнейшей отладки я проверил файл журнала rsyslog, и он содержит сообщения системного журнала:

Dec 23 17:21:39 /uvicorn: startup done
Dec 23 17:21:50 /uvicorn: get hello

а вот конфигурация rsyslog в /etc/rsyslog.d

local0.* {
   action(type="omfile" file="/var/log/test.log" fileOwner="syslog" fileGroup="syslog" fileCreateMode="0640")
   stop
}

Что мне здесь не хватает? Почему gelf игнорирует rsyslog? Что мне нужно знать о uvicorn относительно syslog? или что я могу сделать?

Спасибо


Ответы:


1

Проблема возникает из-за того, что gelf игнорирует системный журнал. Однако простая печать на питоне будет распознана.

Решение: я создал себе функцию журнала в python, которая будет записывать в системный журнал и распечатывать все, что я хочу зарегистрировать.

28.12.2020
Новые материалы

Я хотел выучить язык программирования MVC4, но не мог выучить его раньше, потому что это выглядит сложно…
Просто начните и учитесь самостоятельно Я хотел выучить язык программирования MVC4, но не мог выучить его раньше, потому что он кажется мне сложным, и я бросил его. Это в основном инструмент..

Лицензии с открытым исходным кодом: руководство для разработчиков и создателей
В динамичном мире разработки программного обеспечения открытый исходный код стал мощной парадигмой, способствующей сотрудничеству, инновациям и прогрессу, движимому сообществом. В основе..

Объяснение документов 02: BERT
BERT представил двухступенчатую структуру обучения: предварительное обучение и тонкая настройка. Во время предварительного обучения модель обучается на неразмеченных данных с помощью..

Как проанализировать работу вашего классификатора?
Не всегда просто знать, какие показатели использовать С развитием глубокого обучения все больше и больше людей учатся обучать свой первый классификатор. Но как только вы закончите..

Работа с цепями Маркова, часть 4 (Машинное обучение)
Нелинейные цепи Маркова с агрегатором и их приложения (arXiv) Автор : Бар Лайт Аннотация: Изучаются свойства подкласса случайных процессов, называемых дискретными нелинейными цепями Маркова..

Crazy Laravel Livewire упростил мне создание электронной коммерции (панель администратора и API) [Часть 3]
Как вы сегодня, ребята? В этой части мы создадим CRUD для данных о продукте. Думаю, в этой части я не буду слишком много делиться теорией, но чаще буду делиться своим кодом. Потому что..

Использование машинного обучения и Python для классификации 1000 сезонов новичков MLB Hitter
Чему может научиться машина, глядя на сезоны новичков 1000 игроков MLB? Это то, что исследует это приложение. В этом процессе мы будем использовать неконтролируемое обучение, чтобы..


Для любых предложений по сайту: [email protected]