ralat format exec dalam go aws-lambda dan terraform
Editor PHP Xinyi memperkenalkan anda kepada masalah biasa: "ralat format exec dalam go aws-lambda dan terraform". Apabila mencipta fungsi menggunakan aws-lambda dan terraform, anda mungkin menghadapi masalah dengan ralat format Exec. Ini mungkin disebabkan oleh ralat dalam kod fungsi atau konfigurasi terraform. Artikel ini akan membantu anda memahami dan menyelesaikan masalah ini supaya anda boleh berjaya mencipta dan menjalankan fungsi aws-lambda.
Kandungan soalan
Saya sebenarnya menghadapi masalah yang sangat jarang berlaku apabila memanggil golang lambda menggunakan terraform. Jadi pada asasnya saya menggunakan terraform untuk menggunakan semua sumber saya seperti lambda, gerbang api dengan golang. Masalahnya ialah apabila saya menggunakan fail .zip binari golang lambda ke lambda menggunakan terraform, apabila menyemak permintaan menggunakan laluan, ia mengembalikan ralat format exec. Semua kod terraform bagus dan diformatkan kerana saya menguji fungsi js lambda yang mudah dan ia berfungsi dengan baik. Saya rasa ia adalah isu seni bina binari, tetapi saya menggunakan seni bina binari yang sama seperti lambda yang saya gunakan pada aws. Jika sesiapa boleh membantu, saya juga mengalami masalah yang sama menggunakan Provide.al2 dan mendapat ralat format exec.
Beberapa maklumat penyahpepijatan
1-Struktur direktori
- infra -- helloGO -- main.go -- main // binary file -- terraform -- main.tf -- hello.zip // with main binary file
2- sumber fungsi lambda terraform
resource "aws_lambda_function" "hello" { function_name = "hello" filename = "../hello.zip" // taking filename from root ./hello.zip runtime = "go1.x" # nodejs16.x go1.x handler = "main" # function.handler role = aws_iam_role.hello_lambda_exec.arn timeout = 3 }
3-Bina arahan
buildGO: cleanGO GOOS=linux GOARCH=amd64 CGO_ENABLED=0 cd ./helloGo/ && go build -o ./ main.go cd ./helloGo/ && chmod +x main cd ./helloGo/ && zip ../hello.zip main
Ini akan mencipta fail binaan utama dan membungkusnya sebagai main.zip untuk digunakan oleh fail terraform lambda. (amd64 ialah fail boleh laku bagi x86_64)
Saya cuba menyediakan penyelesaian seperti membina dengan amd64 tetapi tidak mengetahui tentang lambda memanggil go mengatakan binari tidak boleh dilaksanakan dengan boleh laku ini
Penyelesaian
Tetapan persekitaran anda betul tetapi anda salah Perintah menetapkannya.
GOOS=linux GOARCH=amd64 CGO_ENABLED=0 cd ./helloGo/ && go build -o ./ main.go
Tingkah laku ini cd
命令设置 GOOS、GOARCH 和 CGO_ENABLED,而不是为 go build
ditetapkan.
Cuba ini:
cd ./helloGo/ && GOOS=linux GOARCH=amd64 CGO_ENABLED=0 go build -o ./ main.go
Atas ialah kandungan terperinci ralat format exec dalam go aws-lambda dan terraform. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

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

Notepad++7.3.1
Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina
Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1
Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6
Alat pembangunan web visual

SublimeText3 versi Mac
Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Topik panas



OpenSSL, sebagai perpustakaan sumber terbuka yang digunakan secara meluas dalam komunikasi yang selamat, menyediakan algoritma penyulitan, kunci dan fungsi pengurusan sijil. Walau bagaimanapun, terdapat beberapa kelemahan keselamatan yang diketahui dalam versi sejarahnya, yang sebahagiannya sangat berbahaya. Artikel ini akan memberi tumpuan kepada kelemahan umum dan langkah -langkah tindak balas untuk OpenSSL dalam sistem Debian. Debianopenssl yang dikenal pasti: OpenSSL telah mengalami beberapa kelemahan yang serius, seperti: Kerentanan Pendarahan Jantung (CVE-2014-0160): Kelemahan ini mempengaruhi OpenSSL 1.0.1 hingga 1.0.1f dan 1.0.2 hingga 1.0.2 versi beta. Penyerang boleh menggunakan kelemahan ini untuk maklumat sensitif baca yang tidak dibenarkan di pelayan, termasuk kunci penyulitan, dll.

Artikel ini menerangkan cara menggunakan alat PPROF untuk menganalisis prestasi GO, termasuk membolehkan profil, mengumpul data, dan mengenal pasti kesesakan biasa seperti CPU dan isu memori.

Artikel ini membincangkan ujian unit menulis di GO, meliputi amalan terbaik, teknik mengejek, dan alat untuk pengurusan ujian yang cekap.

Perpustakaan yang digunakan untuk operasi nombor terapung dalam bahasa Go memperkenalkan cara memastikan ketepatannya ...

Artikel ini membincangkan menggunakan ujian yang didorong oleh jadual di GO, satu kaedah yang menggunakan jadual kes ujian untuk menguji fungsi dengan pelbagai input dan hasil. Ia menyoroti faedah seperti kebolehbacaan yang lebih baik, penurunan duplikasi, skalabiliti, konsistensi, dan a

Artikel ini membincangkan pakej GO's Reflect, yang digunakan untuk manipulasi kod runtime, bermanfaat untuk siri, pengaturcaraan generik, dan banyak lagi. Ia memberi amaran tentang kos prestasi seperti pelaksanaan yang lebih perlahan dan penggunaan memori yang lebih tinggi, menasihati penggunaan yang bijak dan terbaik

Artikel ini membincangkan menguruskan kebergantungan modul Go melalui Go.Mod, meliputi spesifikasi, kemas kini, dan resolusi konflik. Ia menekankan amalan terbaik seperti versi semantik dan kemas kini biasa.

Laluan Pembelajaran Backend: Perjalanan Eksplorasi dari Front-End ke Back-End sebagai pemula back-end yang berubah dari pembangunan front-end, anda sudah mempunyai asas Nodejs, ...
