Fedora - Use FastAPI to build web services in Python - Printable Version +- Sick Gaming (https://www.sickgaming.net) +-- Forum: Computers (https://www.sickgaming.net/forum-86.html) +--- Forum: Linux, FreeBSD, and Unix types (https://www.sickgaming.net/forum-88.html) +--- Thread: Fedora - Use FastAPI to build web services in Python (/thread-95348.html) |
Fedora - Use FastAPI to build web services in Python - xSicKxBot - 06-01-2020 Use FastAPI to build web services in Python <div><p><em><a href="https://fastapi.tiangolo.com/">FastAPI</a></em> is a modern Python web framework that leverage the latest Python improvement in asyncio. In this article you will see how to set up a container based development environment and implement a small web service with FastAPI.</p> <p> <span id="more-31024"></span> </p> <h2>Getting Started</h2> <p>The development environment can be set up using the Fedora container image. The following Dockerfile prepares the container image with FastAPI, <a href="https://www.uvicorn.org/">Uvicorn</a> and <a href="https://github.com/Tinche/aiofiles">aiofiles</a>.</p> <pre class="wp-block-preformatted">FROM fedora:32 RUN dnf install -y python-pip \ && dnf clean all \ && pip install fastapi uvicorn aiofiles WORKDIR /srv CMD ["uvicorn", "main:app", "--reload"]</pre> <p>After saving this Dockerfile in your working directory, build the container image using podman.</p> <pre class="wp-block-preformatted">$ podman build -t fastapi . $ podman images REPOSITORY TAG IMAGE ID CREATED SIZE localhost/fastapi latest 01e974cabe8b 18 seconds ago 326 MB</pre> <p>Now let’s create a basic FastAPI program and run it using that container image.</p> <pre class="wp-block-preformatted">from fastapi import FastAPI app = FastAPI() @app.get("/") async def root(): return {"message": "Hello Fedora Magazine!"}</pre> <p>Save that source code in a <em>main.py</em> file and then run the following command to execute it:</p> <pre class="wp-block-preformatted">$ podman run --rm -v $PWD:/srv:z -p 8000:8000 --name fastapi -d fastapi $ curl http://127.0.0.1:8000 {"message":"Hello Fedora Magazine!"</pre> <p>You now have a running web service using FastAPI. Any changes to <em>main.py</em> will be automatically reloaded. For example, try changing the “Hello Fedora Magazine!” message.</p> <p>To stop the application, run the following command. </p> <pre class="wp-block-preformatted">$ podman stop fastapi</pre> <h2>Building a small web service</h2> <p>To really see the benefits of FastAPI and the performance improvement it brings (<a href="https://www.techempower.com/benchmarks/#section=test&runid=7464e520-0dc2-473d-bd34-dbdfd7e85911&hw=ph&test=composite&l=z8kflr-v&a=2&f=jz8cg-0-3s-0-3k-6bo-0-0-18y74-8s5c-0">see comparison</a> with other Python web frameworks), let’s build an application that manipulates some I/O. You can use the output of the <em>dnf history</em> command as data for that application.</p> <p>First, save the output of that command in a file.</p> <pre class="wp-block-preformatted">$ dnf history | tail --lines=+3 > history.txt</pre> <p>The command is using <em>tail</em> to remove the headers of <em>dnf history</em> which are not needed by the application. Each dnf transaction can be represented with the following information: </p> <ul> <li>id : number of the transaction (increments every time a new transaction is run)</li> <li>command : the dnf command run during the transaction</li> <li>date: the date and time the transaction happened</li> </ul> <p>Next, modify the <em>main.py</em> file to add that data structure to the application.</p> <pre class="wp-block-preformatted">from fastapi import FastAPI from pydantic import BaseModel app = FastAPI() class DnfTransaction(BaseModel): id: int command: str date: str</pre> <p>FastAPI comes with the <a href="https://pydantic-docs.helpmanual.io/">pydantic</a> library which allow you to easily build data classes and benefit from type annotation to validate your data.</p> <p>Now, continue building the application by adding a function that will read the data from the <em>history.txt </em> file.</p> <pre class="wp-block-preformatted">import aiofiles from fastapi import FastAPI from pydantic import BaseModel app = FastAPI() class DnfTransaction(BaseModel): id: int command: str date: str async def read_history(): transactions = [] async with aiofiles.open("history.txt") as f: async for line in f: transactions.append(DnfTransaction( id=line.split("|")[0].strip(" "), command=line.split("|")[1].strip(" "), date=line.split("|")[2].strip(" "))) return transactions</pre> <p>This function makes use of the <em><a href="https://github.com/Tinche/aiofiles">aiofiles</a></em> library which provides an asyncio API to manipulate files in Python. This means that opening and reading the file will not block other requests made to the server.</p> <p>Finally, change the root function to return the data stored in the transactions list.</p> <pre class="wp-block-preformatted">@app.get("/") async def read_root(): return await read_history()</pre> <p>To see the output of the application, run the following command</p> <pre class="wp-block-preformatted">$ curl http://127.0.0.1:8000 | python -m json.tool [ { "id": 103, "command": "update", "date": "2020-05-25 08:35" }, { "id": 102, "command": "update", "date": "2020-05-23 15:46" }, { "id": 101, "command": "update", "date": "2020-05-22 11:32" }, .... ]</pre> <h2>Conclusion</h2> <p><em>FastAPI</em> is gaining a lot a popularity in the Python web framework ecosystem because it offers a simple way to build web services using asyncio. You can find more information about <em>FastAPI</em> in the <a href="https://fastapi.tiangolo.com/">documentation</a>.</p> <p>The code of this article is available in <a href="https://github.com/cverna/fastapi_app">this GitHub repository</a>.</p> <hr class="wp-block-separator" /> <p><em>Photo by <a href="https://unsplash.com/@jankubita?utm_source=unsplash&utm_medium=referral&utm_content=creditCopyText">Jan Kubita</a> on <a href="https://unsplash.com/s/photos/fast-snake?utm_source=unsplash&utm_medium=referral&utm_content=creditCopyText">Unsplash</a>.</em></p> </div> https://www.sickgaming.net/blog/2020/06/01/use-fastapi-to-build-web-services-in-python/ |