hprose 1.0(rpc 框架) - 内部数据标准

hprose 1.0 内部数据标准

方法的描述  {
    // 请求调用格式
    ‘C‘.writeString(‘method1‘).‘a‘.count($params).‘{‘.‘m‘.count($params)‘{‘. xxx .‘}‘.‘}‘.‘z‘
    
    // 请求返回格式
    ‘R‘.serialize($result).‘z‘
}

// 数据类型的描述
serialize == {
    null == {
        writeNull() --->  ‘n‘
    }
    
    is_scalar == {
        writeNaN() --->  ‘N‘
        writeInteger(10) --->  ‘i10;‘
        writeLong(2000) --->  ‘l2000;‘
        writeBoolean(true) --->  ‘t‘  或者  ‘f‘
        writeDouble(3.6) --->  ‘d000;‘
        writeDouble(正无穷大、负无穷大) --->  ‘I+‘ 或者 ‘I-‘
        writeEmpty() --->  ‘e‘
        writeUTF8Char($val) --->  ‘u‘.‘‘
        writeStringWithRef($val) --->  writeString($val)
        writeBytes($bytes)  --->  ‘b‘.strlen($bytes).‘"‘.$bytes.‘"‘
        writeBytesWithRef($val)  --->  writeBytes($bytes);
        writeString($str) --->  ‘s‘.(strlen(iconv(‘UTF-8‘, ‘UTF-16LE‘, $str)) >> 1).‘"‘.$str.‘"‘
    }

is_array == {
        writeArray($array) --->  ‘a‘.count($array)‘{‘. xxx .‘}‘
        writeAssocArray($map) --->  ‘m‘.count($map)‘{‘. xxx .‘}‘
    }

is_object == {
        writeDateTime($datetime) --->  $datetime->format(‘\DYmd\THis.u\Z‘)
        writeMapWithRef($val) --->   writeMap($val)  --->  ‘m‘.count($val)‘{‘. xxx .‘}‘
        writeListWithRef($val) --->  writeList($val) --->  ‘a‘.count($val)‘{‘. xxx .‘}‘
        writeStdClassWithRef($val) --->  writeStdClass($obj)  --->  ‘m‘.count($val)‘{‘. xxx .‘}‘
        writeObjectWithRef($val) --->  writeObject($obj)  --->  {
            $class = get_class($obj); // ‘Dir1\Dir2\Clazz1‘;
            $alias = ‘Dir1_Dir2_Clazz1‘
            ---> ‘c‘.(strlen(iconv(‘UTF-8‘, ‘UTF-16LE‘, $alias)) >> 1).‘"‘.$alias.‘"‘.count($props).‘{‘.writeString(strtolower($prop[0]) . substr($prop, 1)).‘}‘.‘o‘.‘0‘.‘{‘.$prop->getValue($obj).‘}‘
        }
    }
}

时间: 2024-10-12 04:43:56

hprose 1.0(rpc 框架) - 内部数据标准的相关文章

RPC框架实现 - 监控篇

RPC(Remote Procedure Call,远程过程调用)框架是分布式服务的基石,实现RPC框架需要考虑方方面面.其对业务隐藏了底层通信过程(TCP/UDP.打包/解包.序列化/反序列化),使上层专注于功能实现:框架层面,提供各类可选架构(多进程/多线程/协程):应对设备故障(高负载/死机).网络故障(拥塞/网络分化),提供相应容灾措施. 监控是分布式服务中相当重要的一部分,其有助于我们了解业务发展状况,出灾时提供第一手分析资讯.分布式系统中的每一个模块,都需要一些指标说明其服务状况和服

RPC框架实现

转载RPC框架实现 RPC(Remote Procedure Call,远程过程调用)框架是分布式服务的基石,实现RPC框架需要考虑方方面面.其对业务隐藏了底层通信过程(TCP/UDP.打包/解包.序列化/反序列化),使上层专注于功能实现:框架层面,提供各类可选架构(多进程/多线程/协程):应对设备故障(高负载/死机).网络故障(拥塞/网络分化),提供相应容灾措施. 监控是分布式服务中相当重要的一部分,其有助于我们了解业务发展状况,出灾时提供第一手分析资讯.分布式系统中的每一个模块,都需要一些指

Apache thrift - 使用,内部实现及构建一个可扩展的RPC框架

本文首先介绍了什么是Apache Thrift,接着介绍了Thrift的安装部署及如何利用Thrift来实现一个简单的RPC应用,并简单的探究了一下Thrift的内部实现原理,最后给出一个基于Thrift的可扩展的分布式RPC调用框架,在中小型项目中是一个常见的SOA实践. Thrift介绍 Apache Thrift是Facebook 开发的远程服务调用框架,它采用接口描述语言(IDL)定义并创建服务,支持可扩展的跨语言服务开发,所包含的代码生成引擎可以在多种语言中,如 C++, Java,

Google 高性能 RPC 框架 gRPC 1.0.0 发布(附精彩评论)

gRPC是一个高性能.开源.通用的RPC框架,面向移动和HTTP/2设计,是由谷歌发布的首款基于Protocol Buffers的RPC框架. gRPC基于HTTP/2标准设计,带来诸如双向流.流控.头部压缩.单TCP连接上的多复用请求等特性.这些特性使得其在移动设备上表现更好,更省电且节省空间占用. gRPC 1.0版本是2015年面世以后的第一次版本发布,开发者可以把该版本用于生产.API现在也是很稳定的. 关于Java版本发布情况,大家阅读发布日志:https://github.com/g

C# 的轻量级 RPC 框架

Redola.Rpc 的一个小目标 Redola.Rpc 的一个小目标 Redola.Rpc 的一个小目标:20000 tps. Concurrency level: 8 threads Complete requests: 20000 Time taken for tests: 0.886 seconds Time per request: 0.044 ms (avg) Requests per second: 22573 [#/sec] (avg) Concurrency level: 8

微博轻量级RPC框架Motan正式开源:支撑千亿调用

支撑微博千亿调用的轻量级 RPC 框架 Motan 正式开源了,项目地址为https://github.com/weibocom/motan. 微博轻量级RPC框架Motan正式开源 Motan 是微博技术团队研发的基于 Java 的轻量级 RPC 框架,已在微博内部大规模应用多年,每天稳定支撑微博上亿次的内部调用.Motan 基于微博的高并发和高负载场景优化,成为一套简单.易用.高可用的 RPC 服务框架. Motan 功能特点:简单.易用.高可用 无侵入集成.简单易用,通过 Spring 配

一个简单RPC框架是如何炼成的(II)——制定RPC消息

开局篇我们说了,RPC框架的四个核心内容 RPC数据的传输. RPC消息 协议 RPC服务注册 RPC消息处理 下面,我们先看一个普通的过程调用 class Client(object): def __init__(self): self.remote = None ## # 内部是委托给远程remote对象来获取结果. def sayHello(self): if self.remote: return self.remote.sayHello() else : return None cla

FastRPC 3.2 发布,高性能 C++ 协程 RPC 框架

用过go erlang gevent的亲们应该都会知道协程在应用中带来的方便. 如果对协程不理解的同学,通过阅读下面例子可以快速了解我们框架的协程的意义,已了解的可以跳过这部分. 协程例子:假设我们要发个Get请求获取百度首页内容: php同步方式:$result = file_get_contents("http://www.baidu.com"), php果然是世界上最好的语言,多么简洁. 然后java和c++的同学开始不屑了: "呵呵, 同步,鄙视你不解释."

一个简单RPC框架是怎样炼成的(II)——制定RPC消息

开局篇我们说了,RPC框架的四个核心内容 RPC数据的传输. RPC消息 协议 RPC服务注冊 RPC消息处理 以下,我们先看一个普通的过程调用 class Client(object): def __init__(self): self.remote = None ## # 内部是托付给远程remote对象来获取结果. def sayHello(self): if self.remote: return self.remote.sayHello() else : return None cla