iis服务器助手广告广告
返回顶部
首页 > 资讯 > 精选 >openstack中的rpc如何远程调用
  • 134
分享到

openstack中的rpc如何远程调用

2023-06-20 14:06:46 134人浏览 八月长安
摘要

本篇内容介绍了“openstack中的rpc如何远程调用”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!什么是 RPC看不明白这个图对于看no

本篇内容介绍了“openstack中的rpc如何远程调用”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!

什么是 RPC

openstack中的rpc如何远程调用

看不明白这个图对于看nova代码,其实不是很重要,直接忽略以后再看也可以,当务之急是解决一下看openstack代码遇到rpc就跟丢了的问题

RPC、消息队列、RESTful

这三个其实不是一个层面的东西,本质上不应该放在一起比,但是因为都用来通信,比较容易混淆就还是解释一下

  • RESTful:主要用于各组件之间的通信(比如nova与glance的通信),或者说用于组件对外提供调用接口

  • RPC:则用于同一组件中各个不同模块之间的通信(比如nova组件中nova-compute与-nova-scheduler的通信)

  • 消息队列:用于解耦组件,也是组件间通信用的,而且会有一个队列用来暂存消息

在nova中的典型rpc

nova/nova/nova/conductor/tasks/live_migrate.py

class LiveMigrationTask(base.TaskBase):    def __init__(self, context, instance, destination,                 block_migration, disk_over_commit, migration, compute_rpcapi,                 servicegroup_api, scheduler_client):        super(LiveMigrationTask, self).__init__(context, instance)    ...     def _execute(self):        self._check_instance_is_active()        self._check_host_is_up(self.source)        if not self.destination:            self.destination = self._find_destination()            self.migration.dest_compute = self.destination            self.migration.save()        else:            self._check_requested_destination()        # TODO(johngarbutt) need to move complexity out of compute manager        # TODO(johngarbutt) disk_over_commit?        #调用 ComputeAPI 类中的 live_migration() RPC接口        return self.compute_rpcapi.live_migration(self.context,                host=self.source,                instance=self.instance,                dest=self.destination,                block_migration=self.block_migration,                migration=self.migration,                migrate_data=self.migrate_data)

conductorcompute_rpcapi.live_migration的方式远程调用computelive_migration,过程就是, conductorRPC的方式发出一个请求到Queue再被nova-compute接收

nova/nova/nova/compute/rpcapi.py

class ComputeAPI(object):    # 这是一个RPC远程调用的方法    def live_migration(self, ctxt, instance, dest, block_migration, host,                       migration, migrate_data=None):        args = {'migration': migration}        version = '4.2'        if not self.client.can_send_version(version):            version = '4.0'        # 获取目标 compute 主机(DEST HOST)的RPC client,即被调用的服务进程的HostIP        cctxt = self.client.prepare(server=host, version=version)        # 通过目标主机对象的 RPC cliient 来调用远程过程方法 cast() ,以此来实现远程调用        cctxt.cast(ctxt, 'live_migration', instance=instance,                   dest=dest, block_migration=block_migration,                   migrate_data=migrate_data, **args)        # cast()异步远程调用,不会阻塞别的进程,适合于需要长时间进行的执行过程        # cast()的第二个参数是RPC client调用的函数名,case()后面的参数会继续作为参数传入该调用函数        # cast()函数内的live_migration()函数是 manager.live_migration() 视具体实现迁移功能的函数,在manager.py内实现。

调用的时候是从nova/nova/conductor/tasks/live_migrate.pynova/nova/compute/rpcapi.py,但是实际上是compute服务首先得在rpcapi.py提供出接口函数,然后使用者通过
- 1. import导入的方式去使用rpc调用
- 2. 类实例化传参的方式去引入

热迁移这里用的就是类实例化传参

tip: call()表示同步调用 和 cast()表示异步调用

openstack中的rpc如何远程调用

根据在rpc.py或者rpcapi.py中的cast()的第二个参数,去该服务下的manager.py中找和这个参数同名的函数(这个就是rpc最终想要调用的函数),我们这里是compute_rpcapi,所以要去找compute下的mannager.py

为什么要去找mannager,是因为nova.compute.manager 会一直监听 Queue ,当Queue中存在相关的 RPC 请求时,就去完成这个请求

nova/nova/nova/compute/manager.py

@wrap_exception()    @wrap_instance_event(prefix='compute')    @wrap_instance_fault    def live_migration(self, context, dest, instance, block_migration,                       migration, migrate_data):        """执行实时迁移。        :param context: security context        :param dest: destination host        :param instance: a nova.objects.instance.Instance object        :param block_migration: if true, prepare for block migration        :param migration: an nova.objects.Migration object        :param migrate_data: implementation specific params        """        self._set_migration_status(migration, 'queued')        def dispatch_live_migration(*args, **kwargs):            with self._live_migration_semaphore:                # 调用_do_live_migration执行迁移                self._do_live_migration(*args, **kwargs)        # NOTE(danms): We spawn here to return the RPC worker thread back to        # the pool. Since what follows could take a really long time, we don't        # want to tie up RPC workers.        utils.spawn_n(dispatch_live_migration,                      context, dest, instance,                      block_migration, migration,                      migrate_data)

当然实际干活的还不是manager.pydef live_migration,而是live_migration函数去调用_do_live_migration,但是之后的就是热迁移的流程,在之前的文档里写了就不展开了,反正rpc的体现就只到这里

冷迁移中还有很多例子,不一一列举了,有兴趣可以去看冷迁移源码分析这篇博客

看完例子会发现,既然原生的代码既然已经写了rpc调用,那么对应的服务肯定已经提供了rpc接口,所以实际上看到compute_rpcapi,可以不去compute下的rpc文件中找了,直接去compute下的manager看具体实现(不止compute,其他服务也一样),当然,如果需要雪确定是同步还是异步调用那还是不要偷这一步的懒。

总结

完整的rpc应该具有

  • 组件A提供出rpc调用接口(rpc.py或者rpcapi.py文件)

  • 组件B引入组件A的rpc (import或者类实例化传参)

  • 组件B调用组件A的rpc(以rpc方式发送一个请求到消息队列)

  • 组件A处理请求(组件A监听到发给自己的rpc请求会通过manager处理请求)

如果只是看代码,那么去对应的manager下面找实现就可以了,但是如果自己要加就还是的明白从哪里提供的、怎样导入,何种途径接收,这样想在代码里添加自己的rpc调用才心里有数

“openstack中的rpc如何远程调用”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识可以关注编程网网站,小编将为大家输出更多高质量的实用文章!

--结束END--

本文标题: openstack中的rpc如何远程调用

本文链接: https://www.lsjlt.com/news/297720.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • openstack中的rpc如何远程调用
    本篇内容介绍了“openstack中的rpc如何远程调用”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!什么是 RPC看不明白这个图对于看no...
    99+
    2023-06-20
  • 如何在PHP中实现RPC远程调用?
    随着互联网的快速发展和云计算技术的广泛应用,分布式系统和微服务架构变得越来越普遍。在这样的背景下,远程过程调用(RPC)成为了一种常见的技术手段。RPC能够使得不同的服务在网络上实现远程调用,从而实现不同服务之间的互联操作,提高代码的复用性...
    99+
    2023-05-14
    PHP rpc 远程调用
  • 基于python如何实现rpc远程过程调用
    这篇文章主要介绍“基于python如何实现rpc远程过程调用”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“基于python如何实现rpc远程过程调用”文章能帮助大家解决问题。一、主要内容所谓RPC,...
    99+
    2023-07-02
  • 如何使用PHP和Swoole实现RPC远程调用
    如何使用PHP和Swoole实现RPC远程调用RPC(Remote Procedure Call)是一种远程调用的协议,可以让应用程序在不同计算机上进行函数调用。RPC通常被用于构建分布式系统,其可以让不同的微服务能够协同工作。在PHP和S...
    99+
    2023-05-14
    PHP rpc swoole
  • PHP远程调用以及RPC框架
    目录前言分模块分项目CURLRPCYarThriftSOAPJSON-RPC项目拆分带来的变化项目细化人员需求文档后记前言 一个项目,从开始到版本更新,一直到最后的版本维护。功能在不...
    99+
    2024-04-02
  • 如何在Python中实现一个简单的RPC远程过程调用框架
    如何在Python中实现一个简单的RPC远程过程调用框架在分布式系统中,一种常见的通信机制是通过RPC(Remote Procedure Call,远程过程调用)来实现不同进程之间的函数调用。RPC允许开发者像调用本地函数一样调用远程函数,...
    99+
    2023-10-27
    远程调用 Python RPC框架 实现RPC
  • Golang远程调用框架RPC的具体使用
    目录gRPC需求说明创建RPC服务器实现客户端gRPC gRPC远程过程调用框架是基于动作的模式,类似远程调用微服务。这使得gRPC成为一种围绕Protobufs构建的进程间通信(I...
    99+
    2022-12-14
    Go RPC Go 远程调用 RPC
  • 基于python实现rpc远程过程调用
    目录基于python实现RPC的demo前言一、主要内容二、实现步骤1. 进程间的通信2. 异步回调实现思路总结基于python实现RPC的demo 这是一个远程过程调用(RPC)的...
    99+
    2024-04-02
  • springboot+HttpInvoke如何实现RPC调用
    小编给大家分享一下springboot+HttpInvoke如何实现RPC调用,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧!开始用springboot2+hession4实现RPC服务时,发现第一个服务可以调用成功,但第二...
    99+
    2023-06-29
  • Go语言中net包RPC远程调用方式有哪些
    这篇文章主要介绍Go语言中net包RPC远程调用方式有哪些,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!一、服务端在代码中,启动了三个服务package mainimport ("log...
    99+
    2023-06-25
  • Golang如何实现简易的rpc调用
    这篇文章主要介绍“Golang如何实现简易的rpc调用”,在日常操作中,相信很多人在Golang如何实现简易的rpc调用问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”Golang如何实现简易的rpc调用”的疑...
    99+
    2023-07-05
  • SpringBoot2中怎么利用Dubbo框架实现RPC服务远程调用
    SpringBoot2中怎么利用Dubbo框架实现RPC服务远程调用,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。一、Dubbo框架简介1、框架依赖图例说明:1...
    99+
    2023-06-02
  • Go语言net包RPC远程调用三种方式http与json-rpc及tcp
    目录一、服务端二、http客户端三、TCP客户端四、json客户端五、运行结果rpc有多种调用方式,http、json-rpc、tcp 一、服务端 在代码中,启动了三个服务 pa...
    99+
    2024-04-02
  • SpringCloud中Feign如何远程调用
    这篇文章将为大家详细讲解有关SpringCloud中Feign如何远程调用,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。前言先来看我们以前利用RestTemplate发起远程调用的代码:这里就有几个问题:...
    99+
    2023-06-22
  • PHP XML-RPC 的必备秘籍:成为远程调用大师
    作为一名编程专家,掌握 PHP XML-RPC 至关重要。作为一种强大的远程调用协议,它使您可以轻松地跨不同机器和应用程序进行通信。通过遵循这些必备秘籍,您将成为一名 XML-RPC 大师,能够构建高效且可靠的远程调用解决方案。 1. 了...
    99+
    2024-04-02
  • PHP XML-RPC 深入探讨:揭开远程过程调用的面纱
    XML-RPC 是一种基于 XML 的远程过程调用(RPC)协议,允许不同系统和语言之间通过网络进行通信。在 PHP 中,XML-RPC 库提供了方便的方式来实现 RPC 客户和服务器。 XML-RPC 概述 RPC 允许一个程序调用另一...
    99+
    2024-04-02
  • 远程过程调用RPC基本概念及实现原理
    >>什么是RPC RPC 的全称是 Remote Procedure Call 是一种进程间通信方式。 它允许程序调用另一个地址空间(通常是共享网络的另一台机器上)的过程...
    99+
    2024-04-02
  • C#开发中如何处理远程调用和远程过程调用
    C#开发中如何处理远程调用和远程过程调用,需要具体代码示例引言:随着云计算和分布式系统的快速发展,远程调用和远程过程调用(Remote Procedure Call,简称RPC)在软件开发中变得越来越重要。C#作为一种强大的编程语言,在处理...
    99+
    2023-10-22
    远程过程调用 远程调用 C#开发
  • PHP XML-RPC 的力量:探索远程方法调用的奥秘
    优势 跨平台兼容性: XML-RPC使用XML作为数据格式,可在多种平台和编程语言之间实现互操作性。 简单易用: XML-RPC协议简单明了,易于理解和实现。 灵活性: XML-RPC支持各种数据类型,包括基本类型、结构、数组...
    99+
    2024-04-02
  • SpringBoot整合Dubbo框架,实现RPC服务远程调用
    目录一、Dubbo框架简介  1、框架依赖 二、与SpringBoot2.0整合  1、核心依赖2、项目结构说明3、核心配置 三、演示案例  1、服务远...
    99+
    2024-04-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作