Meningkatkan prestasi permintaan API Golang
Projek itu
Baru-baru ini saya mula mengusahakan agregator pertukaran mata wang kripto. Pada asasnya saya menghantar permintaan kepada sekumpulan pertukaran yang berbeza dan membandingkan kadar. Ini perlu dibuat secepat mungkin. Dalam siaran ini, saya akan menunjukkan beberapa tweak yang saya buat untuk meningkatkan prestasi saya dengan ketara.
Namun perlu diingat bahawa saya bukan pakar (terutamanya dalam perjalanan) dan saya hanya berkongsi penemuan saya daripada projek peribadi saya sendiri.
Penambahbaikan
Peningkatan ini datang dalam urutan peningkatan terbesar masa jalan.
1. Menggunakan goroutine
Dalam mana-mana program Go, goroutine adalah penting untuk kelajuan. Rangsangan terbesar yang saya buat adalah dengan menghantar permintaan secara serentak. Memandangkan saya perlu mendapatkan 12 pertukaran yang berbeza, menghantar permintaan ini pada masa yang sama mengurangkan masa jalan saya daripada sekitar 24 saat kepada hanya ~3.
Gorutin sangat mengagumkan dan sangat mudah digunakan. Anda harus memasukkannya di mana mungkin. Tetapi sentiasa berhati-hati dengan Data Races
2. Menaik taraf Pustaka JSON
Saya menukar pengekodan/json untuk github.com/json-iterator/go.jsoniter ialah perpustakaan pemprosesan JSON pantas yang berfungsi sebagai pengganti drop-in untuk perpustakaan standard, jadi saya tidak perlu menukar sebarang kod , hanya suis perpustakaan.
Keputusan Penanda Aras
Untuk mengukur peningkatan prestasi, saya menjalankan beberapa penanda aras membandingkan pengekodan/json dan jsoniter. Berikut ialah ringkasan keputusan:
goos: linux goarch: amd64 pkg: apiSpeedImprove cpu: AMD Ryzen 5 7640U w/ Radeon 760M Graphics BenchmarkEncodingJSON-12 140383 7381 ns/op BenchmarkJSONIter-12 974605 1217 ns/op PASS ok apiSpeedImprove 3.216s
Jadi, jsoniter adalah kira-kira 6 kali lebih pantas daripada perpustakaan standard.
3. Menggunakan Semula Pengendali HTTP
Saya mula menggunakan semula pengendali HTTP dan bukannya membuat yang baharu untuk setiap permintaan. Dengan menyediakan pengendali sekali dan menggunakannya semula, saya mengurangkan kos pengeluaran untuk membuat pengendali baharu untuk setiap permintaan.
Keputusan Penanda Aras
Berikut ialah hasil penanda aras yang membandingkan pengendali yang digunakan semula berbanding membuat pengendali baharu untuk setiap permintaan:
goos: linux goarch: amd64 pkg: apiSpeedImprove/httpReuse cpu: AMD Ryzen 5 7640U w/ Radeon 760M Graphics BenchmarkReusedHandler-12 2179 505189 ns/op BenchmarkNewHandlerPerRequest-12 2341 507525 ns/op PASS ok apiSpeedImprove/httpReuse 7.270s
Menggunakan semula pengendali HTTP memberikan sedikit peningkatan prestasi berbanding dengan membuat pengendali baharu untuk setiap permintaan.
Kesimpulan
Dengan tweak ini saya berjaya mengurangkan masa yang diambil untuk mengumpulkan semua maklumat daripada 24 saat pada mulanya kepada kira-kira 2 saat. Peningkatan yang cukup mantap!
Jika anda berminat dengan kod untuk penanda aras saya, ia boleh didapati di sini
Jika anda menyukai siaran ini dan ingin menyokong kerja saya, anda boleh menderma di sini.
Atas ialah kandungan terperinci Meningkatkan prestasi permintaan API Golang. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Alat AI Hot

Undress AI Tool
Gambar buka pakaian secara percuma

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

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

Clothoff.io
Penyingkiran pakaian AI

Video Face Swap
Tukar muka dalam mana-mana video dengan mudah menggunakan alat tukar muka AI percuma kami!

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)

Cara yang paling berkesan untuk menulis Kubernetesoperator adalah untuk menggunakan Go untuk menggabungkan Kubebuilder dan pengawal-runtime. 1. Memahami corak pengendali: Tentukan sumber tersuai melalui CRD, tulis pengawal untuk mendengar perubahan sumber dan lakukan gelung perdamaian untuk mengekalkan keadaan yang diharapkan. 2. Gunakan Kubebuilder untuk memulakan projek dan membuat API untuk menghasilkan CRD, pengawal dan konfigurasi secara automatik. 3. Tentukan spec dan struktur status CRD dalam API/V1/MYAPP_TYPES.GO, dan menjalankan makeManifests untuk menjana cRDYAML. 4. Daftar masuk dalam pengawal

Panik adalah seperti program "serangan jantung" di Go. Pulih boleh digunakan sebagai "alat pertolongan cemas" untuk mencegah kemalangan, tetapi pulih hanya berkuatkuasa dalam fungsi penangguhan. 1.Recover digunakan untuk mengelakkan kelewatan perkhidmatan, log log, dan kesilapan yang mesra. 2. Ia mesti digunakan bersempena dengan menangguhkan dan hanya berkuatkuasa pada goroutine yang sama. Program ini tidak kembali ke titik panik selepas pemulihan. 3. Adalah disyorkan untuk menggunakannya di peringkat atas atau pintu masuk kritikal, dan tidak menyalahgunakannya, dan memberi keutamaan untuk menggunakan pemprosesan ralat. 4. Corak umum adalah untuk merangkum fungsi Saferun untuk membungkus logik panik yang mungkin. Hanya dengan menguasai senario penggunaannya dan batasan boleh memainkan peranannya dengan betul.

Peruntukan Stack sesuai untuk pembolehubah tempatan kecil dengan kitaran hayat yang jelas, dan diuruskan secara automatik, dengan kelajuan yang cepat tetapi banyak sekatan; Peruntukan timbunan digunakan untuk data dengan kitaran hayat yang panjang atau tidak pasti, dan fleksibel tetapi mempunyai kos prestasi. Pengkompil GO secara automatik menentukan kedudukan peruntukan pembolehubah melalui analisis melarikan diri. Jika pembolehubah boleh melarikan diri dari skop fungsi semasa, ia akan diperuntukkan kepada timbunan. Situasi biasa yang menyebabkan melarikan diri termasuk: mengembalikan penunjuk pembolehubah tempatan, memberikan nilai kepada jenis antara muka, dan lulus dalam goroutine. Hasil analisis melarikan diri dapat dilihat melalui -gcflags = " -m". Apabila menggunakan petunjuk, anda harus memberi perhatian kepada kitaran hidup yang berubah -ubah untuk mengelakkan pelarian yang tidak perlu.

HTTP Log Middleware di GO boleh merakam kaedah permintaan, laluan, IP klien dan memakan masa. 1. Gunakan http.handlerfunc untuk membungkus pemproses, 2. Rekod waktu mula dan masa akhir sebelum dan selepas memanggil next.servehttp, 3. Dapatkan IP pelanggan sebenar melalui r.remoteaddr dan X-forward-for headers, 4. Gunakan log.printf untuk mengeluarkan log permintaan, 5. Kod sampel lengkap telah disahkan untuk dijalankan dan sesuai untuk memulakan projek kecil dan sederhana. Cadangan lanjutan termasuk menangkap kod status, menyokong log JSON dan meminta penjejakan ID.

GO Language boleh digunakan untuk pengiraan saintifik dan analisis berangka, tetapi perlu difahami. Kelebihannya terletak pada sokongan dan prestasi konkurensi, yang sesuai untuk algoritma selari seperti penyelesaian yang diedarkan, simulasi Monte Carlo, dan sebagainya; Perpustakaan komuniti seperti gonum dan MAT64 menyediakan fungsi pengiraan numerik asas; Pengaturcaraan hibrid boleh digunakan untuk memanggil C/C dan Python melalui CGO atau antara muka untuk meningkatkan kepraktisan. Batasannya adalah bahawa ekosistem tidak matang seperti python, visualisasi dan alat lanjutan lebih lemah, dan beberapa dokumen perpustakaan tidak lengkap. Adalah disyorkan untuk memilih senario yang sesuai berdasarkan ciri GO dan merujuk kepada contoh kod sumber untuk menggunakannya secara mendalam.

Gunakan fmt.scanf untuk membaca input diformat, sesuai untuk data berstruktur yang mudah, tetapi rentetan dipotong ketika menghadapi ruang; 2. Adalah disyorkan untuk menggunakan bufio.scanner untuk membaca garis demi baris, menyokong input berbilang baris, pengesanan EOF dan input saluran paip, dan boleh mengendalikan kesilapan pengimbasan; 3. Gunakan io.readall (os.stdin) untuk membaca semua input sekaligus, sesuai untuk memproses data blok besar atau aliran fail; 4. Sambutan utama masa nyata memerlukan perpustakaan pihak ketiga seperti golang.org/x/term, dan Bufio mencukupi untuk senario konvensional; Cadangan Praktikal: Gunakan fmt.scan untuk input mudah interaktif, gunakan bufio.scanner untuk input baris atau saluran paip, gunakan io.readall untuk data blok besar, dan sentiasa mengendalikan

Pernyataan Switch GO tidak akan dilaksanakan sepanjang proses secara lalai dan secara automatik akan keluar selepas memadankan keadaan pertama. 1. Suis bermula dengan kata kunci dan boleh membawa satu atau tiada nilai; 2. Kes perlawanan dari atas ke bawah dalam urutan, hanya perlawanan pertama yang dijalankan; 3. Pelbagai syarat boleh disenaraikan oleh koma untuk memadankan kes yang sama; 4. Tidak perlu menambah rehat secara manual, tetapi boleh dipaksa melalui; 5.Default digunakan untuk kes -kes yang tidak dapat ditandingi, biasanya diletakkan pada akhir.

Go Generik disokong sejak 1.18 dan digunakan untuk menulis kod generik untuk jenis selamat. 1. Fungsi generik printslice [tany] (s [] t) boleh mencetak kepingan mana -mana jenis, seperti [] int atau [] rentetan. 2. Melalui had bilangan kekangan jenis t ke jenis angka seperti int dan float, jumlah [tnumber] (slice [] t) t Summation selamat direalisasikan. 3. Struktur generik Typebox [Tany] struct {valuet} boleh merangkum sebarang nilai jenis dan digunakan dengan pembina kotak baru [Tany] (Vt)*. 4. Tambahkan set (vt) dan dapatkan () kaedah t untuk kotak [t] tanpa
