DCOM的心跳

2024-01-18 05:38
文章标签 心跳 dcom

本文主要是介绍DCOM的心跳,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

保持DCOM的心跳

 

文档版本

版本

创建时间

创建人

备注

1.0.0114.1

2003-1-14

郑昀

第一稿

 

 

 

 

编写目的:

    本文档将说明DCOM的心跳给编程上的影响

概述

我们的程序员前不久遇到过这样的一个奇怪的现象:

服务器端创建出一个ServerA的实例,好几个分布式的客户端持有这个实例的引用,类似于ConnectionPoint的方式。客户端负责向服务器端的实例发送电话拨入、按键、挂机等消息,服务器端负责处理这些消息。但是在生产环境中,每隔一段时间,服务器端调用持有的客户端实例引用时,得到一个COM错误0x80010108,意思是说被调用的对象已与其客户端断开连接。这时客户端却可以调用服务器端的实例,这时候的网络通信质量也很好。实在是看不出来会是什么原因导致这种调用模式周期性出错。程序员报告这个时间大约是7分钟。

COM+的心跳

排除了代码错误的可能性后,联想到COM+的一个特性:保持心跳。COM+为了实现JIT(即时激活),必须每隔一段时间让COM+组件的实例和调用方之间保持一个心跳,告诉调用方,我还活着。以前没有想过它为什么要定期发送一次消息,通知对方自己健在呢?也许这是一种规则,如果不这么做的话,一定会有大麻烦。

那么是DCOM协议的制约了?

我们从新闻组中得到了一个模糊的说明:

After 6 minutes of non usage, the server considers the client disconnected
and drops the connection. This is a fixed timeout for DCOM that cannot be
changed.

Okay,看样子我们的方向是正确的。确实存在一个约定的时间间隔:6分钟。我们试图描述我们得到的第一个概念:6分钟内,服务器端没有得到来自于客户端的消息,就默认客户端已经消失,于是断开连接。所以我们这之后的再次调用,就会得到0x80010108COM错误。

更多信息

Question:

我的Server如何判断Client是否在运行中?

Background:

DCOM设计时就预先要考虑能处理任何形式的ServerClient或者Network崩溃的组合。所以DCOM决定在ClientServer之间保持一个背景“ping”。如果Client的连接丢失,NT将在6分钟之内检测到。这时,服务器故意模拟Client的正常断开情形,将ClientServer请求的所有接口的引用计数统统释放。

Resolution:

正因为如此,编写Server的程序员不必要太过于担心Client的意外崩溃。NT将会从根本上保证Client正常断开并释放所有引用的接口。

6分钟是如何计算出来的呢?

当一个Connection被请求建立之后,DCOM将在三次不成功的ping之后,认定本次连接超时。由于这些ping每隔2分钟发送一次,所以6分钟就是这么计算出来的。

总结:

u      Pinging是一种检测客户端是否异常终止的著名手段

u      一般在服务器端的设计中,每一个输出的对象都有一个pingPeriodTime参数,和一个numPingsToTimeout参数

u      如果pingPeriod时间过去,而并未接收到来自于Clientping,所有对接口的远程引用计数,将被认为失效,从而可以被垃圾回收器收回。

前面说的0x80010108问题解决办法就是每隔半分钟就给服务器发送一个无害的消息,保证connection不被断掉。

 

本文档所包含的信息代表了在发布之日,ZhengYun 对所讨论问题的当前看法,Zhengyun 不保证所给信息在发布之日以后的准确性。

本文档仅供参考。对本文档中的信息,Zhengyun 不做任何明示或默示的保证。

Written by zhengyun@tomosoft.com



Trackback: http://tb.blog.csdn.net/TrackBack.aspx?PostId=12707


这篇关于DCOM的心跳的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/618185

相关文章

mina 2 心跳包

接收到心跳后先解码,先不调用经过messageReceived()方法,先触发心跳接收发送类KeepAliveMessageFactoryImpl中的isRequest()方法,当判断是心跳时,就会发一个心跳,不再调用messageReceived(),当判断不是心跳时,回调messageReceived()方法,输出内容。//服务器import java.io.IOException;im

webSocket java.io.EOFException: null 增加心跳机制解决

最近发现webSocket连接,经常自动断开,看了晚上的一些文章,很多说是Nginx的问题,但是不想改Nginx因为怕影响其他系统,而且不一定有效,因此决定给webSocket加一个心跳机制: 1:先在服务端判断消息是不是心跳检测消息,是的话,原封不动将消息传给客户端即可: if("heartCheck".equals(jsonObject.getString("heartCheck

面试官问:服务的心跳机制与断线重连,Netty底层是怎么实现的?懵了

点击上方“朱小厮的博客”,选择“设为星标” 后台回复"书",获取 后台回复“k8s”,可领取k8s资料 心跳机制 何为心跳 所谓心跳, 即在 TCP 长连接中, 客户端和服务器之间定期发送的一种特殊的数据包, 通知对方自己还在线, 以确保 TCP 连接的有效性. 注:心跳包还有另一个作用,经常被忽略,即:一个连接如果长时间不用,防火墙或者路由器就会断开该连接。 如何实现 核心Handler

net6 core 接入nacos 实现服务注册入门使用,心跳检测和负载均衡

net6 core 接入nacos 实现服务注册入门使用,心跳检测和负载均衡 配置中心比较Apollo与Nacos_appollo 和 nacos-CSDN博客 一:安装nacos  Release 2.2.3 (May 25th, 2023) · alibaba/nacos · GitHub 二、配置Nacos 注*Nacos 是使用的mysql 数据库,需要先自行安装好数据库

心跳事件总结

心跳事件是什么? 心跳一般来说是用来判断一个人是否还活着的,你有心跳,说明你还活着,你要是心不跳了,就说明你已经是一个死人了,那么问题来了,程序中的心跳是什么呢?其实跟人的心跳是一样的,程序中的心跳事件一般用来判断服务端和客户端之间的通信情况,如果没有了心跳,则说明服务端和客户端之间断开连接了,有的话则说明没有断开连接。 如何判断心跳呢? 一般正常判断心跳的方法是这样的,由客户端给服务端发

Android客户端TCP传输数据、重连、心跳检测

1.Tcp连接、发送数据、接收数据工具类 public class TcpUtil {public static final int PORT = 9000;public static final String HOST = "192.168.2.127";public static Socket socket;private static TcpUtil utils = null;public

记录一次两台虚拟机Oracle rac 心跳不能建立的排查

场景:两台云主机,均有子网IP和虚IP,目前子网IP和虚IP都能互相ping通。而且延迟很小,同时traceroute发现,有带* 的结果,与网络同事沟通后得知,带*并不能影响网络的连通性。 解决方案:使用tcpdump 抓udp包,指定虚拟网卡和虚IP的地址发现,发现没有包过来。然后检查了安全组,发现安全组是全部放通的状态,另外也有同事提出,同一个vpc里面的两个主机不能建立心跳,应该给还不到

WebSocket封装成工具类,实现心跳监测、断开重连

1. 工具类代码 import { Message } from 'element-ui';export class WebSocketManager {constructor(url, reconnectInterval = 5000, onMessageCallback) {this.url = url;this.reconnectInterval = reconnectInterval;

hadoop心跳机制(转)

转自:https://blog.csdn.net/lb812913059/article/details/78713523   主节点和从节点之间的通信是通过心跳机制(心跳实际上是一个RPC函数)实现的 所谓“心跳”是一种形象化描述,指的是持续的按照一定频率在运行,类似于心脏在永无休止的跳动。   心跳机制:   1) master启动的时候,会开启一个RPC server 2)

高可用架构-lvs+keepalived+nginx实现高性能负载均衡(3.心跳检测脚本)

nginx_check.sh: 注意别忘了给文件授予执行的操作 #!/bin/bashA=`ps -C nginx –no-header |wc -l`if [ $A -eq 0 ];then/usr/local/nginx/sbin/nginxsleep 2if [ `ps -C nginx --no-header |wc -l` -eq 0 ];thenkillall keepaliv