Heim > Backend-Entwicklung > Golang > Laravel to Go: Meine Reise und die Erstellung einer Faser-API-Boilerplate

Laravel to Go: Meine Reise und die Erstellung einer Faser-API-Boilerplate

Susan Sarandon
Freigeben: 2024-12-29 11:02:11
Original
900 Leute haben es durchsucht

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

Nachdem ich mehr als vier Jahre in Laravel verbracht habe, bin ich mit der MVC-Architektur (Model-View-Controller) sehr vertraut geworden. Seine Einfachheit und Struktur machen die Arbeit damit zum Vergnügen und die sorgfältig organisierten Ordner von Laravel helfen Entwicklern, den Überblick zu behalten. Sie wissen immer, wo Sie Ihren Code platzieren müssen, und die umfangreichen integrierten Tools – Datenbankverbindungen, Redis, Warteschlangen, Migrationen, ORM und mehr – sorgen für eine reibungslose Einrichtung. Mit nur wenigen Anpassungen an Ihrer Umgebung ist Ihre App einsatzbereit.

Für mich bleibt der MVC-Ansatz von Laravel einer der robustesten. Das Modell definiert Ihre Daten, die Ansicht bestimmt, was Benutzer sehen, und der Controller verwaltet Ihre Geschäftslogik. Es ist einfach, aber strukturiert, und Laravel liefert dieses Setup standardmäßig mit, was es zu einem hervorragenden Framework für die Entwicklung macht.

Aber als meine Karriere voranschritt und ich branchen- und unternehmensübergreifend arbeitete, wurde mir klar, dass der MVC-Ansatz von Laravel nicht immer ausreichte, insbesondere für komplexe Anwendungen.


Erweiterung von Laravels MVC für Komplexität

MVC glänzt bei einfachen Anwendungen, kann jedoch versagen, wenn die Logik komplexer wird. Wenn Sie beispielsweise Laravel für APIs verwenden, bleibt die Ebene Ansicht häufig ungenutzt. Unterdessen kann die Unterbringung der gesamten Logik in Controllern schnell zu aufgeblähten Dateien führen, die schwer zu warten sind.

Um dieses Problem zu beheben, habe ich die MVC-Struktur von Laravel durch die Einführung der Schichten Service und Repository erweitert und so einen Ablauf wie diesen erstellt:

Controller → Service → Repository → Modell

  • Controller: Verwaltet die Validierung und steuert den Anwendungsfluss.
  • Dienst: Verwaltet Geschäftslogik, aufgeteilt in wiederverwendbare Funktionen.
  • Repository: Verwaltet Datenbankinteraktionen.
  • Modell: Definiert die Datenstruktur.

Dieser mehrschichtige Ansatz macht den Code wartbarer und skalierbarer. Mit der Zeit habe ich mich so sehr an diese Struktur gewöhnt, dass es für mich selbstverständlich war, sie auch in anderen Projekten zu übernehmen.


Geben Sie Go ein: Eine ganz neue Herausforderung

Als ich anfing, mit Go (Golang) zu arbeiten, fühlte es sich an, als würde ich Neuland betreten. Go unterscheidet sich stark von PHP und verfügt nicht über eine inhärente Ordnerstruktur. Da es sich auch nicht um eine objektorientierte Sprache handelt, konnte ich das, was ich von Laravel wusste, nicht einfach reproduzieren.

Nach einigem Ausprobieren habe ich beschlossen, bei dem zu bleiben, was mir bekannt war: dem CSRM-Konzept (Controller, Service, Repository, Modell). Ich habe diese Struktur an Go angepasst, auch wenn dafür etwas kreatives Denken erforderlich war. Darüber hinaus habe ich Frameworks untersucht, die die Entwicklung vereinfachen könnten. Ich habe Gin und Fiber ausprobiert und mich letztendlich aufgrund der Geschwindigkeit, der modernen Funktionen und der aktiven Community für Fiber entschieden.


Die Geburt meines Fiber-API-Boilerplates

Nachdem ich mehr als zwei Jahre lang mit Go und Fibre gearbeitet hatte, beschloss ich, ein Standardmodell zu erstellen, um die API-Entwicklung zu optimieren. Das war nicht nur für mich – ich wollte auch anderen helfen, ihre Projekte schnell umzusetzen.

Das Ergebnis: Fiber API Boilerplate.

Dieses Boilerplate ist speziell für APIs gedacht und enthält daher keine Funktionen wie Ansichtsrendering oder Vorlagen-Engines. Die Ordnerstruktur ist inspiriert von:

  • Golang-Projektlayoutstandards
  • Ayoub Zulfiqars Projektlayout-Kerninhalt

Ich habe auch viele Ideen von Laravel übernommen, wie zum Beispiel ORM, Datenbankverbindungen, Redis, Warteschlangen und Authentifizierung. Es ist zwar nicht so umfassend wie Laravel, aber für die Erstellung allgemeiner APIs mehr als ausreichend.


Merkmale der Boilerplate

Das bietet das Boilerplate derzeit:

  1. Authentifizierung: Vereinfachte Benutzerverwaltung sofort einsatzbereit.
  2. Fehlerberichterstattung: Integriert in Sentry.
  3. Anwendungsüberwachung: Verwendet New Relic für Echtzeit-Einblicke.
  4. Hot Reload: Enthält Luft für eine schnellere Entwicklung.
  5. Statische Codeprüfungen: Verwendet GolangCI-Lint.
  6. API-Dokumentation: Integrierte Swagger-Unterstützung über Swag.
  7. Abhängigkeitsinjektion: Unterstützt von Google Wire.
  8. Bereitstellung: Kommt mit Docker und Supervisor für eine nahtlose Bereitstellung.

Das Repository enthält außerdem Beispielcode und eine detaillierte README-Datei, die Sie durch jeden Ordner und jede Funktion führt.


Bauen für die Zukunft

Während das Boilerplate bereits funktionsfähig ist, habe ich Pläne, es durch das Hinzufügen von Tools wie Migrationen, Ereignis-Listenern und Befehlen weiter zu erweitern. Es handelt sich um ein sich entwickelndes Projekt, das darauf ausgelegt ist, mit seinen Benutzern zu wachsen.

Sie können die Boilerplate gerne erkunden und nutzen. Sie können es jederzeit anpassen – fügen Sie Tools hinzu, die Ihnen gefallen, oder entfernen Sie diejenigen, die Sie nicht benötigen. Wenn Sie Vorschläge oder Funktionswünsche haben, erstellen Sie ein Problem oder senden Sie eine Pull-Anfrage.


Legen Sie los

Schauen Sie sich die Fiber API Boilerplate an und probieren Sie es aus. Ich hoffe, dass es Ihre Reise zur Go-API-Entwicklung genauso vereinfacht wie für mich. Lasst uns gemeinsam etwas Großartiges aufbauen!

Das obige ist der detaillierte Inhalt vonLaravel to Go: Meine Reise und die Erstellung einer Faser-API-Boilerplate. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Quelle:dev.to
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Neueste Artikel des Autors
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage