Qu'est - ce qu'un microservice pour Java Spring Cloud + Spring Boot Enterprise Quick Development architecture?Quels sont ses avantages et ses inconvénients?

Utilisateur bpcufjr 2021-09-15 09:24:12
qu est ce qu microservice



“Microservices”Le mot vient de Martin Fowler De《Microservices》Un article..Le micro - service est un style architectural,Diviser les applications individuelles en petites unités de service,Utilisation entre microservices HTTP De API Effectuer l'accès aux ressources et les opérations.

De l'avis de l'auteur,L'évolution de l'architecture des microservices ressemble davantage à un processus d'entreprise,Depuis les premières petites entreprises,Jusqu'aux grands groupes plus tard.Les grands groupes peuvent diviser plusieurs filiales,Chaque filiale a sa propre entreprise indépendante、Personnel,Développement individuel,Aucune influence mutuelle,Ensemble, c'est une puissance infinie.

Un système gonflé、Code répété、Le temps de démarrage excessif n'apporte qu'une plainte infinie aux développeurs,Il n'y a rien de si confortable、C'est très fluide d'écrire du Code.Ils ont passé la plupart de leur temps à résoudre des problèmes et à lancer des projets.

Avantages de l'architecture des microservices
L'utilisation de l'architecture des microservices peut nous apporter les avantages suivants:

1)Déploiement indépendant des services
Chaque service est un projet autonome,Peut être déployé indépendamment,Ne dépend pas d'autres services,Faible couplage.

2)Démarrage rapide du service
Le service doit démarrer beaucoup plus rapidement après le fractionnement qu'avant le fractionnement,Parce qu'il y a moins de bibliothèques dépendantes,Il y a aussi moins de code.

3)Mieux adapté au développement Agile
Le développement agile est centré sur l'évolution des besoins des utilisateurs,Utiliser l'itération、Une approche progressive.Le Service Split vous permet de publier rapidement de nouvelles versions,Il suffit de publier le service correspondant pour modifier quel service,Pas de republication complète.

4)Responsabilité exclusive, Les services spécialisés sont assurés par des équipes spécialisées
Quand les affaires se développent rapidement , .De plus en plus de chercheurs , Chaque équipe peut être responsable du secteur d'activité correspondant , La séparation des services facilite la Division du travail entre les équipes .

5) Le service peut être étendu dynamiquement sur demande
Lorsque le nombre d'accès à un service est élevé , Il suffit d'agrandir ce service .

6) Réutilisation du Code
Chaque service est disponible REST API, Tous les services de base doivent être retirés , De nombreuses implémentations sous - jacentes peuvent être fournies sous forme d'interfaces .

Inconvénients de l'architecture des microservices
Microservice est en fait une épée à double tranchant , Si c'est bon, c'est mauvais. . Parlons des inconvénients du micro - service , Et ce qui peut être fait pour éviter .

1)Déploiement réparti, La complexité de l'appel est élevée
Quand le monomère est appliqué , Tous les appels antérieurs au module sont effectués localement ,En microservice, Chaque module est déployé indépendamment ,Adoption HTTP Pour communiquer, Il y a beaucoup de problèmes , Comme les problèmes de réseau 、 Problèmes de tolérance aux pannes 、 Relations d'appel, etc .

2) Base de données indépendante ,Défis liés aux transactions distribuées
Chaque microservice possède sa propre base de données , C'est ce qu'on appelle la gestion décentralisée des données . L'avantage de ce modèle réside dans les différents services , Vous pouvez choisir les données qui conviennent à votre entreprise , Par exemple, le Service de commande peut être utilisé MySQL、 Le Service de commentaires est disponible en Mongodb、 Le Service de recherche de produits est disponible en Elasticsearch.

L'inconvénient est le problème de la transaction , La solution idéale à l'heure actuelle est la cohérence ultime dans les transactions flexibles , Les chapitres suivants vous donneront des détails .

3) La difficulté du test augmente
Les services et les services interagissent par l'intermédiaire d'interfaces , Quand l'interface change , Cela affecte tous les appelants , Les tests automatisés sont très importants , Si vous comptez sur la main - d'oeuvre pour tester une interface après l'autre , La charge de travail serait trop lourde . Je voudrais souligner un point ,C'est API La gestion des documents est particulièrement importante .

4) Amélioration des difficultés d'exploitation et d'entretien
Dans les applications monomères traditionnelles , On doit peut - être se concentrer sur un seul Tomcat Groupe、Un MySQL Le cluster de , Mais ça ne marchera pas avec l'architecture des microservices . Quand les affaires augmentent , De plus en plus de services ,Déploiement des services、 La surveillance deviendra très complexe , Les exigences en matière d'exploitation et d'entretien sont élevées à cette époque .
 

Code source de l'architecture distribuée recommandée

版权声明
本文为[Utilisateur bpcufjr]所创,转载请带上原文链接,感谢
https://javamana.com/2021/09/20210915091722200B.html

  1. 快速从 Windows 切换到 Linux 环境
  2. 五分钟向MySql数据库插入一千万条数据
  3. Java日期时间API系列42-----一种高效的中文日期格式化和解析方法
  4. 用Java实现红黑树
  5. 使用Redis Stream来做消息队列和在Asp.Net Core中的实现
  6. 海量列式非关系数据库HBase 架构,shell与API
  7. Architecture, Shell et API de base de données non relationnelle à grande échelle
  8. Mise en œuvre de l'arbre Rouge et noir en Java
  9. Java Date Time API Series 42 - - a efficient Chinese Date Format and Analysis Method
  10. 5 minutes pour insérer 10 millions de données dans la base de données MySQL
  11. Passage rapide de Windows à l'environnement Linux
  12. Notes on Java backend development of PostgreSQL (I)
  13. 海量列式非關系數據庫HBase 架構,shell與API
  14. Byte Jump the latest open source, the most Classic hashtap Graph details,
  15. L'interview Java de Byte Hopping Society, l'analyse super populaire de l'utilisation et du code source de countdownlatch,
  16. "Anti Mafia storm" Wang Zhifei's love history is really wonderful: he divorced Zhang Xinyi and married a 14-year-old wife
  17. In spring in the jade mansion, Jia Fengyuan was not moved by his brother's death. Why was su Yingxue changed? The reason is realistic
  18. Adam Oracle Oracle fully constructs Adam token incentive for ecological development
  19. 实战SpringCloud通用请求字段拦截处理,超过500人面试阿里,
  20. 宅家36天咸鱼翻身入职腾讯,Zookeeper一致性级别分析,
  21. The first starcoin & move hacksong source code analysis - P (a)
  22. Zhaijia 36 days Salt Fish turn into Tencent, Zookeeper Consistency level analysis,
  23. Traitement de l'interception des champs de demande communs de Spring Cloud, plus de 500 personnes interviewent Ali,
  24. About JavaScript modules
  25. Object oriented programming (2)
  26. Java日期时间API系列42-----一种高效的中文日期格式化和解析方法
  27. Java日期時間API系列42-----一種高效的中文日期格式化和解析方法
  28. 宅家36天鹹魚翻身入職騰訊,Zookeeper一致性級別分析,
  29. Java Date Time API Series 42 - - a efficient Chinese Date Format and Analysis Method
  30. 已成功拿下字节、腾讯、脉脉offer,7年老Java一次操蛋的面试经历,
  31. 小米Java社招面试,每次面试必问的二叉树的设计与编码,
  32. 小米Java校招面试,阿里、百度、美团、携程、蚂蚁面经分享,
  33. 小米Java校招面試,阿裏、百度、美團、攜程、螞蟻面經分享,
  34. Xiaomi Java School Recruitment interview, Ali, baidu, meituan, ctrip, ant Facebook Sharing,
  35. La conception et le codage de l'arbre binaire requis pour chaque entrevue d'embauche de la société Java millet;
  36. A remporté avec succès Byte, Tencent, Pulse offer, 7 ans Java une expérience d'entrevue de baise,
  37. 干货来袭,Java岗面试12家大厂成功跳槽,
  38. 常用Java框架面试题目,现在做Java开发有前途吗?
  39. 常用Java框架面試題目,現在做Java開發有前途嗎?
  40. Les questions d'entrevue couramment utilisées pour le cadre Java sont - elles prometteuses pour le développement Java?
  41. L'arrivée de marchandises sèches, l'entretien d'emploi Java 12 grandes usines ont réussi à changer d'emploi,
  42. Multiple postures for handling container time in k8s environment
  43. Echarts remove left Gap, Blank
  44. Hotspot Weekly | zoom $100 million, docker fees, $38 billion Data bricks
  45. JsonMappingException: No serializer found for class org.apache.ibatis.executor.loader.javassist.JavassistProxyFactory...
  46. Java. Security. Securerandom source code analysis Java. Security. EGD = file: / dev /. / urandom
  47. When using IntelliJ idea, jump directly and quickly from the mapper interface to mapper.xml
  48. When idea writes SQL in mybatis XML, the solution to the problems of table name, field and red reporting
  49. Spring cloud integrates Nacos
  50. 应届毕业生Java笔试题目,2021大厂Java社招最全面试题,
  51. Liver explosion! Take you to understand Hadoop serialization
  52. linux系列之:告诉他,他根本不懂kill
  53. java版gRPC实战之三:服务端流
  54. RabbitMQ核心知识总结!
  55. linux系列之:告诉他,他根本不懂kill
  56. java版gRPC实战之三:服务端流
  57. RabbitMQ核心知识总结!
  58. 10天拿到字节跳动Java岗位offer,学习Java开发的步骤
  59. 10天拿到字节跳动Java岗位offer,Java知识点思维导图
  60. Résumé des connaissances de base de rabbitmq!