Rumah >pembangunan bahagian belakang >Golang >Laravel to Go: My Journey and the Creation of Fiber API Boilerplate

Laravel to Go: My Journey and the Creation of Fiber API Boilerplate

Susan Sarandon
Susan Sarandonasal
2024-12-29 11:02:11925semak imbas

Laravel to Go: My Journey and the Creation of a Fiber API Boilerplate

Setelah menghabiskan lebih daripada empat tahun berendam dalam Laravel, saya sudah sangat mengenali seni bina MVC (Model-View-Controller). Kesederhanaan dan strukturnya menjadikannya menyeronokkan untuk bekerja, dan folder Laravel yang disusun dengan teliti membantu pembangun berada di landasan yang betul. Anda sentiasa tahu tempat untuk meletakkan kod anda, dan alatan terbina dalam yang meluas—sambungan pangkalan data, Redis, baris gilir, migrasi, ORM dan banyak lagi—membuat persediaan lancar. Dengan hanya beberapa tweak pada persekitaran anda, apl anda sedia untuk digunakan.

Bagi saya, pendekatan MVC Laravel kekal sebagai salah satu yang paling mantap. Model mentakrifkan data anda, Paparan menentukan perkara yang pengguna lihat dan Pengawal mengurus logik perniagaan anda. Ia mudah tetapi berstruktur, dan Laravel menyampaikan persediaan ini secara lalai, menjadikannya rangka kerja yang sangat baik untuk pembangunan.

Tetapi apabila kerjaya saya meningkat dan saya bekerja merentas industri dan perniagaan, saya menyedari bahawa pendekatan MVC Laravel tidak selalu mencukupi, terutamanya untuk aplikasi yang kompleks.


Memperluaskan MVC Laravel untuk Kerumitan

MVC bersinar untuk aplikasi mudah tetapi boleh gagal apabila logik menjadi lebih rumit. Sebagai contoh, apabila menggunakan Laravel untuk API, lapisan Paparan selalunya tidak digunakan. Sementara itu, meletakkan semua logik dalam pengawal dengan cepat boleh membawa kepada fail kembung yang sukar diselenggara.

Untuk menangani perkara ini, saya melanjutkan struktur MVC Laravel dengan memperkenalkan lapisan Perkhidmatan dan Repositori, mencipta aliran seperti ini:

Pengawal → Perkhidmatan → Repositori → Model

  • Pengawal: Mengendalikan pengesahan dan mengarahkan aliran aplikasi.
  • Perkhidmatan: Mengurus logik perniagaan, dipecahkan kepada fungsi boleh guna semula.
  • Repositori: Mengurus interaksi pangkalan data.
  • Model: Mentakrifkan struktur data.

Pendekatan berlapis ini menjadikan kod lebih boleh diselenggara dan berskala. Lama kelamaan, saya menjadi terbiasa dengan struktur ini sehinggakan ia berasa semula jadi untuk mengguna pakainya dalam projek lain.


Masukkan Go: A Whole New Challenge

Apabila saya mula bekerja dengan Go (Golang), rasanya seperti melangkah ke wilayah yang belum dipetakan. Go agak berbeza daripada PHP dan tidak mempunyai struktur folder yang wujud. Ia juga bukan bahasa berorientasikan objek, jadi saya tidak boleh meniru apa yang saya tahu daripada Laravel.

Selepas beberapa percubaan dan kesilapan, saya memutuskan untuk kekal dengan perkara yang saya kenali: konsep CSRM (Pengawal, Perkhidmatan, Repositori, Model). Saya menyesuaikan struktur ini kepada Go, walaupun ia memerlukan pemikiran kreatif. Selain itu, saya meneroka rangka kerja yang boleh memudahkan pembangunan. Saya mencuba Gin dan Fiber, akhirnya memilih Fiber untuk kelajuan, ciri moden dan komuniti yang aktif.


Kelahiran My Fiber API Boilerplate

Selepas lebih daripada dua tahun bekerja dengan Go dan Fiber, saya memutuskan untuk mencipta boilerplate untuk menyelaraskan pembangunan API. Ini bukan sahaja untuk saya—saya juga ingin membantu orang lain menyediakan projek mereka dengan pantas.

Hasilnya: Fiber API Boilerplate.

Pelat dandang ini khusus untuk API, jadi ia tidak termasuk ciri seperti pemaparan paparan atau enjin templat. Struktur folder mendapat inspirasi daripada:

  • Piawaian Susun atur Projek Golang
  • Ayoub Zulfiqar’s Project Layout Gist

Saya juga meminjam banyak idea daripada Laravel, seperti ORM, sambungan pangkalan data, Redis, baris gilir dan pengesahan. Walaupun ia tidak menyeluruh seperti Laravel, ia lebih daripada mencukupi untuk membina API umum.


Ciri-ciri Boilerplate

Inilah yang ditawarkan oleh boilerplate pada masa ini:

  1. Pengesahan: Pengurusan pengguna dipermudahkan di luar kotak.
  2. Pelaporan Ralat: Disepadukan dengan Sentry.
  3. Pemantauan Aplikasi: Menggunakan Relik Baharu untuk cerapan masa nyata.
  4. Muat Semula Panas: Termasuk Udara untuk pembangunan yang lebih pantas.
  5. Pemeriksaan Kod Statik: Menggunakan GolangCI-Lint.
  6. Dokumentasi API: Sokongan Swagger Terbina dalam melalui Swag.
  7. Suntikan Kebergantungan: Dikuasakan oleh Google Wire.
  8. Pengerahan: Didatangkan dengan Docker dan Penyelia untuk penggunaan yang lancar.

Repositori juga termasuk kod contoh dan README terperinci untuk membimbing anda melalui setiap folder dan ciri.


Membina untuk Masa Depan

Walaupun boilerplate sudah berfungsi, saya mempunyai rancangan untuk mengembangkannya lagi dengan menambahkan alatan seperti migrasi, pendengar acara dan arahan. Ia merupakan projek berkembang yang direka untuk berkembang bersama penggunanya.

Anda dialu-alukan untuk meneroka dan menggunakan boilerplate. Jangan ragu untuk menyesuaikannya—tambahkan alat yang anda suka atau alih keluar alat yang anda tidak perlukan. Jika anda mempunyai cadangan atau permintaan ciri, buat isu atau serahkan permintaan tarik.


Mulakan

Lihat Fiber API Boilerplate dan ambil pusingannya. Saya harap ia membantu memudahkan perjalanan pembangunan API Go anda sama seperti yang saya lakukan. Mari kita bina sesuatu yang menakjubkan bersama-sama!

Atas ialah kandungan terperinci Laravel to Go: My Journey and the Creation of Fiber API Boilerplate. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan:
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