第14章:实现自定义的编码解码器.pdfVIP

  1. 1、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
第14章:实现自定义的编码解码器

Netty In Action 文版 - 第十四章 :实现自定义的编码解码器 目录 [-] 1. 编解码器的范围 2. 实现Memcached的编解码器 3. 了解Memcached二进制协议 4. Netty编码器和解码器 1. 实现Memcached编码器 2. 实现Memcached解码器 5. 测试编解码器 6. Summary 本章讲述Netty 中如何轻松实现定制的编解码器,由于Netty架构的灵活性,这些编解码器易于重用和测试。为了更容 易实现,使用Memcached作为协议例子是因为它更方便我们实现。 Memcached是免费开源、高性能、分布式的内存对象缓存系统,其目的是加速动态Web应用程序的响应,减轻数据 库负载;Memcache实际上是一个以key-value存 任意数据的内存小块。可能有人会问为什么使用Memcached?”,因为 Memcached协议非常简单,便于讲解。 14.1 解码器的范围 我们将只实现Memcached协议的一个子集,这足够我们进行添加、检索、删除对象;在Memcached中是通过执行 SET,GET,DELETE命令来实现的。Memcached支持很多其他的命令,但我们只使用其中三个命令,简单的东西,我们才 会理解的更清楚。 Memcached有一个二进制和纯文本协议,它们都可以用来与Memcached服务器通信,使用什么类型的协议取决于服 务器支持哪些协议。本章主要关注实现二进制协议,因为二进制在网络编程中最常用。 14.2 实现Memcached 的 解码器 当想要实现一个给定协议的编解码器,我们应该花一些事件来了解它的运作原理。通常情况下,协议本身都有一些详 细的记录。在这里你会发现多少细节?幸运的是Memcached的二进制协议可以很好的扩展。 在RFC中有相应的规范,并提 了Memcached二进制协议下载地址:/p/memcached/wiki /BinaryProtocolRevamped。我们不会执行Memcached的所有命令,只会执行三种操作:SET,GET和DELETE 。这样做事 为了让事情变得简单。 14.3 了解Memcached二进制协议 可以在/p/memcached/wiki/BinaryProtocolRevamped上详细了解Memcached二进制协议结 构。不过这个网站如果不翻墙的话好像访问不了。 14.4 Netty 码器和解码器 14.4.1 实现Memcached 码器 先定义memcached操作码(Opcode)和响应状态码(Status) : [java] 01. package netty.in.action.mem; 02. 03. /** 04. * memcached operation codes 05. * @author c.king 06. * 07. */ 08. public class Opcode { 09. 10. public static final byte GET = 0x00; 11. public static final byte SET = 0x01; 12. public static final byte DELETE = 0x04; 13. 14. } [java] 01. package netty.in.action.mem; 02. 03. /** 04. * memcached response statuses 05. * @author c.king 06. * 07. */ 08. public class Status { 09. 10. public static final short NO_ERROR = 0x0000; 11. public static final short KEY_NOT_FOUND = 0x0001; 12. public static final short KEY_EXISTS = 0x0

文档评论(0)

jiupshaieuk12 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

版权声明书
用户编号:6212135231000003

1亿VIP精品文档

相关文档