前言:
现在的主要工作是给出公司的SOA解决方案,在通讯层选用netty的NIO框架,通讯协议使用Google最新的SPDY协议草案2,苦于没有中文版本的SPDY,对英文的理解实在有些偏差,在架构组几个人各自看了英文版本的SPDY后,互相讨论,现在通讯层快完工,在此总结一下SPDY协议,也为SPDY做些贡献。对于我这样不是专业的翻译人员来说,翻译的工作量是巨大的,希望各位看官能别着急,能留个言就是对我最大的支持,欢迎转载,但请保留原文链接,我会随着以后的翻译不断斟酌每个词的使用,不断更新已有的翻译,多谢。
SPDY 协议 – 草案 2
草案
目录
1 概述
1.1 文章总览
1.2 基本定义
2 帧层
2.1 连接
2.2 帧
2.2.1 协议版本
2.3 控制帧
2.4 数据帧
2.5 流
2.5.1 创建一个流
2.5.2 数据交互
2.5.3 半关闭
2.5.4 关闭
2.6 数据流程
2.7 控制帧
2.7.1 SYN_STREAM
2.7.2 SYN_REPLY
2.7.3 RST_STREAM
2.7.4 HELLO
2.7.5 NOOP
2.7.6 PING
2.7.7 GOAWAY
2.7.8 HEADERS
2.7.9 WINDOW_UPDATE
3 以SPDY协议实现HTTP
3.1 响应
3.2 服务器推送
3.2.1 服务端实现
3.2.2 客户端实现
3.3 部署
3.3.1 服务器通过AlternateProtocol协议头来推荐使用SPDY协议
3.3.2 依托于SPDY会话的HTTP请求
4 与SPDY草案1不兼容的地方
5 计划中的工作/实验
6 贡献者
翻译:Lookis(lookisliu@gmail.com,http://lookis.me)
更新时间:2010-03-19
文章来源:
http://lookis.me/?p=50
posted @
2010-03-24 10:18 Lookis 阅读(465) |
评论 (2) |
编辑 收藏
由于时间关系,这一次的培训计划有变,把JVM调试单独出来做为一节课,另外新加入课程,预计都是下周给新人们上课
文章来源:
http://lookis.me/?p=38
posted @
2010-03-24 10:18 Lookis 阅读(176) |
评论 (0) |
编辑 收藏
内容稍微变化了一点,主要讲解JVM中GC相关的部分
PPT:JVM_GC.pdf
示例源码:src_jvm_gc.rar
讲稿:
==========
GC
1.什么是GC:
1)释放不再使用的内存对象以回收内存空间
2)压缩内存碎片
2.为什么要让JVM做GC,而不是程序员来做?
1)把开发人员从管理内存中解放出来,提高生产率
2)安全角度考虑,不会由于失误/故意错误释放内存带来潜在的安全问题
3)弊端:额外地占用CPU,且对于程序员来说”难于”控制
引用计数收集器:
start:当创建对象,并且指向该对象的引用被分配给一个变量,这个对象的引用计数被置为1
其他变量被赋值为对这个对象引用时,i++
一个对象引用超过生存期或者被设置成一个新值时,i–
计数为0的对象就可以被收集
当收集的时候,该对象所引用的对象计数i–
优点:速度快,交织在程序运行之中
缺点:无法检测出循环引用
跟踪收集器:
从根结点开始跟踪,对所有跟踪到的对象以某种方式(和实现有关)打上标记,跟踪结束时,就可以对没打上标记的对象实现收集
优点:可以回收循环引用
缺点:回收的时候长时间独占CPU
问题:什么是根结点
根结点:
和实现有关:总的来说有以下几个方面:
1.局部变量,操作数栈(参数)
2.常量池中对象:字符串,类名,接口名…
3.JNI调用,没有被释放的
压缩收集器:
把标记为活动的对象从原来的区域越过空闲区移动到堆的另一端
问题:更新移动的对象要更新所有的指针(以用于清理)
解决:有些JVM实现做了一层 间接对象引用层 (不完美,每次取对象都要多一个步骤)
拷贝收集器:
有两个内存区域
把标记为活动的对象从原来的区域拷贝到另一个区域
同一时间只有一个区域在使用
优点:在使用的时候才更新指针
缺点:内存使用率降低
finalize
时机:对象被回收时
流程:收集器第一遍扫描出不再被引用的对象
调用他们的finalize方法,此时程序员可以实现finalize方法做清理工作,可以复活这个对象
收集器第二遍扫描,只扫描不再被引用的对象,对没复活的对象做清理
jdk1.2以前:可触及,可复活,不可触及
可触及:从根结点开始跟踪可以触及到
可复活:从根结点跟踪不可触及,但在自己或者别人的finalize方法里重新使该对象可触及
不可触及:finalize方法后也不可触及
jdk1.2以后:软引用,弱引用,影子引用
软引用:做cache
弱引用,做映射:初始化实例时默认配置,配置修改时可以通知,如果实例已经不再使用,就不通知
影子引用:处理收集时的后续操作,类比finalize,初始化时要增加一个ReferenceQueue队列参数
==========
文章来源:
http://lookis.me/?p=32
posted @
2010-03-24 10:18 Lookis 阅读(193) |
评论 (0) |
编辑 收藏