fastapi项目生成环境搭建

概述

整个环境搭建的思路我觉得是没问题的,只是还缺少一些东西。
这是一个很糟糕的尝试过程,到最后还是因为其中一步有问题前功尽弃,最近没有时间再进行测试了,希望各位大佬看到之后能指点一二。

从github获取代码

先到想要放置代码的文件夹

pip3 install cookiecutter
cookiecutter https://github.com/tiangolo/full-stack-fastapi-postgresql

接下来的执行方式参考官方文档:https://github.com/tiangolo/full-stack-fastapi-postgresql
完成代码的获取之后,就可以修改dockerfile和很多其他配置,完成之后再运行环境

安装需要的环境

docker

docker安装如下:


apt install docker
apt install docker-compose

安装完成之后需要修改docker的软件源。
坏消息是模板是使用了非官方的dockerfile,导致安装时间缓慢,好消息是找到了对应的dockerhub镜像,速度影响不大。
配置dockerhub加速方式如下:

sudo mkdir -p /etc/docker
sudo tee /etc/docker/daemon.json <<-'EOF'
{
    "registry-mirrors": [
        "https://1nj0zren.mirror.aliyuncs.com",
        "https://docker.mirrors.ustc.edu.cn",
        "http://f1361db2.m.daocloud.io",
        "https://dockerhub.azk8s.cn"
    ]
}
EOF
sudo systemctl daemon-reload
sudo systemctl restart docker

完成该配置之后就能够大幅度提高docker的下载速度。
接下来修改dockerfile
总共需要修改的有四个dockerfile,backend文件夹三个,frontend文件夹一个
先修改frontend文件夹的代码,
打开项目/frontend/dockerfile,修改文中的:

RUN npm install 

RUN npm --registry https://registry.npm.taobao.org info underscore 
RUN npm install   --registry=https://registry.npm.taobao.org

使用淘宝镜像加快npm速度(不然让你怀疑人生)

然后修改backend后端的三个dockerfile,修改方式都一样,主要目的为加快镜像源的apt速度和pip速度
分别在三个文件的头增加:

#加快apt install *的速度
RUN  sed -i s@/archive.ubuntu.com/@/mirrors.aliyun.com/@g /etc/apt/sources.list
RUN  apt-get clean
RUN apt-get update

# 加快pip的速度
RUN pip install -U pip
RUN pip config set global.index-url http://mirrors.aliyun.com/pypi/simple
RUN pip config set install.trusted-host mirrors.aliyun.com

分别在三个文件夹完成之后,就可以执行以下指令尝试运行了:

docker-compose up -d

更多和项目相关的介绍在项目文件夹的readme.md里面。
我主要遇到的就是,配置了apt加速还是很慢。。。满到爆。。。
如果有大佬成功部署了留言告知一下

  • 3
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
FastAPI是一个由Python编写的现代高性能Web框架,特别适合构建RESTful API和Web应用。它基于星lette和Uvicorn,提供了简单易用的API定义、自动文档生成以及类型安全等特性。以下是一些基本步骤来使用FastAPI搭建Web服务器: 1. 安装FastAPI: 首先确保你已经安装了Python和pip,然后在命令行中运行 `pip install fastapi uvicorn` 来安装FastAPI和其依赖的Uvicorn。 2. 创建项目文件结构: 创建一个新的目录,例如`my_api`,并在其中创建`main.py`和`app.py`(如果需要分模块管理)。 3. 编写`main.py` (或app.py): 这里通常导入并启动FastAPI应用程序。例如,一个简单的示例是: ```python from fastapi import FastAPI # 在这里导入你的API路由和配置 from app import app as api if __name__ == "__main__": import uvicorn uvicorn.run(api, host="0.0.0.0", port=8000) ``` 4. 定义路由和处理函数: 在`app.py`中,你需要定义`API Router`,即定义HTTP方法(GET、POST、PUT等)和URL路径,以及对应的处理函数。例如: ```python from fastapi import APIRouter, Depends, HTTPException, status router = APIRouter() @router.get("/items/") async def read_items(): # 这里是返回数据的逻辑,比如查询数据库 return [{"item_id": 1, "item_name": "Example item"}] ``` 5. 文档生成: FastAPI内置了`docs`功能,可以通过`app.include_router(router, tags=["Items"])`来添加文档,并访问`http://localhost:8000/docs`查看API文档。 6. 启动服务: 运行`main.py`(或指定的`app.py`),在指定的主机和端口上(如8000)启动Web服务器。 相关问题-- 1. FastAPI与星lette和Uvicorn的关系是什么? 2. 如何在FastAPI中处理POST请求并解析请求体数据? 3. 如何在FastAPI中设置全局响应头信息? 4. FastAPI中的Depends函数是用来做什么的?
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值