Rumah >pembangunan bahagian belakang >Tutorial Python >Pembangunan FastAPI Tanpa Pelayan: Membina API Pemain FC pada AWS

Pembangunan FastAPI Tanpa Pelayan: Membina API Pemain FC pada AWS

Linda Hamilton
Linda Hamiltonasal
2025-01-11 16:09:41571semak imbas

Sudah agak lama saya tidak berpeluang membina sesuatu yang mudah, menarik dan moden. Menjelang akhir tahun 2024, saya terjumpa FastAPI dan teruja, sementara saya telah membina API dalaman di tempat kerja sebelum ini, saya belum lagi mencipta apa-apa yang dihadapi oleh orang ramai.

Helo FastAPI!

FastAPI ialah rangka kerja moden yang berkuasa untuk membina API dengan Python dan ia kelihatan sesuai untuk apa yang saya mahu bina, API untuk maklumat asas pemain bola sepak. Saya pada mulanya menggelarkannya sebagai "Jugador FC" sebelum memilih "Player FC API".

Mengkonfigurasi Persekitaran.

Sebelum anda bermula, pastikan anda mempunyai keperluan berikut:

AWS CDK
Pelabuhan
Python 3.12.7

Mencipta Projek

Buat direktori pada mesin anda. Namakannya player_fc_fastapi_app, dalam direktori ini buat subdirektori berikut:

apl
    Mengandungi semua kod FastAPI
dynamo_db_local
    Mengandungi skrip python untuk mencipta versi tempatan Jadual Amazon DynamoDB
iac
    Mengandungi fail tindanan anda untuk mencipta sumber dalam AWS

Saya telah memudahkannya dengan menyediakan arahan yang boleh anda jalankan untuk menjimatkan masa di bawah:

Struktur direktori projek kini sepatutnya kelihatan seperti di bawah:

Menyediakan persekitaran Python

Selepas mencipta struktur direktori, cipta fail teks yang dipanggil requirements.txt dan masukkan baris berikut di dalamnya:

Setelah anda mencipta fail requirements.txt, cipta persekitaran maya dan pasang kebergantungan:

Menyediakan Amazon DynamoDB Local

Mari kita mulakan dengan menyediakan tika tempatan DynamoDB, ini memerlukan
Docker

untuk dipasang dan dijalankan.

Ini akan mengambil masa beberapa saat untuk imej ditarik dan memulakan bekas, setelah selesai kita boleh menavigasi ke arah direktori

dynamo_db_local dan mencipta fail create_ddb_table.py, isikan fail dengan kod di bawah :

Dengan kod ini, anda boleh mencipta jadual dalam contoh DynamoDB setempat. Jalankan coretan kod. Pembangunan FastAPI

Sekarang kita mempunyai instance tempatan

DynamoDB
dan berjalan, mari mula membuat apl kami, navigasi ke arah direktori
apl

dan buat dua fail, main.py dan keperluan. txt.

Isi keperluan.txt dengan yang di bawah:

Buat subdirektori di bawah :

model
     Model Pydantic Player<script></script> <script></script>penghala<script></script><script></script>      Mengandungi laluan<script></script> <script></script> <script></script> <script></script>

Mari kita buat beberapa model menggunakan Pydantic, kami akan menggunakan model Player dan UpdatePlayer untuk menentukan struktur data maklumat pemain yang boleh kami tambah atau ubah suai.

Dalam subdirektori model, buat fail __init__.py kosong dan fail bernama players.py dan isikan kod di bawah:

Dalam subdirektori penghala

, buat fail __init__.py kosong dan fail bernama players.py dan isikan kod di bawah:

Mencipta fail __init__.py kosong menukar folder menjadi pakej Python.

Buat fail bernama main.py dalam subdirektori

app
dan mula mengisinya dengan kod di bawah:

Pandu Uji Masa untuk pandu uji pantas, pastikan anda berada dalam direktori app

dan jalankan arahan di bawah untuk memulakan
Uvicorn
:

Sekarang apl kami sedang aktif dan berjalan, navigasi ke

http://127.0.0.1:8000/docs/

FastAPI Swagger Documentation

Anda akan melihat dokumentasi API interaktif automatik dengan 6 titik akhir tersedia:

Mari cuba tambah pemain. Pilih titik akhir

POST /players
, pilih butang
Cubalah

dan gunakan muatan di bawah untuk menambah pemain terbaik dunia, "Vinícius Júnior":

Berikut ialah rupa setiap operasi API dalam tindakan.

Add Player

Menambah Pemain Baharu:

Get All Players

Mengambil semula Semua Pemain:

Update Player

Mengemaskini Maklumat Pemain:

Get Player

Mendapatkan Butiran Pemain Tunggal:

Delete Player

Mengalih keluar Pemain:

Penggunaan menggunakan AWS CDK v2

Sekarang kami selesa menjalankan dan menguji apl kami secara tempatan, tiba masanya untuk menggunakan apl kami pada AWS. Kami akan menggunakan AWS CDK v2.
Navigasi ke dalam direktori <script></script>iac<script></script>, jalankan arahan di bawah untuk memulakan projek cdk:<script></script> <script></script> <script></script> <script></script>

Ubah suai fail requirements.txt yang terdapat dalam subdirektori, tambah baris di bawah:

Mari kita tentukan Jadual DynamoDB, fungsi Lambda dan url fungsi Lambda. Dalam direktori iac semasa, terdapat subdirektori lain yang anda perlukan untuk menavigasi ke arah (iac

). Buka fail iac_stack.py dan gantikan kandungan tindanan CDK dengan kod di bawah:

Kami mempunyai satu langkah terakhir sebelum kami memulakan penggunaan, tetapkan bendera untuk local_development: bool kepada False dalam fail players.py dalam direktori

app/router
.

Aktifkan persekitaran maya dalam direktori
iac
dan pasang kebergantungan dengan arahan di bawah:

Gunakan apl dengan arahan penggunaan cdk.CDK Deploy FastAPI APP
Setelah penempatan selesai, anda akan melihat URL fungsi dalam output terminal, ini ialah titik akhir API anda pada AWS.

    Uji semua titik akhir menggunakan URL fungsi seperti yang kami lakukan semasa pemacu ujian tempatan. Sebaik sahaja anda menambah pemain, tiba masanya untuk mengesahkan sama ada data pemain kami kekal atau hilang ke dalam eter.
  1. Untuk mengesahkan semuanya berfungsi:
  2. Pergi ke Konsol Pengurusan AWS
  3. Navigasi ke DynamoDB
  4. Cari Pemain Jadual
Pilih

Teroka item jadual

Player FC DynamoDB Table

Anda sepatutnya melihat data pemain anda dalam awan:

?

Penting: Jangan lupa untuk membersihkan sumber! Apabila tidak diperlukan lagi, anda boleh menjalankan perintah cdk destroy untuk memadam semua sumber AWS yang telah dibuat. <script></script>Itu melengkapkan perjalanan kami daripada pembangunan FastAPI tempatan kepada penggunaan tanpa pelayan pada AWS.<script></script> <script></script> <script></script>

Atas ialah kandungan terperinci Pembangunan FastAPI Tanpa Pelayan: Membina API Pemain FC pada AWS. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan:
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn