advanced-java/docs/micro-services/huifer-micro-services-technology-stack.md

312 lines
8.1 KiB
Markdown
Raw Normal View History

# 微服务技术栈
2020-05-06 20:23:11 +08:00
* Author: [HuiFer](https://github.com/huifer)
* Description: 该文简单介绍微服务技术栈有哪些分别用来做什么
## 技术栈
2020-05-06 20:23:11 +08:00
### 微服务开发
2020-05-06 20:23:11 +08:00
作用:快速开发服务。
2020-05-06 20:23:11 +08:00
* Spring
* Spring MVC
* Spring Boot
[官网](https://spring.io/)Spring 目前是 JavaWeb 开发人员必不可少的一个框架SpringBoot 简化了 Spring 开发的配置目前也是业内主流开发框架。
### 微服务注册发现
2020-05-06 20:23:11 +08:00
作用:发现服务,注册服务,集中管理服务
#### Eureka
2020-05-06 20:23:11 +08:00
* Eureka Server : 提供服务注册服务, 各个节点启动后,会在 Eureka Server 中进行注册。
* Eureka Client : 简化与 Eureka Server 的交互操作
* Spring Cloud Netflix : [GitHub](https://github.com/spring-cloud/spring-cloud-netflix)[文档](https://cloud.spring.io/spring-cloud-netflix/reference/html/)
#### Zookeeper
2020-05-06 20:23:11 +08:00
> ZooKeeper is a centralized service for maintaining configuration information, naming, providing distributed synchronization, and providing group services.
2020-05-06 20:23:11 +08:00
[Zookeeper](https://github.com/apache/zookeeper) 是一个集中的服务, 用于维护配置信息、命名、提供分布式同步和提供组服务。
#### Zookeeper 和 Eureka 区别
2020-05-06 20:23:11 +08:00
Zookeeper 保证 CPEureka 保证 AP
2020-05-06 20:23:11 +08:00
* C数据一致性
* A服务可用性
* P服务对网络分区故障的容错性这三个特性在任何分布式系统中不能同时满足最多同时满足两个。
### 微服务配置管理
2020-05-06 20:23:11 +08:00
作用:统一管理一个或多个服务的配置信息, 集中管理。
#### Disconf
2020-05-06 20:23:11 +08:00
Distributed Configuration Management Platform(分布式配置管理平台) , 它是专注于各种分布式系统配置管理 的通用组件/通用平台, 提供统一的配置管理服务, 是一套完整的基于 zookeeper 的分布式配置统一解决方案。
* [GitHub](https://github.com/knightliao/disconf)
#### SpringCloudConfig
2020-05-06 20:23:11 +08:00
* [GitHub](https://github.com/spring-cloud/spring-cloud-config)
#### Apollo
2020-05-06 20:23:11 +08:00
Apollo阿波罗是携程框架部门研发的分布式配置中心能够集中化管理应用不同环境、不同集群的配置配置修改后能够实时推送到应用端并且具备规范的权限、流程治理等特性用于微服务配置管理场景。
2020-05-06 20:23:11 +08:00
* [GitHub](https://github.com/ctripcorp/apollo)
### 权限认证
2020-05-06 20:23:11 +08:00
作用:根据系统设置的安全规则或者安全策略, 用户可以访问而且只能访问自己被授权的资源,不多不少。
#### Spring Security
2020-05-06 20:23:11 +08:00
* [官网](https://spring.io/projects/spring-security)
#### apache Shiro
2020-05-06 20:23:11 +08:00
> Apache Shiro™ is a powerful and easy-to-use Java security framework that performs authentication, authorization, cryptography, and session management. With Shiros easy-to-understand API, you can quickly and easily secure any application from the smallest mobile applications to the largest web and enterprise applications.
2020-05-06 20:23:11 +08:00
* [官网](http://shiro.apache.org/)
### 批处理
2020-05-06 20:23:11 +08:00
作用: 批量处理同类型数据或事物
#### Spring Batch
2020-05-06 20:23:11 +08:00
* [官网](官网)
### 定时任务
2020-05-06 20:23:11 +08:00
> 作用: 定时做什么.
2020-05-06 20:23:11 +08:00
#### Quartz
2020-05-06 20:23:11 +08:00
* [官网](http://www.quartz-scheduler.org/)
### 微服务调用 (协议)
2020-05-06 20:23:11 +08:00
> 通讯协议
2020-05-06 20:23:11 +08:00
#### Rest
2020-05-06 20:23:11 +08:00
* 通过 HTTP/HTTPS 发送 Rest 请求进行数据交互
#### RPC
2020-05-06 20:23:11 +08:00
* Remote Procedure Call
* 它是一种通过网络从远程计算机程序上请求服务而不需要了解底层网络技术的协议。RPC 不依赖于具体的网络传输协议tcp、udp 等都可以。
#### gRPC
2020-05-06 20:23:11 +08:00
* [官网](https://www.grpc.io/)
* > A high-performance, open-source universal RPC framework
> 所谓 RPC(remote procedure call 远程过程调用) 框架实际是提供了一套机制,使得应用程序之间可以进行通信,而且也遵从 server/client 模型。使用的时候客户端调用 server 端提供的接口就像是调用本地的函数一样。
2020-05-06 20:23:11 +08:00
#### RMI
2020-05-06 20:23:11 +08:00
* Remote Method Invocation
* 纯 Java 调用
### 服务接口调用
2020-05-06 20:23:11 +08:00
> 作用:多个服务之间的通讯
2020-05-06 20:23:11 +08:00
#### Feign(HTTP)
2020-05-06 20:23:11 +08:00
Spring Cloud Netflix 的微服务都是以 HTTP 接口的形式暴露的,所以可以用 Apache 的 HttpClient 或 Spring 的 RestTemplate 去调用,而 Feign 是一个使用起来更加方便的 HTTP 客戶端,使用起来就像是调用自身工程的方法,而感觉不到是调用远程方法。
2020-05-06 20:23:11 +08:00
* [GitHub](https://github.com/OpenFeign/feign)
### 服务熔断
2020-05-06 20:23:11 +08:00
> 作用: 当请求到达一定阈值时不让请求继续.
2020-05-06 20:23:11 +08:00
#### Hystrix
2020-05-06 20:23:11 +08:00
* > Hystrix is a latency and fault tolerance library designed to isolate points of access to remote systems, services and 3rd party libraries, stop cascading failure and enable resilience in complex distributed systems where failure is inevitable.
2020-05-06 20:23:11 +08:00
>
2020-05-06 20:23:11 +08:00
* [GitHub](https://github.com/Netflix/Hystrix)
2020-05-06 20:23:11 +08:00
#### Sentinel
2020-05-06 20:23:11 +08:00
* > A lightweight powerful flow control component enabling reliability and monitoring for microservices. (轻量级的流量控制、熔断降级 Java 库)
* [GitHub](https://github.com/alibaba/Sentinel)
### 服务的负载均衡
2020-05-06 20:23:11 +08:00
> 作用:降低服务压力, 增加吞吐量
#### Ribbon
2020-05-06 20:23:11 +08:00
* >Spring Cloud Ribbon 是一个基于 HTTP 和 TCP 的客户端负载均衡工具, 它基于 Netflix Ribbon 实现
>
2020-05-06 20:23:11 +08:00
* [GitHub](https://github.com/Netflix/ribbon)
#### Nginx
2020-05-06 20:23:11 +08:00
Nginx (engine x) 是一个高性能的 HTTP 和反向代理 web 服务器, 同时也提供了 IMAP/POP3/SMTP 服务
* [GitHub](https://github.com/nginx/nginx)
#### Nginx 与 Ribbon 区别
2020-05-06 20:23:11 +08:00
1. Nginx 属于服务端负载均衡,Ribbon 属于客户端负载均衡.Nginx 作用与 Tomcat,Ribbon 作用与各个服务之间的调用 (RPC)
### 消息队列
2020-05-06 20:23:11 +08:00
> 作用: 解耦业务, 异步化处理数据
#### Kafka
2020-05-06 20:23:11 +08:00
* [官网](http://kafka.apache.org/)
#### RabbitMQ
2020-05-06 20:23:11 +08:00
* [官网](https://www.rabbitmq.com/)
#### RocketMQ
2020-05-06 20:23:11 +08:00
* [官网](http://rocketmq.apache.org/)
#### activeMQ
2020-05-06 20:23:11 +08:00
* [官网](http://activemq.apache.org/)
### 日志采集 (elk)
2020-05-06 20:23:11 +08:00
> 作用: 收集各服务日志提供日志分析、用户画像等
#### Elasticsearch
2020-05-06 20:23:11 +08:00
* [GitHub](https://github.com/elastic/elasticsearch)
#### Logstash
2020-05-06 20:23:11 +08:00
* [GitHub](https://github.com/elastic/logstash)
#### Kibana
2020-05-06 20:23:11 +08:00
* [GitHub](https://github.com/elastic/kibana)
### API 网关
2020-05-06 20:23:11 +08:00
> 作用: 外部请求通过 API 网关进行拦截处理, 再转发到真正的服务
#### Zuul
2020-05-06 20:23:11 +08:00
> Zuul is a gateway service that provides dynamic routing, monitoring, resiliency, security, and more.
>
2020-05-06 20:23:11 +08:00
* [GitHub](https://github.com/Netflix/zuul)
### 服务监控
2020-05-06 20:23:11 +08:00
> 作用: 以可视化或非可视化的形式展示出各个服务的运行情况 (CPU、内存、访问量等)
#### Zabbix
2020-05-06 20:23:11 +08:00
* [GitHub](https://github.com/jjmartres/Zabbix)
#### Nagios
2020-05-06 20:23:11 +08:00
* [官网](https://www.nagios.org/)
#### Metrics
2020-05-06 20:23:11 +08:00
* [官网](https://metrics.dropwizard.io)
### 服务链路追踪
2020-05-06 20:23:11 +08:00
> 作用: 明确服务之间的调用关系
#### Zipkin
2020-05-06 20:23:11 +08:00
* [GitHub](https://github.com/openzipkin/zipkin)
#### Brave
2020-05-06 20:23:11 +08:00
* [GitHub](https://github.com/openzipkin/brave)
### 数据存储
2020-05-06 20:23:11 +08:00
> 作用: 存储数据
2020-05-06 20:23:11 +08:00
#### 关系型数据库
2020-05-06 20:23:11 +08:00
##### MySql
2020-05-06 20:23:11 +08:00
* [官网](https://www.mysql.com/)
##### Oracle
2020-05-06 20:23:11 +08:00
* [官网](https://www.oracle.com/index.html)
##### MsSql
2020-05-06 20:23:11 +08:00
* [官网](https://docs.microsoft.com/zh-cn/sql/?view=sql-server-ver15)
##### PostgreSql
2020-05-06 20:23:11 +08:00
* [官网](https://www.postgresql.org/)
#### 非关系型数据库
2020-05-06 20:23:11 +08:00
##### Mongodb
2020-05-06 20:23:11 +08:00
* [官网](https://www.mongodb.com/)
##### Elasticsearch
2020-05-06 20:23:11 +08:00
* [GitHub](https://github.com/elastic/elasticsearch)
### 缓存
2020-05-06 20:23:11 +08:00
> 作用: 存储数据
2020-05-06 20:23:11 +08:00
#### redis
2020-05-06 20:23:11 +08:00
* [官网](https://redis.io/)
### 分库分表
2020-05-06 20:23:11 +08:00
> 作用: 数据库分库分表方案.
2020-05-06 20:23:11 +08:00
#### shardingsphere
2020-05-06 20:23:11 +08:00
* [官网](http://shardingsphere.apache.org/)
2020-05-06 20:23:11 +08:00
#### Mycat
2020-05-06 20:23:11 +08:00
* [官网](http://www.mycat.io/)
### 服务部署
2020-05-06 20:23:11 +08:00
> 作用: 将项目快速部署、上线、持续集成.
2020-05-06 20:23:11 +08:00
#### Docker
2020-05-06 20:23:11 +08:00
* [官网](http://www.docker.com/)
#### Jenkins
2020-05-06 20:23:11 +08:00
* [官网](https://jenkins.io/zh/)
#### Kubernetes(K8s)
2020-05-06 20:23:11 +08:00
* [官网](https://kubernetes.io/)
#### Mesos
2020-05-06 20:23:11 +08:00
* [官网](http://mesos.apache.org/)