工作中心得记录20151015

1.学会看eclipse中的用mvn管理的项目的pom文件 

2.CMD开启快速编辑模式

3.浏览器在打开网页时要咋新建标签页打开,按住ctrl 在点击链接

4.JVM的内存和电脑的内存区别?   答:本质上没区别,只是在在电脑上开一个进程,这个进程有自己管理的内存。(JVM内存是从电脑内存里面申请出来的。 )一个JVM实例占用一块内存(物理)区域,然后JVM将自己管理这一块内存(这时这块内存就属于这个JVM了),这是内存的分配,就有JVM来控制,无论你是堆,还是栈,还是代码段,数据段,都逃不出这一块内存区域了。不知道我这样的理解是否正确
5. 在Redis中,并不是所有的数据都一直存储在内存中的。这是和Memcached相比一个最大的区别。 Redis只会缓存所有的 key的信息 ,如果Redis发现内存的使用量超过了某一个阀值,将触发swap的操作,Redis根据“swappability = age*log(size_in_memory)”计 算出哪些key对应的value需要swap到磁盘。然后再将这些key对应的value持久化到磁盘中,同时在内存中清除。这种特性使得Redis可以 保持超过其机器本身内存大小的数据。当然,机器本身的内存必须要能够保持所有的key,毕竟这些数据是不会进行swap操作的。同时由于Redis将内存 中的数据swap到磁盘中的时候,提供服务的主线程和进行swap操作的子线程会共享这部分内存,所以如果更新需要swap的数据,Redis将阻塞这个 操作,直到子线程完成swap操作后才可以进行修改。Memcached基本只支持简单的key-value存储,不支持枚举,不支持持久化和复制等功能
  Redis除key/value之外,还支持list,set,sorted set,hash等众多数据结构,提供了KEYS
  进行枚举操作
6.java中Thread t=new Thread(new Runnable(){});这是怎么回事?接口还能这么玩?你问的同等与这种写法,实例化了一个Runnable接口子类的实例
Thread t=new Thread(new MyRunnable());
public class MyRunnable implements Runnable{
@Override
public void run() {
//具体实现
}
}
7.分布式: Distributed是针对用户/终端来讲的,把Job送到地理上分散的sever(i.e. 网格类)上协同作业,然后合并计算结果 分布式是解决高性能、高并发的 
一个业务分拆多个子业务,部署在不同的服务器上
集群:同一个业务,部署在多个服务器上

8.import org.springframework.beans.BeanUtils   BeanUtils.copyProperties(源对象, 目标对象);对象拷贝
9.Cobar介绍及配置     
当当开源sharding-jdbc,轻量级数据库分库分表中间件
Mycat 数据库分库分表中间件
10.
关于RPC
你的题目是RPC框架,首先了解什么叫RPC,为什么要RPC,RPC是指远程过程调用,也就是说两台服务器A,B,一个应用部署在A服务器上,想要调用B服务器上应用提供的函数/方法,由于不在一个内存空间,不能直接调用,需要通过网络来表达调用的语义和传达调用的数据。

比如说,一个方法可能是这样定义的:
Employee getEmployeeByName(String fullName)
那么:
  • 首先,要解决通讯的问题,主要是通过在客户端和服务器之间建立TCP连接,远程过程调用的所有交换的数据都在这个连接里传输。连接可以是按需连接,调用结束后就断掉,也可以是长连接,多个远程过程调用共享同一个连接。
  • 第二,要解决寻址的问题,也就是说,A服务器上的应用怎么告诉底层的RPC框架,如何连接到B服务器(如主机或IP地址)以及特定的端口,方法的名称名称是什么,这样才能完成调用。比如基于Web服务协议栈的RPC,就要提供一个endpoint URI,或者是从UDDI服务上查找。如果是RMI调用的话,还需要一个RMI Registry来注册服务的地址。
  • 第三,当A服务器上的应用发起远程过程调用时,方法的参数需要通过底层的网络协议如TCP传递到B服务器,由于网络协议是基于二进制的,内存中的参数的值要序列化成二进制的形式,也就是序列化(Serialize)或编组(marshal),通过寻址和传输将序列化的二进制发送给B服务器。
  • 第四,B服务器收到请求后,需要对参数进行反序列化(序列化的逆操作),恢复为内存中的表达方式,然后找到对应的方法(寻址的一部分)进行本地调用,然后得到返回值。
  • 第五,返回值还要发送回服务器A上的应用,也要经过序列化的方式发送,服务器A接到后,再反序列化,恢复为内存中的表达方式,交给A服务器上的应用
<img src="https://pic4.zhimg.com/45366c44f775abfd0ac3b43bccc1abc3_b.jpg" data-rawwidth="500" data-rawheight="314" class="origin_image zh-lightbox-thumb" width="500" data-original="https://pic4.zhimg.com/45366c44f775abfd0ac3b43bccc1abc3_r.jpg">
(图片来源: cs.rutgers.edu/~pxk/417

为什么RPC呢?就是无法在一个进程内,甚至一个计算机内通过本地调用的方式完成的需求,比如比如不同的系统间的通讯,甚至不同的组织间的通讯。由于计算能力需要横向扩展,需要在多台机器组成的集群上部署应用,

RPC的协议有很多,比如最早的CORBA,Java RMI,Web Service的RPC风格,Hessian,Thrift,甚至Rest API。

关于Netty
而Netty框架不局限于RPC,更多的是作为一种网络协议的实现框架,比如HTTP,由于RPC需要高效的网络通信,就可能选择以Netty作为基础。除了网络通信,RPC还需要有比较高效的序列化框架,以及一种寻址方式。如果是带会话(状态)的RPC调用,还需要有会话和状态保持的功能。

大体上来说,Netty就是提供一种事件驱动的,责任链式(也可以说是流水线)的网络协议实现方式。网络协议包含很多层次,很多部分组成,如传输层协议,编码解码,压缩解压,身份认证,加密解密,请求的处理逻辑,怎么能够更好的复用,扩展,业界通用的方法就是责任链,

一个请求应答网络交互通常包含两条链,一条链(Upstream)是从传输层,经过一系列步骤,如身份认证,解密,日志,流控,最后到达业务层,一条链(DownStream)是业务层返回后,又经过一系列步骤,如加密等,又回到传输层。
<img src="https://pic1.zhimg.com/6661f6c06aba782ff5ff61b70f842b64_b.jpg" data-rawwidth="422" data-rawheight="540" class="origin_image zh-lightbox-thumb" width="422" data-original="https://pic1.zhimg.com/6661f6c06aba782ff5ff61b70f842b64_r.jpg">(图片来源: (图片来源: ChannelPipeline (The Netty Project API Reference (3.2.6.Final))

这样每一层都有一个处理接口,都可以进行不同的操作,比如身份认证,加解密,日志,流控,将不同的处理实现像拼积木那样插接起来就可以实现一个网络协议了(快速开发)。每一层都有自己的实现,上层不需要关注面向网络的操作(可维护)。Netty已经提供了很多实现。

<img src="https://pic4.zhimg.com/7decee9dca245621988ebb0fea7d2be3_b.jpg" data-rawwidth="592" data-rawheight="348" class="origin_image zh-lightbox-thumb" width="592" data-original="https://pic4.zhimg.com/7decee9dca245621988ebb0fea7d2be3_r.jpg">(图片来源: (图片来源: docs.jboss.org/netty/3.
当然Netty还有许多好处,比如对非阻塞IO(NIO)的支持,比如在链上传递时最大程度的减少buffer的copy(高性能)。


作者:用心阁
链接:http://www.zhihu.com/question/25536695/answer/36197244
来源:知乎
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。




















  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值