


Création de microservices à l'aide du framework Web de Golang Echo Framework
Ces dernières années, avec le développement rapide de la technologie Internet, l'architecture des microservices est devenue un modèle d'architecture logicielle adopté par de plus en plus d'entreprises. Par rapport à une seule application à grande échelle, l'architecture de microservice divise une application à grande échelle en plusieurs petits services. Chaque service peut être déployé, étendu et entretenu indépendamment, améliorant ainsi l'efficacité du développement et la fiabilité des applications. Cet article explique comment créer un microservice simple à l'aide du framework Web Echo de Golang.
1. Qu'est-ce que le framework Echo ?
Echo est un framework web performant, léger, simple et élégant basé sur le langage Golang et adopte le modèle d'architecture MVC (Model-View-Controller), ce qui signifie que nous pouvons facilement Divisez l'application en trois couches : modèle, vue et contrôleur.
En raison de l'émergence du framework Echo, il n'est plus nécessaire d'utiliser la bibliothèque native net/http pour le développement. Echo fournit un routage élégant, un middleware puissant, un traitement rapide des requêtes et des réponses HTTP, etc.
2. Installez le framework Echo
Pour utiliser le framework Echo, vous devez d'abord l'installer. Nous pouvons utiliser la commande go get pour installer le framework Echo :
go get -u github.com/labstack/echo/v4
Cette commande téléchargera le framework Echo depuis Github et l'installera sous github.com/labstack/echo/v4 dans le répertoire src de GOPATH.
3. Utilisez le framework Echo pour créer des microservices
Après avoir installé le framework Echo, nous pouvons commencer à créer un microservice simple.
Créez un répertoire nommé echo-demo sous GOPATH, et créez un fichier nommé main.go dans ce répertoire :
package main import ( "net/http" "github.com/labstack/echo/v4" ) func main() { // create echo instance e := echo.New() // define route e.GET("/", func(c echo.Context) error { return c.String(http.StatusOK, "Hello, World!") }) // start server e.Logger.Fatal(e.Start(":8080")) }
Dans le code, nous avons d'abord importé "net/http" et "github.com/labstack/echo/v4 " emballer. Ensuite, nous avons créé une instance Echo e et défini une route "/". Lors de l'accès au répertoire racine "/", "Hello, World!"
Enfin, nous utilisons "e.Logger.Fatal(e.Start(":8080"))" pour démarrer le serveur Echo et spécifier le numéro de port comme 8080. À ce stade, nous pouvons saisir « http://localhost:8080 » dans le navigateur pour accéder à notre microservice, et nous devrions voir « Hello, World !
4. Créez des microservices plus complexes
Ce qui précède n'est qu'un exemple simple de microservices. Dans des applications réelles, vous devrez peut-être créer des microservices plus complexes. Dans le framework Echo, nous pouvons créer des microservices plus complets grâce à des fonctions telles que le middleware, la liaison de paramètres et le rendu de modèles.
- Middleware
Le Middleware est une fonction très puissante et pratique dans le framework Echo. Il peut ajouter une logique de traitement supplémentaire pendant tout le processus, du client envoyant une requête au serveur répondant à la requête. Dans le framework Echo, nous pouvons utiliser la méthode Use() pour enregistrer un middleware.
Exemple :
func main() { //create echo instance e := echo.New() //define middleware e.Use(middleware.Logger()) //define route e.GET("/", func(c echo.Context) error { return c.String(http.StatusOK, "Hello, World!") }) //start server e.Logger.Fatal(e.Start(":8080")) }
Dans l'exemple ci-dessus, nous utilisons e.Use(middleware.Logger()) pour enregistrer un middleware. Ce middleware imprimera des informations telles que la méthode, l'URI, la taille du corps de la requête et le code de réponse de chaque requête avant que la requête n'atteigne la méthode de traitement de routage correspondante. Cela nous permet de comprendre plus clairement la situation de la demande lors du débogage, en particulier lorsque la demande est anormale, et nous pouvons bien comprendre le traitement de la demande et de la réponse, ce qui facilite grandement notre développement et notre dépannage.
- Liaison de paramètres
Le framework Echo dispose d'une puissante fonction de liaison de paramètres qui peut nous aider à extraire les paramètres des requêtes HTTP, afin que les données puissent être facilement transmises au gestionnaire sans extraire manuellement les données. Les formats courants pour la liaison de paramètres sont JSON, XML, les paramètres de formulaire et de requête, etc.
Exemple :
type User struct { Name string `json:"name"` Email string `json:"email"` } func main() { // create echo instance e := echo.New() // define route for create user e.POST("/users/create", func(c echo.Context) error { // bind json data to struct instance u := new(User) if err := c.Bind(u); err != nil { return err } return c.JSON(http.StatusCreated, u) }) // start server e.Logger.Fatal(e.Start(":8080")) }
Dans l'exemple ci-dessus, nous avons défini une structure User puis créé une route "/users/create". Lorsque la requête appelle la route en mode POST, les données de la requête au format JSON seront automatiquement. se lie à l'instance de structure User u, puis renvoie la réponse au format JSON de l'instance.
- Rendu de modèles
Le framework Echo prend également en charge plusieurs moteurs de modèles, tels que HTML, JSON, etc. Nous pouvons utiliser la méthode Render fournie par le framework pour le rendu des modèles.
Exemple :
func main() { // create echo instance e := echo.New() // use html renderer e.Renderer = &Template{ templates: template.Must(template.ParseGlob("templates/*.html")), } // define route e.GET("/users/:id", func(c echo.Context) error { id := c.Param("id") u := User{Id: id, Name: "jack", Email: "jack@sample.com"} return c.Render(http.StatusOK, "user.html", u) }) // start server e.Logger.Fatal(e.Start(":8080")) }
Dans l'exemple ci-dessus, nous utilisons &Template{} pour créer le moteur de modèle et utilisons la méthode ParseGlob() pour spécifier le chemin d'accès au fichier modèle. Ensuite, dans l'implémentation du routage, nous utilisons la méthode c.Param() pour obtenir les paramètres de routage, utilisons la structure User pour construire les données et enfin utilisons la méthode c.Render() pour restituer le modèle et renvoyer la réponse.
5. Résumé
Le framework Echo est un framework Web Golang simple et élégant avec des performances élevées et des fonctionnalités légères. L'utilisation du framework Echo pour créer des microservices peut améliorer l'efficacité du développement et la fiabilité des applications. Vous pouvez apprendre l'utilisation de base d'Echo à travers les exemples ci-dessus, et vous pouvez également ajuster et améliorer l'architecture des microservices dans les applications réelles.
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!

GOISASTRONGCHOICEFORPROSTRESSNEDINGSIMPLICITY, Performance et Concurrence, ButMaylackinAdvancedFeaturesAnSystemMaturity.1) Go'SyntaxisSIMPLEADEASYTOLEARN, LeadToFewerBugsandMoreMaintAwing

Go'SinitFonctionnalandjava'sstaticitialisersbothservetOsEtunvironments peut-être la fonctionnalisation de la manière, mais ladifferinexecution et leControl.

The CommermonusecasesFortFortFonctioningoAre: 1) ChargeingConfigurationFiles est en train de faire la diffusion de programmes, 2) d'initialiser les globalvariables, et3) RunningPre-Checkorvalidations est possible

Les canaux se sont émeurés de la création de personnes interrogées entre les degortines.

Dans GO, les erreurs peuvent être enveloppées et le contexte peut être ajouté via des méthodes Errors.Wrap et Errors.unwrap. 1) En utilisant la nouvelle fonctionnalité du package Erreurs, vous pouvez ajouter des informations de contexte lors de la propagation des erreurs. 2) Aidez à localiser le problème en emballage les erreurs via fmt.errorf et% w. 3) Les types d'erreur personnalisés peuvent créer des erreurs plus sémantiques et améliorer la capacité expressive de la gestion des erreurs.

Gooffersrobustfeaturesforsecucoding, ButdeveloversMustimplementSecurityBestPracticeseffectively.1) usego'scryptopackageforsecureatahandling.2) manageCurrencywithSynchronizationPrimiTeStOpreventraceConDITIONS.3)

L'interface d'erreur de Go est définie comme TypeErrorInterface {error () String}, permettant à tout type qui implémente la méthode Error () d'être considérée comme une erreur. Les étapes à utiliser sont les suivantes: 1. Fondamentalement, vérifiez et journalisez les erreurs, telles que IFERR! = NIL {log.printf ("ANERROROCCURRED:% V", ERR) RETOUR}. 2. Créez un type d'erreur personnalisé pour fournir plus d'informations, telles que TypeMyErrorStruct {msgStringDetailString}. 3. Utilisez des emballages d'erreur (depuis Go1.13) pour ajouter du contexte sans perdre le message d'erreur d'origine,

Toefficativement handleerrorsinconcurrentGOprograms, usEchannelStoCommunicateErrors, metterororwatchers, considérer les channeaux usuered, et les fournisseurs


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

Video Face Swap
Échangez les visages dans n'importe quelle vidéo sans effort grâce à notre outil d'échange de visage AI entièrement gratuit !

Article chaud

Outils chauds

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

SublimeText3 version chinoise
Version chinoise, très simple à utiliser

MinGW - GNU minimaliste pour Windows
Ce projet est en cours de migration vers osdn.net/projects/mingw, vous pouvez continuer à nous suivre là-bas. MinGW : un port Windows natif de GNU Compiler Collection (GCC), des bibliothèques d'importation et des fichiers d'en-tête librement distribuables pour la création d'applications Windows natives ; inclut des extensions du runtime MSVC pour prendre en charge la fonctionnalité C99. Tous les logiciels MinGW peuvent fonctionner sur les plates-formes Windows 64 bits.

mPDF
mPDF est une bibliothèque PHP qui peut générer des fichiers PDF à partir de HTML encodé en UTF-8. L'auteur original, Ian Back, a écrit mPDF pour générer des fichiers PDF « à la volée » depuis son site Web et gérer différentes langues. Il est plus lent et produit des fichiers plus volumineux lors de l'utilisation de polices Unicode que les scripts originaux comme HTML2FPDF, mais prend en charge les styles CSS, etc. et présente de nombreuses améliorations. Prend en charge presque toutes les langues, y compris RTL (arabe et hébreu) et CJK (chinois, japonais et coréen). Prend en charge les éléments imbriqués au niveau du bloc (tels que P, DIV),

DVWA
Damn Vulnerable Web App (DVWA) est une application Web PHP/MySQL très vulnérable. Ses principaux objectifs sont d'aider les professionnels de la sécurité à tester leurs compétences et leurs outils dans un environnement juridique, d'aider les développeurs Web à mieux comprendre le processus de sécurisation des applications Web et d'aider les enseignants/étudiants à enseigner/apprendre dans un environnement de classe. Application Web sécurité. L'objectif de DVWA est de mettre en pratique certaines des vulnérabilités Web les plus courantes via une interface simple et directe, avec différents degrés de difficulté. Veuillez noter que ce logiciel
