【Dubbo核心 详解五】Dubbo 服务治理详解

news/2024/11/8 15:09:46/

引言

当前,分布式服务在互联网行业中得到了广泛应用。然而,分布式服务不仅仅是将单个应用程序分割成不同的模块,还涉及到模块之间的相互合作和协作。

服务治理是分布式服务的一个关键问题,因为它可以帮助开发人员管理不同的服务、协调不同的组件和确保服务的可用性和可靠性。Dubbo 服务治理可以快速实现不同服务之间的通信和调用,因此被广泛应用。

本文将详细介绍 Dubbo 服务治理的架构设计、注册与发现机制、负载均衡算法、实现方式、应用场景和优化措施。通过本文,读者可以更深入地了解 Dubbo 服务治理的内部结构和工作原理,并且学习到如何应用 Dubbo 服务治理来管理和调度分布式系统中的服务。

一、介绍

1. 介绍 Dubbo 服务治理的基本概念和重要性

Dubbo 服务治理是一种服务管理和协调的解决方案,它主要是为分布式系统提供服务管理、服务调度、服务监控、服务负载均衡等功能。Dubbo 服务治理可以有效地管理和调度分布式系统中的服务,通过提供丰富的管理工具可以方便地实现服务的监控、调度和负载均衡等功能。在分布式系统中,Dubbo 服务治理可以提供一种方式,让不同的应用程序通过调用远程服务实现互联互通。

以下是一个简单的 Dubbo 服务治理的时序图,展示了 Dubbo 服务注册、发现和调用的过程:

Client Registry Provider1 Provider2 Service Discovery Return Service List Service Call Return Result Service Call Return Result Client Registry Provider1 Provider2

在这个时序图中,Client 是服务的消费者,Registry 是服务注册中心,Provider1 和 Provider2 是服务的提供者。整个过程分为三个步骤:

  1. 服务发现:Client 向 Registry 发起服务发现请求,Registry 返回可用的服务列表。
  2. 服务调用:Client 向 Provider1 发起服务调用请求,Provider1 返回结果;接着 Client 向 Provider2 发起服务调用请求,Provider2 返回结果。
  3. 结果返回:Provider1 和 Provider2 返回结果给 Client。

Dubbo 服务治理的重要性在于,它可以帮助开发人员管理和协调不同的服务和组件,并确保服务的可用性和可靠性。通过 Dubbo 服务治理,开发团队可以通过一个单一的入口管理所有服务,这对于大规模分布式服务的管理非常重要。

2. 阐述 Dubbo 服务治理的实现方式和应用场景

Dubbo 服务治理可以分为两种类型:基础服务治理和应用服务治理。基础服务治理主要针对基础组件提供服务治理的解决方案,如注册中心、监控中心等。应用服务治理主要针对业务服务提供服务治理的解决方案,如服务的调度、负载均衡、容错等。

Dubbo 服务治理的实现方式包括:基于 Docker 容器的 Dubbo 服务治理、基于 Kubernetes 容器编排的 Dubbo 服务治理和基于云原生架构的 Dubbo 服务治理。

基于 Docker 容器的 Dubbo 服务治理可以方便地部署和管理 Dubbo 服务,不需要人工干预。基于 Kubernetes 容器编排的 Dubbo 服务治理可以更加灵活地管理 Dubbo 服务,同时还支持容器的自动弹性伸缩和故障自愈的功能。基于云原生架构的 Dubbo 服务治理可以通过云平台来实现弹性伸缩、高可用性、灰度发布等功能,这为 Dubbo 服务的管理和部署带来了极大的便利。

Dubbo 服务治理广泛应用于微服务架构、分布式系统和大型企业等场景中。在微服务架构中,Dubbo 服务治理可以帮助开发人员快速构建分布式应用,通过服务治理机制可以方便地管理和协调不同的服务。在分布式系统中,Dubbo 服务治理可以确保系统的高可用性和可靠性。在大型企业中,Dubbo 服务治理可以帮助企业更好地管理和调度分布式系统中的服务,提高业务处理的效率。

二、Dubbo 服务治理的原理

1. Dubbo 服务治理的架构设计

Dubbo 服务治理的架构设计主要包括注册中心、服务消费者和服务提供者三个部分。注册中心是一个分布式的注册表,可以存储服务提供者的地址、版本等信息。服务消费者可以从注册中心查找服务提供者的位置和信息,并发起请求。服务提供者是一个分布式集群,可以提供服务,并支持负载均衡和容错机制。服务消费者和服务提供者之间采用消息队列进行通信,可以支持异步处理和消息缓存等功能。

Registry
+register(service, address)
+unregister(service, address)
+discover(service)
Consumer
-registry: Registry
+invoke(service, method, args)
Provider
-registry: Registry
+export(service, impl, address)
MessageQueue
+send(message)
+receive()
LoadBalancer
+select(providerList)
Failover
+invoke(request)
Failfast
+invoke(request)
Failsafe
+invoke(request)
Failback
+invoke(request)
RegistryListener
+notify(service)

以上是 Dubbo 服务治理的架构设计的 UML 类图。其中,Registry 表示注册中心,包括注册、注销和服务发现等方法。Consumer 和 Provider 分别表示服务消费者和服务提供者。服务消费者通过 invoke 方法发起请求,服务提供者通过 export 方法提供服务。MessageQueue 表示消息队列,用于服务消费者和服务提供者之间的通信。LoadBalancer 表示负载均衡,用于从多个服务提供者中选择一个进行请求。Failover、Failfast、Failsafe 和 Failback 表示 Dubbo 支持的容错机制。RegistryListener 表示注册中心的监听器,可以监听服务的注册和注销事件。

2. Dubbo 服务治理的注册与发现机制

由于Dubbo服务治理的注册与发现机制主要是基于网络通信的,因此可以使用时序图来描述其过程。

ServiceConsumer RegistryCenter ServiceProvider 查询服务 返回服务列表 注册服务 调用服务 ServiceConsumer RegistryCenter ServiceProvider

上图中,ServiceConsumer表示服务消费者,RegistryCenter表示注册中心,ServiceProvider表示服务提供者。在服务治理的注册与发现机制中,服务消费者会向注册中心发送查询请求,查询服务提供者的信息。注册中心会将服务提供者的信息存储在分布式注册表中,并将服务列表返回给服务消费者。服务消费者可以根据注册表中的信息,找到服务提供者的位置和版本等信息,并发起请求。同时,服务提供者也会将自己的服务信息注册到注册中心中,以便服务消费者可以发现并调用该服务。

3. Dubbo 服务治理的负载均衡算法

Dubbo 服务治理的负载均衡算法是指服务消费者可以将请求分配到多个服务提供者上,提高服务的性能和可用性。Dubbo 服务治理支持轮询、加权轮询、最小连接数和加权最小连接数四种负载均衡算法。轮询算法是指服务消费者按照一定的时间间隔,将请求轮流分配给多个服务提供者。加权轮询算法是指服务消费者按照服务提供者的负载情况,将请求轮流分配给多个服务提供者。最小连接数算法是指服务消费者按照服务提供者的最小连接数,将请求分配给多个服务提供者。加权最小连接数算法是指服务消费者按照服务提供者的负载情况,以及服务提供者的最小连接数,将请求分配给多个服务提供者。

发送请求
选择服务提供者
选择服务提供者
选择服务提供者
处理请求
处理请求
处理请求
服务消费者
负载均衡算法
服务提供者1
服务提供者2
服务提供者3
返回响应
返回响应
返回响应

以上流程图简要描述了Dubbo服务治理中负载均衡算法的过程。服务消费者向负载均衡算法发送请求,负载均衡算法会选择一个合适的服务提供者来处理请求,并返回响应。在Dubbo服务治理中,可用的负载均衡算法包括轮询、加权轮询、最小连接数和加权最小连接数。在这个流程中,我们没有具体说明每种负载均衡算法的实现细节,因为不同的算法可能具有不同的实现方式。

三、Dubbo 服务治理的实现方式

1. 基于 Docker 容器的 Dubbo 服务治理

1.1 安装 Docker

在本地计算机上安装 Docker 后,需要将其启用为系统服务。可以使用以下命令启动 Docker 服务:

sudo systemctl start docker  
sudo systemctl enable docker  

1.2 创建 Docker Compose 文件

使用 Docker Compose 文件来定义 Dubbo 服务的配置。在命令行中打开 Docker Compose 文件编辑器:

vi /etc/docker/compose.yaml  

然后,编辑 Compose 文件,定义 Dubbo 服务的主机、端口和配置文件等信息:

version: '3'  
services:  dubbo:  image: dubbo:latest  environment:  DUBBO_VERSION: '2.7.6'  JAVA_OPTS: '-Xmx512m -XX:+UseConcMarkSweepGC -Djava.util.concurrent.Executor=yes'  ports:  - "8080:8080"  - "8081:8081"  volumes:  - ./ DubboConfig:/dubbo/config  - ./logs:/dubbo/logs  

在上面的 Compose 文件中,Dubbo 服务使用最新的版本,并且将使用 Executor 来优化性能。该服务有两个端口,一个用于客户端访问,另一个用于内部服务通信。它还提供了一个 volumes 选项,用于将本地目录映射到容器内。

1.3 启动 Docker Compose

使用以下命令启动 Docker Compose:

docker-compose up  

这将启动 Dubbo 服务,并将端口 8080 和 8081 暴露给客户端。

1.4 查看 Dubbo 服务

可以使用以下命令查看 Dubbo 服务的状态:

docker-compose ps dubbo  

这将列出 Dubbo 服务的所有进程。可以使用以下命令停止或重新启动服务:

docker-compose stop dubbo  
docker-compose restart dubbo  

1.5 部署 Dubbo 服务到云环境

如果要将 Dubbo 服务部署到云环境中,需要使用云原生技术,比如 Kubernetes。可以使用以下命令将 Dubbo 服务部署到 Kubernetes 集群中:

kubectl apply -f https://docs.projectdouban.io/zh-cn/dubbo/kubernetes/dubbo-service.yaml  

这将创建一个新的 Kubernetes Service,该 Service 将暴露 Dubbo 服务到客户端,同时也将配置 Dubbo 服务在 Kubernetes 集群中的端口映射。

1.6 测试 Dubbo 服务

现在,可以在本地计算机上使用 Dubbo 客户端工具来测试 Dubbo 服务。可以使用以下命令启动 Dubbo 客户端:

java -jar DubboClient.jar --url=http://localhost:8080/dubbo --user=admin --password=123456  

这将启动一个 Dubbo 客户端,该客户端将使用 HTTP 协议访问 Dubbo 服务,并使用管理员权限进行验证。

使用以下命令可以查看 Dubbo 客户端的日志:

java -jar DubboClient.jar --url=http://localhost:8080/dubbo --user=admin --password=123456 | more  

这将列出 Dubbo 客户端的日志,可以查看客户端与 Dubbo 服务之间的通信情况。

2. 基于 Kubernetes 容器编排的 Dubbo 服务治理

2.1 安装 Kubernetes

首先需要安装 Kubernetes。可以在本地计算机上使用以下命令安装 Kubernetes:

sudo apt-get update    
sudo apt-get install -y apt-transport-https curl    
curl -s https://packages.cloud.google.com/apt/doc/apt-key.gpg | sudo apt-key add -    
echo "deb https://apt.kubernetes.io/ kubernetes-xenial main" | sudo tee /etc/apt/sources.list.d/kubernetes.list    
sudo apt-get update    
sudo apt-get install -y kubernetes    

2.2 创建 Kubernetes Deployment

使用 Deployment 来定义 Dubbo 服务的配置。在 Kubernetes Deployment 中,可以指定 Dubbo 服务的名称、版本、端口、环境变量等信息。可以使用以下命令创建 Kubernetes Deployment:

kubectl create deployment dubbo --image=dubbo:latest --port=8080 --env-file=.env    

这将创建一个 Kubernetes Deployment,该 Deployment 将定义 Dubbo 服务的主机、端口和配置文件等信息。其中,–image 参数指定了 Dubbo 服务的镜像地址,–port 参数指定了 Dubbo 服务使用的端口,–env-file 参数指定了 Dubbo 服务的环境变量配置文件。

2.3 创建 Kubernetes Service

使用 Service 来定义 Dubbo 服务的服务类型和端口。可以使用以下命令创建 Kubernetes Service:

kubectl create service dubbo --port=8080 --type=LoadBalancer    

这将创建一个 Kubernetes Service,该 Service 将暴露 Dubbo 服务到客户端,同时也将在 Kubernetes 集群中暴露 Dubbo 服务的端口。

2.4 创建 Kubernetes ConfigMap

使用 ConfigMap 来定义 Dubbo 服务的配置文件。可以使用以下命令创建 Kubernetes ConfigMap:

kubectl create configmap dubbo-config --from-file=./dubbo/config/dubbo.conf    

这将创建一个 Kubernetes ConfigMap,该 ConfigMap 将使用 Dubbo 服务的配置文件。

2.5 创建 Kubernetes Secret

使用 Secret 来定义 Dubbo 服务的认证密码。可以使用以下命令创建 Kubernetes Secret:

kubectl create secret generic dubbo-password --from-literal=password=<your-password>    

这将创建一个 Kubernetes Secret,该 Secret 将存储 Dubbo 服务的认证密码。

2.6 创建 Kubernetes Ingress

使用 Ingress 来定义 Dubbo 服务的客户端访问路径。可以使用以下命令创建 Kubernetes Ingress:

kubectl create ingress dubbo --from-literal=tls-secret=dubbo-password    

这将创建一个 Kubernetes Ingress,该 Ingress 将配置 Dubbo 服务的客户端访问路径,同时也将使用之前创建的 Secret 来存储认证密码。

2.7 测试 Dubbo 服务

现在可以使用 Kubernetes Deployment、Service、ConfigMap 和 Secret 来测试 Dubbo 服务。可以使用以下命令启动 Dubbo 客户端:

kubectl apply -f https://docs.projectdouban.io/zh-cn/dubbo/kubernetes/dubbo-ingress.yaml    

这将创建一个新的 Kubernetes Ingress,该 Ingress 将配置 Dubbo 服务的客户端访问路径,同时也将使用之前创建的 Secret 来存储认证密码。现在可以使用本地 Dubbo 客户端工具来测试 Dubbo 服务了。

3. 基于云原生架构的 Dubbo 服务治理

3.1 安装云原生基础设施

首先需要安装云原生基础设施,比如容器编排平台 (Kubernetes)、服务注册与发现平台 (Zookeeper)、负载均衡器 (ELB) 等。可以在本地计算机上使用以下命令安装这些平台:

sudo apt-get update  
sudo apt-get install -y kubelet kubeadm kubectl  

3.2 创建 Kubernetes Deployment

使用 Deployment 来定义 Dubbo 服务的配置。在 Kubernetes Deployment 中,可以指定 Dubbo 服务的名称、版本、端口、环境变量等信息。可以使用以下命令创建 Kubernetes Deployment:

kubectl create deployment dubbo --image=dubbo:latest --port=8080 --env-file=.env  

这将创建一个 Kubernetes Deployment,该 Deployment 将定义 Dubbo 服务的主机、端口和配置文件等信息。其中,–image 参数指定了 Dubbo 服务的镜像地址,–port 参数指定了 Dubbo 服务使用的端口,–env-file 参数指定了 Dubbo 服务的环境变量配置文件。

3.3 创建 Kubernetes Service

使用 Service 来定义 Dubbo 服务的服务类型和端口。可以使用以下命令创建 Kubernetes Service:

kubectl create service dubbo --port=8080 --type=LoadBalancer  

这将创建一个 Kubernetes Service,该 Service 将暴露 Dubbo 服务到客户端,同时也将在 Kubernetes 集群中暴露 Dubbo 服务的端口。

3.4 创建 Kubernetes ConfigMap

使用 ConfigMap 来定义 Dubbo 服务的配置文件。可以使用以下命令创建 Kubernetes ConfigMap:

kubectl create configmap dubbo-config --from-file=./dubbo/config/dubbo.conf  

这将创建一个 Kubernetes ConfigMap,该 ConfigMap 将使用 Dubbo 服务的配置文件。

3.5 创建 Kubernetes Secret

使用 Secret 来定义 Dubbo 服务的认证密码。可以使用以下命令创建 Kubernetes Secret:

kubectl create secret generic dubbo-password --from-literal=password=<your-password>  

这将创建一个 Kubernetes Secret,该 Secret 将存储 Dubbo 服务的认证密码。

3.6 创建 Kubernetes Ingress

使用 Ingress 来定义 Dubbo 服务的客户端访问路径。可以使用以下命令创建 Kubernetes Ingress:

kubectl create ingress dubbo --from-literal=tls-secret=dubbo-password  

这将创建一个 Kubernetes Ingress,该 Ingress 将配置 Dubbo 服务的客户端访问路径,同时也将使用之前创建的 Secret 来存储认证密码。

3.7 测试 Dubbo 服务

现在可以使用 Kubernetes Deployment、Service、ConfigMap 和 Secret 来测试 Dubbo 服务。可以使用以下命令启动 Dubbo 客户端:

kubectl apply -f https://docs.projectdouban.io/zh-cn/dubbo/kubernetes/dubbo-ingress.yaml  

这将创建一个新的 Kubernetes Ingress,该 Ingress 将配置 Dubbo 服务的客户端访问路径,同时也将使用之前创建的 Secret 来存储认证密码。现在可以使用本地 Dubbo 客户端工具来测试 Dubbo 服务了。

四、Dubbo 服务治理的应用场景

1. 微服务架构中的 Dubbo 服务治理

在微服务架构中,服务之间的通信需要通过中间件来实现,而 Dubbo 是常用的一种中间件。Dubbo 可以提供双向通信、负载均衡、服务注册与发现等功能,使得服务之间的通信更加高效和安全。在微服务架构中,Dubbo 服务治理的应用场景包括:

  • 服务注册与发现:微服务架构中,服务的数量和维护量往往非常大,因此需要使用 Dubbo 这样的中间件来对服务进行治理和管理。Dubbo 可以提供服务注册与发现、负载均衡、服务消费等功能,可以帮助微服务架构更好地管理和监控服务。
  • 服务调用:微服务架构中,服务之间的通信需要通过 Dubbo 来实现。Dubbo 可以提供双向通信、负载均衡等功能,使得服务之间的通信更加高效和安全。

2. 分布式系统中的 Dubbo 服务治理

在分布式系统中,服务之间的通信需要通过总线或者中间件来实现,而 Dubbo 也是常用的一种中间件。Dubbo 可以提供双向通信、负载均衡、服务注册与发现等功能,使得服务之间的通信更加高效和安全。在分布式系统中,Dubbo 服务治理的应用场景包括:

  • 服务注册与发现:分布式系统中,服务的数量和维护量往往非常大,因此需要使用 Dubbo 这样的中间件来对服务进行治理和管理。Dubbo 可以提供服务注册与发现、负载均衡、服务消费等功能,可以帮助分布式系统更好地管理和监控服务。
  • 服务调用:分布式系统中,服务之间的通信需要通过 Dubbo 来实现。Dubbo 可以提供双向通信、负载均衡等功能,使得服务之间的通信更加高效和安全。

五、Dubbo 服务治理的优化措施

1. 提高 Dubbo 服务治理的可用性和高并发处理能力

为了提高 Dubbo 服务治理的可用性和高并发处理能力,可以采取以下措施:

  • 使用集群部署:将 Dubbo 注册中心和服务提供者部署在多个节点上,提高服务的可用性和容错能力。

  • 优化资源配置:针对 Dubbo 服务的并发量和负载情况,适当调整机器的 CPU、内存、磁盘等资源,提高系统的处理能力。

监控服务的负载情况
分析负载数据
优化服务提供者的资源配置
重新部署服务提供者

该流程图表示了对 Dubbo 服务进行资源配置优化的过程。首先需要通过监控服务的负载情况,收集并分析服务的负载数据,然后根据分析结果对服务提供者的资源进行优化配置,最后重新部署服务提供者,使得服务提供者能够更好地处理并发请求,提高系统的处理能力。

  • 合理设置 Dubbo 的线程池大小:根据业务需求和硬件资源情况,合理设置 Dubbo 的线程池大小,避免线程池过大或过小导致的性能问题。
  • 使用缓存和消息队列:通过缓存和消息队列来缓解 Dubbo 服务的并发压力,提高系统的可用性和性能。

2. 优化 Dubbo 服务治理的性能和带宽消耗

为了优化 Dubbo 服务治理的性能和带宽消耗,可以采取以下措施:

  • 选择合适的序列化框架:Dubbo 支持多种序列化框架,包括 Hessian、Java 自带的序列化、JSON 等,选择合适的序列化框架可以提高性能和降低带宽消耗。
  • 合理设置超时时间:设置合理的超时时间可以避免 Dubbo 服务调用出现阻塞和超时等问题,提高系统的性能和稳定性。
  • 使用缓存:通过缓存来避免 Dubbo 服务频繁调用,提高系统的性能和带宽利用率。
  • 优化网络带宽:通过优化网络带宽的使用方式,例如启用 TCP 协议的 Nagle 算法、使用压缩算法等,可以降低 Dubbo 服务的带宽消耗。

3. 增强 Dubbo 服务治理的安全性和可靠性

为了增强 Dubbo 服务治理的安全性和可靠性,可以采取以下措施:

  • 启用 SSL 加密:通过启用 SSL 加密来保障 Dubbo 服务的安全性。
  • 启用认证机制:通过启用认证机制来保障 Dubbo 服务的安全性,例如使用基于 Token 的认证机制等。
  • 设置合理的重试机制:设置合理的重试机制可以避免 Dubbo 服务因为网络波动等原因出现调用失败的情况,提高系统的可靠性。
  • 监控和日志记录:通过监控和日志记录可以及时发现系统中的问题,进行及时的处理,提高系统的可靠性和安全性。
  • 使用健康检查:通过使用健康检查可以及时发现服务故障或者节点异常,避免服务因为故障而无法提供服务,提高系统的可靠性。 定期备份和恢复:定期备份和恢复可以避免服务因为数据丢失或者损坏而无法正常提供服务,提高系统的可靠性和安全性。

http://www.ppmy.cn/news/97823.html

相关文章

2023软件设计师上午题答案

1 cpu 主存 外设 2 物理物理地址 ❌ 3 4 4 中断程序入口 5 与真值对应❌ 6 2003 7 表示层 8 会话 公钥❌ 9 不信任 10 阻止网络攻击❌ 11 流氓软件❌ 12 署名 13 版权 14 继承所有权利 ❌ 15 加工要具体说明 16 集中化 17 E 18 23 19 28条 20 a为true 21 1不能连续 22 39&#…

Midjourney AI绘画咒语与生成的作品(实例)

据说Midjourney出来后&#xff0c;有一大批设计师抱着电脑&#xff0c;哭晕了~~ 有兴趣的朋友&#xff0c;可以看一下我前两天发的&#xff0c;地址如下&#xff1a; Midjourney AI绘画中文教程详解&#xff08;完整版&#xff09;模型、命令、参数与各种高级用法https://blog…

8.3:加强堆的应用

8.3&#xff1a;加强堆的应用 题目要求&#xff1a; 做一个加强堆的题目&#xff0c;给定一个整型数组&#xff0c;int[] arr&#xff1b;和一个布尔类型数组&#xff0c;boolean[] op 两个数组一定等长&#xff0c;假设长度为N&#xff0c;arr[i]表示客户编号&#xff0c;op…

C++ [STL之list的使用]

本文已收录至《C语言和高级数据结构》专栏&#xff01; 作者&#xff1a;ARMCSKGT 前言 vector是一片连续的空间&#xff0c;在数据访问上性能较好&#xff0c;但是任意位置插入删除性能较低&#xff0c;头插头删性能亦是如此&#xff1b;此时在这种需要频繁插入的场景下&…

TA-lib第三方库安装问题

因为学习的需要&#xff0c;用到Talib库做写指标分析&#xff0c;但是百度了好久&#xff0c;说是去要某某网站下载对应版本的文件进行本地安装&#xff0c;但是把…404 Not found 然后通过查找&#xff0c;Ta-lib库的安装已经迁移到这里了 https://github.com/TA-Lib/ta-lib-p…

三秒教会你如何使用scrcpy手机无线投屏到电脑

简介 scrcpy 是一款免费开源的投屏软件&#xff0c;可以将安卓手机屏幕投放在 Windows、macOS、GNU/Linux 上&#xff0c;并可以直接使用鼠标在投屏窗口中进行交互和录制。此应用程序镜像通过 USB 或TCP/IP连接的 Android 设备&#xff08;视频和音频&#xff09;&#xff0c;并…

如何理解ORB_SLAM2算法中一个特征点在y方向的位置是以金字塔尺度为半径的多行中?

文章目录 首先看下vRowIndices里面存储了什么?右图像的坐标系右图上每个图像金字塔中提取到的特征点数据经过处理后每行中有多少个特征点每个特征点分别属于那些行?左目特征点的后选匹配点讲一下代码实现的细节算法原理vector<vector<size_t> > vRowIndices(nRow…

轩辕:首个千亿级中文金融对话模型

背景 目前开源的大语言模型或多或少存在以下痛点&#xff1a; 缺少专门针对中文进行优化过的的大语言模型。 支持中文的开源模型的参数规模偏小&#xff0c;没有超过千亿。比如清华和智谱AI的ChatGLM-6B目前只开源了6B参数模型&#xff0c;盘古alpha也只开源了13B的模型。 支…