Mon expérience dans la création d'API Go avec Fuego
En tant que développeur Go avec plusieurs années d'expérience, j'ai exploré différents frameworks web. Mon parcours comprenait la bibliothèque standard, Gin et Fiber. Bien que chacun ait ses mérites, j'ai souvent eu besoin de plus de structure ou j'ai passé trop de temps à intégrer plusieurs bibliothèques à des fins de validation, de sérialisation et de documentation. C'est là que Fuego a changé la donne.
Au départ, Fuego semblait être juste un autre framework. Cependant, son utilisation des fonctionnalités Go modernes, notamment génériques, pour générer automatiquement des spécifications OpenAPI directement à partir du code, m'a intrigué. J'ai décidé de le tester sur un petit projet interne, et voici mon compte honnête.
Premières impressions
La simplicité de Fuego était immédiatement apparente. La configuration d'un serveur de base n'a pris que quelques minutes :
package main import "github.com/go-fuego/fuego" func main() { s := fuego.NewServer() fuego.Get(s, "/", func(c fuego.ContextNoBody) (string, error) { return "Hello, World!", nil }) s.Run() }
La familiarité était frappante : similaire à Gin, mais avec le support OpenAPI intégré.
Un exemple concret
L'exemple « Hello World » ne reflète pas les complexités du monde réel. Mon application nécessitait une gestion des données JSON, une validation et des réponses saisies. D'autres frameworks nécessitent un décodage JSON personnalisé, une gestion des erreurs et une intégration de middleware. Fuego a considérablement rationalisé cela en utilisant des gestionnaires de routes typés.
Voici un gestionnaire d'itinéraire simplifié :
type UserInput struct { Name string `json:"name" validate:"required"` } type UserOutput struct { Message string `json:"message"` } func main() { s := fuego.NewServer() fuego.Post(s, "/user", handleUser) s.Run() } func handleUser(c fuego.ContextWithBody[UserInput]) (UserOutput, error) { in, err := c.Body() if err != nil { return UserOutput{}, err } return UserOutput{Message: "Hello, " + in.Name}, nil }
Améliorations clés :
-
Gestionnaires typés :
fuego.ContextWithBody[UserInput]
désérialise automatiquement JSON dans la structureUserInput
. -
Validation :
validate:"required"
garantit que le champName
est présent ; Fuego gère les erreurs avec élégance. -
Réponses : Le renvoi d'une structure
UserOutput
la sérialise automatiquement en JSON.
Cela a éliminé un code passe-partout important : pas de json.Unmarshal
, de bibliothèques de validation externes ou de gestion des erreurs personnalisée.
Pourquoi Fuego se démarque
-
Native Go Feel : Contrairement aux frameworks qui enveloppent fortement
net/http
, Fuego se sent remarquablement natif. Il utilisenet/http
directement, permettant une intégration transparente des middleware et des gestionnaires standard. J'ai réutilisé le middleware d'authentification existant sans problème. -
Génération automatique d'OpenAPI : Auparavant, je gérais des fichiers YAML séparés ou je m'appuyais sur les commentaires pour les spécifications OpenAPI, un processus fastidieux et sujet aux erreurs. Fuego génère automatiquement les spécifications à partir des types de gestionnaires de routes, garantissant que la documentation reste toujours à jour.
-
Validation et gestion des erreurs : La validation intégrée (à l'aide de
go-playground/validator
) était intuitive et la gestion des erreurs a été simplifiée. Les structuresUserInput
invalides ont entraîné des messages d'erreur structurés conformes aux normes RFC.
Transformations de données
Pour m'assurer que tous les champs Name
entrants étaient en minuscules, j'ai utilisé la méthode InTransform
de Fuego :
package main import "github.com/go-fuego/fuego" func main() { s := fuego.NewServer() fuego.Get(s, "/", func(c fuego.ContextNoBody) (string, error) { return "Hello, World!", nil }) s.Run() }
Cela transforme automatiquement les données avant d'atteindre le gestionnaire d'itinéraire.
Défis rencontrés
-
Écosystème plus petit : La base d'utilisateurs plus petite de Fuego par rapport à Gin ou Echo a entraîné moins de ressources communautaires facilement disponibles. Cependant, les exemples et la documentation du référentiel se sont avérés suffisants.
-
Middleware intégré limité : Bien que Fuego fournisse un certain middleware, il n'est pas aussi complet que certains frameworks plus anciens.
net/http
compatibilité autorisée à l'aide de bibliothèques externes ou d'un middleware personnalisé.
Conclusion
Fuego offre un équilibre convaincant entre commodité et flexibilité. Il accélère le développement d'API grâce à la validation, la sérialisation et la génération de documentation intégrées, tout en restant fidèle aux principes de Go. Utiliser des structures typées et laisser Fuego gérer le reste a considérablement amélioré mon flux de travail.
Principaux avantages :
- Productivité accrue : Code plus propre et passe-partout réduit.
- Documentation automatisée : Spécifications OpenAPI toujours à jour.
-
Transitions fluides : Intégration facile avec les
net/http
gestionnaires existants.
Si vous recherchez un framework Go moderne et flexible, surtout si vous en avez assez de la maintenance manuelle OpenAPI, je recommande fortement Fuego. Cela a simplifié mon processus de développement tout en restant fidèle à la philosophie minimaliste de Go. Le référentiel GitHub fournit des informations complètes et une feuille de route prometteuse. Je suis enthousiasmé par son avenir et je continuerai à l'utiliser pour de futurs projets.
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

GolangisidealforPerformance-Critical Applications and Concurrent programmation, WhilepythonexcelsIndatascice, RapidPrototyping et Versatity.1)

Golang obtient une concurrence efficace par le goroutine et le canal: 1. Goroutine est un fil léger, commencé avec le mot clé GO; 2. Le canal est utilisé pour une communication sécurisée entre les Goroutines afin d'éviter les conditions de course; 3. L'exemple d'utilisation montre une utilisation de base et avancée; 4. Les erreurs courantes incluent des impasses et une concurrence de données, qui peuvent être détectées par Gorun-Race; 5. L'optimisation des performances suggère de réduire l'utilisation du canal, de définir raisonnablement le nombre de goroutines et d'utiliser Sync.Pool pour gérer la mémoire.

Golang convient plus à la programmation système et aux applications de concurrence élevées, tandis que Python est plus adapté à la science des données et au développement rapide. 1) Golang est développé par Google, en tapant statiquement, mettant l'accent sur la simplicité et l'efficacité, et convient aux scénarios de concurrence élevés. 2) Python est créé par Guidovan Rossum, dynamiquement typé, syntaxe concise, large application, adaptée aux débutants et au traitement des données.

Golang est meilleur que Python en termes de performances et d'évolutivité. 1) Les caractéristiques de type compilation de Golang et le modèle de concurrence efficace le font bien fonctionner dans des scénarios de concurrence élevés. 2) Python, en tant que langue interprétée, s'exécute lentement, mais peut optimiser les performances via des outils tels que Cython.

Le langage GO présente des avantages uniques dans la programmation simultanée, les performances, la courbe d'apprentissage, etc .: 1. La programmation simultanée est réalisée via Goroutine et Channel, qui est légère et efficace. 2. La vitesse de compilation est rapide et les performances de l'opération sont proches de celles du langage C. 3. La grammaire est concise, la courbe d'apprentissage est lisse et l'écosystème est riche.

Les principales différences entre Golang et Python sont les modèles de concurrence, les systèmes de type, les performances et la vitesse d'exécution. 1. Golang utilise le modèle CSP, qui convient aux tâches simultanées élevées; Python s'appuie sur le multi-threading et Gil, qui convient aux tâches à forte intensité d'E / S. 2. Golang est un type statique, et Python est un type dynamique. 3. La vitesse d'exécution du langage compilée de Golang est rapide, et le développement du langage interprété par Python est rapide.

Golang est généralement plus lent que C, mais Golang présente plus d'avantages dans l'efficacité de programmation et de développement simultanée: 1) Le modèle de collecte et de concurrence de Golang de Golang le fait bien fonctionner dans des scénarios à haute concurrence; 2) C obtient des performances plus élevées grâce à la gestion manuelle de la mémoire et à l'optimisation matérielle, mais a une complexité de développement plus élevée.

Golang est largement utilisé dans le cloud computing et DevOps, et ses avantages résident dans la simplicité, l'efficacité et les capacités de programmation simultanées. 1) Dans le cloud computing, Golang gère efficacement les demandes simultanées via les mécanismes de goroutine et de canal. 2) Dans DevOps, les fonctionnalités de compilation rapide de Golang et de plate-forme en font le premier choix pour les outils d'automatisation.


Outils d'IA chauds

Undresser.AI Undress
Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover
Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool
Images de déshabillage gratuites

Clothoff.io
Dissolvant de vêtements AI

AI Hentai Generator
Générez AI Hentai gratuitement.

Article chaud

Outils chauds

Listes Sec
SecLists est le compagnon ultime du testeur de sécurité. Il s'agit d'une collection de différents types de listes fréquemment utilisées lors des évaluations de sécurité, le tout en un seul endroit. SecLists contribue à rendre les tests de sécurité plus efficaces et productifs en fournissant facilement toutes les listes dont un testeur de sécurité pourrait avoir besoin. Les types de listes incluent les noms d'utilisateur, les mots de passe, les URL, les charges utiles floues, les modèles de données sensibles, les shells Web, etc. Le testeur peut simplement extraire ce référentiel sur une nouvelle machine de test et il aura accès à tous les types de listes dont il a besoin.

Version crackée d'EditPlus en chinois
Petite taille, coloration syntaxique, ne prend pas en charge la fonction d'invite de code

Envoyer Studio 13.0.1
Puissant environnement de développement intégré PHP

SublimeText3 version anglaise
Recommandé : version Win, prend en charge les invites de code !

PhpStorm version Mac
Le dernier (2018.2.1) outil de développement intégré PHP professionnel