欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

關于docker部署fastapi項目以及日志掛載方式

 更新時間:2023年03月15日 08:39:07   作者:id老貓  
這篇文章主要介紹了關于docker部署fastapi項目以及日志掛載方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教

docker部署fastapi項目以及日志掛載

最近在嘗試用docker部署fastapi項目

他的基本架構(gòu)是由nginx+guvicorn+uvicorn+fastapi項目組成的

Nginx

nginx起到反向代理的作用

可能有人會問,為什么要用nginx反向代理,我直接訪問項目不行嗎?

其實nginx不只是反向代理的功能,還有很多像負載均衡、請求攔截、靜態(tài)文件訪問等等功能,而且他還隱藏了web服務的地址。

uvicorn

uvicorn是什么呢?大家都知道,fastapi使用的是ASGI協(xié)議,它是WSGI協(xié)議的一種升級版

而uvicorn是一個高性能的ASGI服務器,它建立在uvloop和httptools之上,

我們在本地開發(fā)時可以使用uvicorn來做服務器,

不過雖然uviorn也可以啟動和運行多個進程,但是在處理工作進程的能力上更有限。

gunicorn

所以我使用gunicorn來做進程管理器,雖然gunicorn是一個WSGI服務器,本身與fastapi不兼容,但是你只要告訴它使用哪個特定的工作進程類,他就可以使用這個類啟動一個或多個工作進程

這不就巧了嗎?uvicorn就有一個gunicorn兼容的worker類

下面我們來講一下究竟怎么啟動

首先我們需要下載uvicorn和gunicorn

pip install "uvicorn[standard]"
pip install gunicorn

然后我們就可以啟動了

不過官方展示的是命令行啟動:

gunicorn main:app --workers 4 --worker-class uvicorn.workers.UvicornWorker --bind 0.0.0.0:80

并沒有展示文件啟動的方式,我們還是習慣配置文件啟動,其實也很簡單。

我們只需要在項目根路徑下建立一個config.py文件作為配置文件即可。

import multiprocessing

# 是否開啟debug
debug = True

# 設置守護進程
daemon = True

# 綁定ip和端口號
bind = '0.0.0.0:8000'

# 超時時間
timeout = 30

# 工作模式
worker_class = 'uvicorn.workers.UvicornWorker'

# 進程數(shù)
workers = multiprocessing.cpu_count() * 2 + 1

# 設置證書
# keyfile = ''
# certfile = ''

# 日志級別,這個日志級別指的是錯誤日志級別,而訪問日志的級別無法設置
loglevel = 'debug'

#設置執(zhí)行路徑
chdir = './sql_app'

# 日志配置
# 訪問日志文件
accesslog = "/app/sql_app/log/access.log"
# 錯誤日志文件
errorlog = "/app/sql_app/log/error.log"

這里我們只要把worker_class 工作模式設置成’uvicorn.workers.UvicornWorker’,他就可以啟動我們的uvicorn服務器了。

注意設置好執(zhí)行路徑和日志文件

然后執(zhí)行啟動命令

gunicorn -c config.py main:app

其中main為項目的初始化文件

docker日志掛載的問題

關鍵是本地服務器沒有寫入的權(quán)限 

關鍵看這里吧(Permission denied), 一直沒有看正方,以為是配置日志文件 找不到有問題,下面是部分異常

10:35:09,498 |-ERROR in ch.qos.logback.core.rolling.RollingFileAppender[FILE] - openFile(null,true) call failed. java.io.FileNotFoundException: logs/bandwidth.log.2019-04-25.log (Permission denied)
        at java.io.FileNotFoundException: logs/bandwidth.log.2019-04-25.log (Permission denied)
        at      at java.io.FileOutputStream.open0(Native Method)
        at      at java.io.FileOutputStream.open(FileOutputStream.java:270)
        at      at java.io.FileOutputStream.<init>(FileOutputStream.java:213)
        at      at ch.qos.logback.core.recovery.ResilientFileOutputStream.<init>(ResilientFileOutputStream.java:26)
        at      at ch.qos.logback.core.FileAppender.openFile(FileAppender.java:204)
        at      at ch.qos.logback.core.FileAppender.start(FileAppender.java:127)
        at      at ch.qos.logback.core.rolling.RollingFileAppender.start(RollingFileAppender.java:100)
        at      at ch.qos.logback.core.joran.action.AppenderAction.end(AppenderAction.java:90)
        at      at ch.qos.logback.core.joran.spi.Interpreter.callEndAction(Interpreter.java:309)
        at      at ch.qos.logback.core.joran.spi.Interpreter.endElement(Interpreter.java:193)

嘗試好多遍,才真正看懂原因也是從網(wǎng)上看到的一點啟發(fā),希望大家也能注意到,我用如下命令完美解決

docker run ? -it --privileged=true ? ?-v /dockerlogs:/app/logs ? -d -p 5080:5080 ?82edb4bbc79b

掛載宿主機已存在目錄后,在容器內(nèi)對其進行操作,報“Permission denied”

可通過兩種方式解決:

1> 關閉selinux。

臨時關閉:# setenforce 0

永久關閉:修改/etc/sysconfig/selinux文件,將SELINUX的值設置為disabled。

2> 以特權(quán)方式啟動容器 

指定--privileged參數(shù)

如:

# docker run -it --privileged=true -v /test:/softlogs

總結(jié)

以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。

相關文章

  • 使用Docker compose編排Laravel應用的方法

    使用Docker compose編排Laravel應用的方法

    本篇文章主要介紹了使用Docker compose編排Laravel應用的方法,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-07-07
  • 30分鐘帶你了解Docker(推薦)

    30分鐘帶你了解Docker(推薦)

    這篇文章是針對Java開發(fā)人員的,但Docker的使用場景絕不僅限于此。最后,靈敏意味著可能有一些開發(fā)方式需要調(diào)整,到底如何利用Docker應該是當你了解它之后需要認真思考的問題
    2018-08-08
  • docker常用命令操作方法

    docker常用命令操作方法

    最近幾天都在研究docker,今天給大家分享docker一些常用的命令,需要的朋友可以參考下
    2017-11-11
  • 使用Docker-compose離線部署Django應用的方法

    使用Docker-compose離線部署Django應用的方法

    這篇文章主要介紹了使用Docker-compose離線部署Django應用的方法,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2019-03-03
  • Docker安裝阿里云服務器和在虛擬機安裝遇到的坑(問題小結(jié))

    Docker安裝阿里云服務器和在虛擬機安裝遇到的坑(問題小結(jié))

    這篇文章主要介紹了Docker安裝阿里云服務器和在虛擬機安裝遇到的坑,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2021-03-03
  • ssh 直接登錄docker容器的操作方法(不用通過宿主機進入)

    ssh 直接登錄docker容器的操作方法(不用通過宿主機進入)

    這篇文章主要介紹了ssh 直接登錄docker容器的操作方法(不用通過宿主機進入),本文給大家介紹的非常詳細,感興趣的朋友跟隨小編一起看看吧
    2024-06-06
  • 如何使用docker創(chuàng)建minio鏡像并上傳文件并提供demo

    如何使用docker創(chuàng)建minio鏡像并上傳文件并提供demo

    這篇文章主要介紹了使用docker創(chuàng)建minio鏡像并上傳文件,提供demo,minio還是很方便的,從部署到使用,都可以非常快速的搭建,而且比較穩(wěn)定,需要的朋友可以參考下
    2023-09-09
  • Docker容器應用日志查看方法

    Docker容器應用日志查看方法

    今天小編就為大家分享一篇關于Docker容器應用日志查看方法,小編覺得內(nèi)容挺不錯的,現(xiàn)在分享給大家,具有很好的參考價值,需要的朋友一起跟隨小編來看看吧
    2019-03-03
  • Windows10安裝WSL2 Ubuntu20.04并設置docker環(huán)境的方法

    Windows10安裝WSL2 Ubuntu20.04并設置docker環(huán)境的方法

    這篇文章主要介紹了Windows10安裝WSL2 Ubuntu20.04并設置docker環(huán)境的方法,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2020-05-05
  • Docker安裝ElasticSearch和Kibana的問題及處理方法

    Docker安裝ElasticSearch和Kibana的問題及處理方法

    這篇文章主要介紹了Docker安裝ElasticSearch和Kibana的問題及遇到問題解決方法,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2022-02-02

最新評論