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:
- Struktur fail (artikel ini)
- 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>
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>
Jika kita melihat definisi Lambda, kita belajar:
- BuildMethod: go1.x Kami menggunakan pembina Go terbina dalam AWS untuk membina boleh laku untuk kami
- CodeUri: kod hello-world/ lambda akan disimpan secara eksklusif dalam direktori ini.
- Pengendali: bootstrap Nama boleh laku ialah bootstrap
- 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>Terdapat banyak kod pendua!
Dan ia menjadi lebih teruk apabila lebih banyak lambda yang kami tambah. Mesti ada cara yang lebih baik! Memandangkan saya ingin berkongsi go.mod, go.sum dan kod utiliti melalui semua lambda, saya menghasilkan struktur ini: Sekarang saya hanya perlu memberitahu AWS SAM tentang struktur baharu ini?! Saya dapati penyelesaiannya hanya dengan melaraskan nilai CodeUri dan Handler. Nampaknya jika anda SAM akan mengesannya secara automatik dan membina dengan kebergantungan akar dan dalaman/kod ? Ya✨, kami akan membincangkan lebih banyak cara untuk menyesuaikan kompilasi Go dalam artikel seterusnya! Penyelesaian
<code>.
├── hello-world/
│ ├── go.mod
│ ├── go.sum
│ └── main.go
├── events/
│ └── ...
├── samconfig.toml
└── template.yaml</code>
Rahsia?
<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>
Bolehkah ia menjadi lebih baik?
Atas ialah kandungan terperinci Membina API dengan AWS SAM dan Go. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Ciri -ciri teras GO termasuk pengumpulan sampah, penyambungan statik dan sokongan konvensional. 1. Model keseragaman bahasa GO menyedari pengaturcaraan serentak yang cekap melalui goroutine dan saluran. 2. Antara muka dan polimorfisme dilaksanakan melalui kaedah antara muka, supaya jenis yang berbeza dapat diproses secara bersatu. 3. Penggunaan asas menunjukkan kecekapan definisi fungsi dan panggilan. 4. Dalam penggunaan lanjutan, kepingan memberikan fungsi saiz semula dinamik yang kuat. 5. Kesilapan umum seperti keadaan kaum dapat dikesan dan diselesaikan melalui perlumbaan getest. 6. Pengoptimuman prestasi menggunakan objek melalui sync.pool untuk mengurangkan tekanan pengumpulan sampah.

Pergi bahasa berfungsi dengan baik dalam membina sistem yang cekap dan berskala. Kelebihannya termasuk: 1. Prestasi Tinggi: Disusun ke dalam Kod Mesin, Kelajuan Berjalan Cepat; 2. Pengaturcaraan serentak: Memudahkan multitasking melalui goroutine dan saluran; 3. Kesederhanaan: sintaks ringkas, mengurangkan kos pembelajaran dan penyelenggaraan; 4. Cross-Platform: Menyokong kompilasi silang platform, penggunaan mudah.

Keliru mengenai penyortiran hasil pertanyaan SQL. Dalam proses pembelajaran SQL, anda sering menghadapi beberapa masalah yang mengelirukan. Baru-baru ini, penulis membaca "Asas Mick-SQL" ...

Hubungan antara konvergensi stack teknologi dan pemilihan teknologi dalam pembangunan perisian, pemilihan dan pengurusan susunan teknologi adalah isu yang sangat kritikal. Baru -baru ini, beberapa pembaca telah mencadangkan ...

Golang ...

Bagaimana membandingkan dan mengendalikan tiga struktur dalam bahasa Go. Dalam pengaturcaraan GO, kadang -kadang perlu untuk membandingkan perbezaan antara dua struktur dan menggunakan perbezaan ini kepada ...

Bagaimana untuk melihat pakej yang dipasang di seluruh dunia? Dalam proses membangun dengan bahasa Go, sering menggunakan ...

Apa yang perlu saya lakukan jika label struktur tersuai di Goland tidak dipaparkan? Apabila menggunakan Goland untuk Pembangunan Bahasa GO, banyak pemaju akan menghadapi tag struktur tersuai ...


Alat AI Hot

Undresser.AI Undress
Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover
Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool
Gambar buka pakaian secara percuma

Clothoff.io
Penyingkiran pakaian AI

AI Hentai Generator
Menjana ai hentai secara percuma.

Artikel Panas

Alat panas

Hantar Studio 13.0.1
Persekitaran pembangunan bersepadu PHP yang berkuasa

MinGW - GNU Minimalis untuk Windows
Projek ini dalam proses untuk dipindahkan ke osdn.net/projects/mingw, anda boleh terus mengikuti kami di sana. MinGW: Port Windows asli bagi GNU Compiler Collection (GCC), perpustakaan import yang boleh diedarkan secara bebas dan fail pengepala untuk membina aplikasi Windows asli termasuk sambungan kepada masa jalan MSVC untuk menyokong fungsi C99. Semua perisian MinGW boleh dijalankan pada platform Windows 64-bit.

mPDF
mPDF ialah perpustakaan PHP yang boleh menjana fail PDF daripada HTML yang dikodkan UTF-8. Pengarang asal, Ian Back, menulis mPDF untuk mengeluarkan fail PDF "dengan cepat" dari tapak webnya dan mengendalikan bahasa yang berbeza. Ia lebih perlahan dan menghasilkan fail yang lebih besar apabila menggunakan fon Unicode daripada skrip asal seperti HTML2FPDF, tetapi menyokong gaya CSS dsb. dan mempunyai banyak peningkatan. Menyokong hampir semua bahasa, termasuk RTL (Arab dan Ibrani) dan CJK (Cina, Jepun dan Korea). Menyokong elemen peringkat blok bersarang (seperti P, DIV),

Dreamweaver CS6
Alat pembangunan web visual

SublimeText3 versi Mac
Perisian penyuntingan kod peringkat Tuhan (SublimeText3)