Rumah >pembangunan bahagian belakang >Golang >Cloud Functions Gen2 dengan Golang - Kitaran hayat contoh dan keselamatan sisipan BigQuery tanpa menunggu kerja selesai
editor php Apple membawakan anda artikel tentang Cloud Functions Gen2 menggunakan Golang. Artikel ini akan menumpukan pada kitaran hayat contoh dan keselamatan sisipan BigQuery dan cara melakukan ini tanpa menunggu kerja selesai. Dengan membaca artikel ini, anda akan belajar cara mengoptimumkan dan meningkatkan prestasi dan keselamatan aplikasi anda. Mari kita terokai topik menarik ini bersama-sama!
Saya menggunakan Fungsi Awan Google (Gen2) yang ditulis dalam Golang, yang dicetuskan oleh permintaan HTTP. Kes penggunaan saya memerlukan menyimpan beberapa data dalam BigQuery dan saya mahu mengelak daripada menunggu kerja selesai sebelum membalas permintaan HTTP.
Walau bagaimanapun, saya bimbang tentang kelakuan instance Cloud Function selepas kembali daripada fungsi:
Berapa lama tika itu kekal aktif selepas menghantar respons HTTP? Adakah selamat untuk tidak menunggu kerja BigQuery selesai? Adakah saya berisiko kehilangan data jika saya menamatkan contoh sebelum kerja selesai? Sebarang cerapan atau amalan terbaik mengenai senario ini akan sangat dihargai.
Pendekatan ini tidak digalakkan. Sila rujuk dokumentasi berikut:
Sesuatu fungsi hanya boleh mengakses sumber yang diperuntukkan (memori dan CPU) semasa pelaksanaan fungsi. Kod yang berjalan di luar kitaran pelaksanaan tidak dijamin untuk dilaksanakan dan boleh dihentikan pada bila-bila masa. Oleh itu, anda harus sentiasa memberi isyarat dengan betul tamat pelaksanaan fungsi dan elakkan menjalankan sebarang kod di luar skop pelaksanaan fungsi.
Aktiviti latar belakang ialah apa sahaja yang berlaku selepas fungsi ditamatkan. Panggilan fungsi selesai sebaik sahaja fungsi kembali atau sebaliknya menandakan selesai, seperti dengan memanggil parameter callback
dalam fungsi dipacu peristiwa Node.js. Sebarang kod yang dijalankan selepas penamatan yang anggun tidak akan mempunyai akses kepada CPU dan tidak akan membuat sebarang kemajuan.
Selain itu, apabila panggilan berikutnya dibuat dalam persekitaran yang sama, aktiviti latar belakang anda akan disambung semula, mengganggu panggilan baharu. Ini boleh membawa kepada tingkah laku yang tidak dijangka dan kesilapan yang sukar untuk didiagnosis. Mengakses rangkaian selepas fungsi ditamatkan biasanya akan menyebabkan sambungan ditetapkan semula (ECONNRESET
kod ralat).
Aktiviti latar belakang biasanya boleh dikesan dalam log panggilan individu dengan mencari apa-apa yang dilog selepas talian selesai panggilan. Aktiviti latar belakang kadangkala boleh terkubur lebih dalam dalam kod, terutamanya apabila terdapat operasi tak segerak seperti panggilan balik atau pemasa. Semak kod anda untuk memastikan semua operasi tak segerak selesai sebelum menamatkan fungsi.
Penyelesaian lain ialah melaksanakannya sebagai fungsi dipacu peristiwa (lihat Jenis Fungsi Awan). Kemudian tentukan pencetus Pub/Sub dan topik Pub/Sub untuk fungsi ini (lihat Pub/Sub Pencetus). Pelanggan mesti ditulis semula untuk menerbitkan acara untuk topik ini.
Jika klien tidak boleh ditindih, penyelesaiannya ialah mengekalkan kedua-dua fungsi HTTP dan fungsi dipacu peristiwa, dan biarkan fungsi HTTP memunggah kerja ke fungsi dipacu peristiwa dengan menerbitkan acara ke topik. Bergantung pada saiz acara dan masa pelaksanaan tugas BigQuery, mungkin ia tidak akan membuatkan pelanggan menunggu lebih sedikit. Dan saya fikir pendekatan ini menambah kos yang ketara.
Atas ialah kandungan terperinci Cloud Functions Gen2 dengan Golang - Kitaran hayat contoh dan keselamatan sisipan BigQuery tanpa menunggu kerja selesai. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!