Rumah > pembangunan bahagian belakang > Golang > Membina API dengan AWS SAM dan Go

Membina API dengan AWS SAM dan Go

Patricia Arquette
Lepaskan: 2025-01-20 12:05:09
asal
530 orang telah melayarinya

Building an API with AWS SAM and Go

AWS SAM ialah cara terbaik untuk menggunakan aplikasi web melalui Infrastruktur sebagai Kod (IAC). Saya baru-baru ini cuba menggunakannya dalam projek kerja saya dan menghadapi realiti yang nyata...

Pergi adalah anak itik hodoh AWS?

Bahagian dokumentasi AWS SAM yang didedikasikan untuk Go adalah sangat pendek dan samar-samar, mengesyorkan mengulang kod sumber kami secara meluas ! Setiap fungsi lambda mempunyai fungsi go.mod, go.sum dan utiliti?!

Saya tulis artikel ini untuk anda yang keliru seperti saya?‍?. Mari kita selesaikan masalah ini bersama-sama!

Ini akan menjadi siri dua bahagian:

  1. Struktur fail (artikel ini)
  2. Konfigurasi SAM

Pergi konteks masa jalan

Pada masa ini, lambda tidak disokong dalam masa jalan Go. Ini bermakna AWS lambda tidak mempunyai pilihan khusus untuk menentukan bahawa kod anda ditulis dalam Go. Sebaliknya, AWS menawarkan 2 masa jalan biasa?:

  • al2 (Amazon Linux 2)
  • al2023 (Amazon Linux 2023)

Ini merujuk kepada sistem pengendalian lambda akan dijalankan. Adalah disyorkan untuk menggunakan al2023 kerana ia lebih baharu dan serasi dengan pemproses AWS Graviton yang menawarkan prestasi yang lebih baik pada harga yang lebih rendah.

Apa pun, masa jalan ini memerlukan kami menyediakan fail boleh laku (biasanya dinamakan bootstrap) yang akan dilaksanakan dalam setiap fungsi lambda. Jadi, daripada menghantar kod kepada lambda, kami menghantar boleh laku yang sebelum ini kami susun dengan Go. Cukup mudah, bukan?

Ini juga menghapuskan keperluan untuk lapisan lambda untuk bahasa seperti JS, kerana semua kebergantungan biasa akan dibungkus dalam boleh laku yang disusun.

Soalan

Jadi, bagaimana kita membina boleh laku ini? AWS mengesyorkan bahawa setiap lambda kami hendaklah disimpan dalam folder, bersama dengan go.mod dan go.sumnya, dan templat yang mereka sediakan kelihatan seperti ini:

<code>.
├── hello-world/
│   ├── go.mod
│   ├── go.sum
│   └── main.go
├── events/
│   └── ...
├── samconfig.toml
└── template.yaml</code>
Salin selepas log masuk
Salin selepas log masuk

Ini ialah definisi fungsi dalam template.yaml

<code>  HelloWorldFunction:
    Type: AWS::Serverless::Function 
    Metadata:
      BuildMethod: go1.x
    Properties:
      CodeUri: hello-world/
      Handler: bootstrap
      Runtime: provided.al2023
      Architectures:
        - x86_64
      Events:
        CatchAll:
          Type: Api
          Properties:
            Path: /hello
            Method: GET</code>
Salin selepas log masuk
Salin selepas log masuk

Jika kita melihat definisi Lambda, kita belajar:

  1. BuildMethod: go1.x Kami menggunakan pembina Go terbina dalam AWS untuk membina boleh laku untuk kami
  2. CodeUri: kod hello-world/ lambda akan disimpan secara eksklusif dalam direktori ini.
  3. Pengendali: bootstrap Nama boleh laku ialah bootstrap
  4. Masa Jalan: disediakan.al2023 Ini akan menjadi masa jalan.

Adakah anda nampak masalahnya? Pada masa ini kita memerlukan lambda kedua, kita perlu mencipta direktori baharu dengan go.mod, go.sum dan dependencies sendiri, bagaimana jika kita ingin berkongsi fungsi utiliti antara kedua-dua lambda itu? Sayang sekali?! Anda perlu menyalin fail yang sama ke dalam folder lambda baharu. Ini meninggalkan struktur fail yang kelihatan seperti ini:

Ini sangat teruk?!
<code>.
├── function1/
│   ├── go.mod
│   ├── go.sum
│   ├── main.go
│   └── SHAREDFUNC.go
├── function2/
│   ├── go.mod
│   ├── go.sum
│   ├── main.go
│   └── SHAREDFUNC.go
├── events/
│   └── ...
├── samconfig.toml
└── template.yaml</code>
Salin selepas log masuk
Terdapat banyak kod pendua!

Dan ia menjadi lebih teruk apabila lebih banyak lambda yang kami tambah. Mesti ada cara yang lebih baik!

Penyelesaian

Memandangkan saya ingin berkongsi go.mod, go.sum dan kod utiliti melalui semua lambda, saya menghasilkan struktur ini:

<code>.
├── hello-world/
│   ├── go.mod
│   ├── go.sum
│   └── main.go
├── events/
│   └── ...
├── samconfig.toml
└── template.yaml</code>
Salin selepas log masuk
Salin selepas log masuk
  1. Saya memecahkan semua kod awam ke dalam folder dalaman/,
  2. Letakkan fail go.mod dan go.sum dalam direktori akar
  3. Alihkan semua titik masuk lambda ke /cmd (terdapat konvensyen dalam Go bahawa setiap kali projek menghasilkan berbilang boleh laku, titik masuk diletakkan dalam direktori cmd)

Sekarang saya hanya perlu memberitahu AWS SAM tentang struktur baharu ini?! Saya dapati penyelesaiannya hanya dengan melaraskan nilai CodeUri dan Handler.

Rahsia?

Nampaknya jika anda

  • Alihkan go.mod dan go.sum ke folder akar
  • Tetapkan CodeUri kepada folder apa sahaja tempat masuk fungsi.

SAM akan mengesannya secara automatik dan membina dengan kebergantungan akar dan dalaman/kod ?

<code>  HelloWorldFunction:
    Type: AWS::Serverless::Function 
    Metadata:
      BuildMethod: go1.x
    Properties:
      CodeUri: hello-world/
      Handler: bootstrap
      Runtime: provided.al2023
      Architectures:
        - x86_64
      Events:
        CatchAll:
          Type: Api
          Properties:
            Path: /hello
            Method: GET</code>
Salin selepas log masuk
Salin selepas log masuk

Bolehkah ia menjadi lebih baik?

Ya✨, kami akan membincangkan lebih banyak cara untuk menyesuaikan kompilasi Go dalam artikel seterusnya!

Atas ialah kandungan terperinci Membina API dengan AWS SAM dan Go. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

sumber:php.cn
Kenyataan Laman Web ini
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
Artikel terbaru oleh pengarang
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan