- 浏览: 102929 次
- 性别:
- 来自: 杭州
最新评论
-
ncs123:
yusimiao 写道ncs123 写道四种创建对象的方法只要 ...
java创建对象的四种方法 -
keke8614:
关于clone和反序列化手段 手段创建的类是指那些特定类可以被 ...
java创建对象的四种方法 -
yusimiao:
ncs123 写道四种创建对象的方法只要不是看他们有什么利弊的 ...
java创建对象的四种方法 -
ncs123:
四种创建对象的方法只要不是看他们有什么利弊的,而是来适应不同的 ...
java创建对象的四种方法 -
左手写不了爱:
同上,什么情况下用什么好 能说下不
java创建对象的四种方法
文章列表
一 背景
购物车依赖推荐的dubbo接口,推荐服务每天凌晨3点会批量下线推荐dubbo服务,全量更新商品,更新完以后在执行上线操作,每天凌晨3点10分左右,购物车工程都会出现5000左右的connection timeout error。正常依赖的dubbo服 ...
一、TCP简介
TCP(Transmission Control Protocol 传输控制协议)是一种面向连接的、可靠的、基于字节流的传输层通信协议。
TCP基本术语:
接收缓冲区:服务端建立连接后,接受的数据会存入内核的接收缓冲区中,然后调用recv系统调用,把接收缓冲区中的数据拷贝到应用程序的内存中,进行处理。
发送缓冲区:客户端调用send,把数据拷贝到内核的发送缓冲区,再通过网络把数据发送到服务端。
滑动窗口:一 个socket有两个滑动窗口(一个sendbuf、一个recvbuf),两个窗口的大小是通过setsockopt函数设置的。服务端ack请求时会返回 ...
一、Dispatcher介绍 对于Dubbo集群中的Provider角色,有IO线程池和业务处理线程池(默认200)两个线程池,所以当业务的并发比较高,或者某些业务处理变慢,业务线程池就很容易被“打满”,抛出“RejectedExecutionException: Thread pool is EXHAUSTED! ”异常。
<dubbo:provider version="1.0" delay="-5000" timeout="5000" dispatcher="all" threads=&quo ...
一、取消某次合并
git merge --abort #如果Git版本 >= 1.7.4
git reset --merge #如果Git版本 >= 1.6.1
二、回滚commit和push的代码
# 找到要回滚的commitID
git reset [--mixed | --soft | --hard | --merge | --keep] [<commit>]
--mixed reset HEAD and index
--soft reset only HEAD
--hard ...
一、AOP术语
Aspect(切面): aspect 由 pointcount 和 advice 组成, 它既包含了横切逻辑的定义,切面就是对横切关注点的抽象。
pointcut(切点): 匹配 join point 的谓词(a predicate that matches join points)。
advice(增强): 指拦截到连接点之后要执行的代码,通知分为前置、后置、异常、最终、环绕通知五类。
target(目标对象): 织入 advice 的目标对象. 目标对象也被称为 advised object。
joinpoint(连接点): 程序运行 ...
一、RpcContext简介
RpcContext 是一个 ThreadLocal 的临时状态记录器,当接收到 RPC 请求,或发起 RPC 请求时,RpcContext 的状态都会变化。
比如:A调B,B再调C,则B机器上,在B调C之前,RpcContext记录的是A调B的信息,在B调C之后,RpcContext记录的是B调C的信息。
二、RpcContext的使用
消费端
// 远程调用之前,通过attachment传KV给提供方
RpcContext.getContext().setAttachment("userKey", " ...
一、扩展点简介
Dubbo 的扩展点加载从 JDK 标准的 SPI (Service Provider Interface) 扩展点发现机制加强而来。
Dubbo 改进了 JDK 标准的 SPI 的以下问题:
JDK 标准的 SPI 会一次性实例化扩展点所有实现,如果有扩展实现初始化很耗时,但如果没用上也加载,会很浪费资源。
如果扩展点加载失败,连扩展点的名称都拿不到了。比如:JDK 标准的 ScriptEngine,通过 getName() 获取脚本类型的名称,但如果 RubyScriptEngine 因为所依赖的 jruby.jar 不存在,导致 RubyScr ...
一、Dubbo简介
Apache Dubbo (incubating) |ˈdʌbəʊ| is a high-performance, java based RPC framework open-sourced by Alibaba. As in many RPC systems, dubbo is based around the idea of defining a service, specifying the methods that can be called remotely with their parameters and return types. On the ser ...
一、案例
//案例一
public static void main(String[] args) {
List<String> list = new ArrayList<>();
list.add("1");
list.add("2");
for (String item : list) {
if ("1".equals(item)) {
list.remove(it ...
一、ThreadPoolExecutor简介
使用线程池主要为了解决一下几个问题:
通过重用线程池中的线程,来减少每个线程创建和销毁的性能开销。
对线程进行一些维护和管理,比如定时开始,周期执行,并发数控制等等。
public ThreadPoolExecutor(int corePoolSize,
int maximumPoolSize,
long keepAliveTime,
TimeUnit ...
RabbitMq简介
RabbitMq exchange四种方式
RabbitMq Consumer和Producer端使用
RabbitMq确认机制
RabbitMq Cluster 和 High Availability
一、Producer端
ConnectionFactory factory = new ConnectionFactory();
factory.setHost("localhost");
Connection connection = factory.newConnection();
...
RabbitMq简介
RabbitMq exchange四种方式
RabbitMq Consumer和Producer端使用
RabbitMq确认机制
RabbitMq Cluster 和 High Availability
一、RabbitMq Cluster
所有节点两两相连
users, virtual hosts, exchanges, bindings,queue metadata会自动镜像到所有Node
连接任意一个N ...
问题
一天晚上突然收到同事反馈,其使用的一个正责表达式对收货人姓名处理时,输入某种字符不能正确保存,现象为服务端请求卡死,没有response返回给客户端;在测试环境重现该问题时通过jstack获取到的信息可以发现 ...
Linux的内核将所有外部设备都看做一个文件来操作,对一个文件的读写操作会调用内核提供的系统命令,返回一个file descriptor(fd,文件描述符)。而对一个socket的读写也会有相应的描述符,称为socketfd(socket描述符),描述符就是一个数字,它指向内核中的一个结构体(文件路径,数据区等一些属性)。
根据UNIX网络编程对I/O模型的分类,UNIX提供了5种I/O模型,分别如下。
(1)阻塞I/O模型:
(2)非阻塞I/O模型:
(3)I/O复用模型:
(4)信号驱动I/O模型:
(5)异步I ...
一、Metaspace介绍
JDK 8 开始把类的元数据放到本地堆内存(native heap)中,这一块区域就叫 Metaspace,中文名叫元空间。
使用本地内存有什么好处呢?最直接的表现就是OOM问题将不复存在,因为默认的类的元数据分配只受本地内存大小的限制,也就是说本地内存剩余多少,理论上Metaspace就可以有多大(貌似容量还与操作系统的虚拟内存有关?这里不太清楚),这解决了空间不足的问题。不过,让 Metaspace 变得无限大显然是不现实的,因此我们也要限制 Metaspace 的大小:使用 -XX:MaxMetaspaceSize 参数来指定 Metaspace ...