53 个解决方案
#1
用ajax 的 timer 定时获取或提交数据。
也可用一个宽为0 高为0的iframe 包含一个自动提交数据的页。 这样就能http长链接了,session 也就不会过期了
也可用一个宽为0 高为0的iframe 包含一个自动提交数据的页。 这样就能http长链接了,session 也就不会过期了
#2
可以参考下:
http://bbs.chinaunix.net/thread-1088810-1-1.html
服务端:
<?php
$filename = dirname(__FILE__).'/data.txt';
// store new message in the file
$msg = isset($_GET['msg']) ? $_GET['msg'] : '';
if ($msg != '')
{
file_put_contents($filename,$msg);
die();
}
// infinite loop until the data file is not modified
$lastmodif = isset($_GET['timestamp']) ? $_GET['timestamp'] : 0;
$currentmodif = filemtime($filename);
while ($currentmodif <= $lastmodif) // check if the data file has been modified
{
usleep(10000); // sleep 10ms to unload the CPU
clearstatcache();
$currentmodif = filemtime($filename);
}
// return a json array
$response = array();
$response['msg'] = file_get_contents($filename);
$response['timestamp'] = $currentmodif;
echo json_encode($response);
flush();
?>
http://bbs.chinaunix.net/thread-1088810-1-1.html
服务端:
<?php
$filename = dirname(__FILE__).'/data.txt';
// store new message in the file
$msg = isset($_GET['msg']) ? $_GET['msg'] : '';
if ($msg != '')
{
file_put_contents($filename,$msg);
die();
}
// infinite loop until the data file is not modified
$lastmodif = isset($_GET['timestamp']) ? $_GET['timestamp'] : 0;
$currentmodif = filemtime($filename);
while ($currentmodif <= $lastmodif) // check if the data file has been modified
{
usleep(10000); // sleep 10ms to unload the CPU
clearstatcache();
$currentmodif = filemtime($filename);
}
// return a json array
$response = array();
$response['msg'] = file_get_contents($filename);
$response['timestamp'] = $currentmodif;
echo json_encode($response);
flush();
?>
#3
谢谢两位的up!对于HTTP长连接技术我这两天才开始学习,这方面的知识很弱.
因为老大叫我搞一个web版的聊天系统(IM),没得办法只有硬起头皮搞哦.
像用JS来定时发请求获得数据这种ajax技术,主要是太浪费网络带宽了;
所以关注一下HTTP的长连接,只要有心跳,服务器端就向客户端推送数据---->服务器推技术.
服务器推技术理论上了解,但是技术上还没有掌握,在网上找了个框架pushlet,据说比较轻量(JAVA写的),研究中...
服务器推技术有两个技术点不明白:
1. 建立HTTP长连接的request格式和response格式是什么?
2. 因为是长连接,所以服务器端要保存住连接,这就要消耗服务器系统资源,
请问一下非服务器的双核台式机(CPU 1.8GHZ) 1G内存能支持多少长连接?
因为老大叫我搞一个web版的聊天系统(IM),没得办法只有硬起头皮搞哦.
像用JS来定时发请求获得数据这种ajax技术,主要是太浪费网络带宽了;
所以关注一下HTTP的长连接,只要有心跳,服务器端就向客户端推送数据---->服务器推技术.
服务器推技术理论上了解,但是技术上还没有掌握,在网上找了个框架pushlet,据说比较轻量(JAVA写的),研究中...
服务器推技术有两个技术点不明白:
1. 建立HTTP长连接的request格式和response格式是什么?
2. 因为是长连接,所以服务器端要保存住连接,这就要消耗服务器系统资源,
请问一下非服务器的双核台式机(CPU 1.8GHZ) 1G内存能支持多少长连接?
#4
通信双方以客户-服务器方式建立TCP连接,用于双方信息的相互提交。当信道上没有数据传输时,通信双方应每隔时间C发送链路检测包以维持此连接,当链路检测包发出超过时间T后未收到响应,应立即再发送链路检测包,再连续发送N-1次后仍未得到响应则断开此连接。
#5
服务器推技术,学习受教了!
#6
dwr 可以实现
#7
J2EE面试题集锦(附答案)
一、基础问答
1.下面哪些类可以被继承?
java.lang.Thread (T)
java.lang.Number (T)
java.lang.Double (F)
java.lang.Math (F)
java.lang.Void (F)
java.lang.Class (F)
java.lang.ClassLoader (T)
2.抽象类和接口的区别
(1)接口可以被多重implements,抽象类只能被单一extends
(2)接口只有定义,抽象类可以有定义和实现
(3)接口的字段定义默认为:public static final, 抽象类字段默认是"friendly"(本包可见)
3.Hashtable的原理,并说出HashMap与Hashtable的区别
HashTable的原理:通过节点的关键码确定节点的存储位置,即给定节点的关键码k,通过一定的函数关系H(散列函数),得到函数值H(k),将此值解释为该节点的存储地址.
HashMap 与Hashtable很相似,但HashMap 是非同步(unsynchronizded)和可以以null为关键码的.
4.forward和redirect的区别
forward: an internal transfer in servlet
redirect: 重定向,有2次request,第2次request将丢失第一次的attributs/parameters等
5.什么是Web容器?
实现J2EE规范中web协议的应用.该协议定义了web程序的运行时环境,包括:并发性,安全性,生命周期管理等等.
6.解释下面关于J2EE的名词
(1)JNDI:Java Naming & Directory Interface,JAVA命名目录服务.主要提供的功能是:提供一个目录系统,让其它各地的应用程序在其上面留下自己的索引,从而满足快速查找和定位分布式应用程序的功能.
(2)JMS:Java Message Service,JAVA消息服务.主要实现各个应用程序之间的通讯.包括点对点和广播.
(3)JTA:Java Transaction API,JAVA事务服务.提供各种分布式事务服务.应用程序只需调用其提供的接口即可.
(4)JAF: Java Action FrameWork,JAVA安全认证框架.提供一些安全控制方面的框架.让开发者通过各种部署和自定义实现自己的个性安全控制策略.
(5)RMI:Remote Method Interface,远程方法调用
7.EJB是基于哪些技术实现的?并说 出SessionBean和EntityBean的区别,StatefulBean和StatelessBean的区别.
EJB包括Session Bean、Entity Bean、Message Driven Bean,基于JNDI、RMI、JAT等技术实现.
SessionBean在J2EE应用程序中被用来完成一些服务器端的业务操作,例如访问数据库、调用其他EJB组件.EntityBean被用来代表应用系统中用到的数据.对于客户机,SessionBean是一种非持久性对象,它实现某些在服务器上运行的业务逻辑;EntityBean是一种持久性对象,它代表一个存储在持久性存储器中的实体的对象视图,或是一个由现有企业应用程序实现的实体.
Session Bean 还可以再细分为 Stateful Session Bean 与 Stateless Session Bean .这两种的 Session Bean都可以将系统逻辑放在 method之中执行,不同的是 Stateful Session Bean 可以记录呼叫者的状态,因此通常来说,一个使用者会有一个相对应的 Stateful Session Bean 的实体.Stateless Session Bean 虽然也是逻辑组件,但是他却不负责记录使用者状态,也就是说当使用者呼叫 Stateless Session Bean 的时候,EJB Container 并不会找寻特定的 Stateless Session Bean 的实体来执行这个 method.换言之,很可能数个使用者在执行某个 Stateless Session Bean 的 methods 时,会是同一个 Bean 的 Instance 在执行.从内存方面来看, Stateful Session Bean 与 Stateless Session Bean 比较, Stateful Session Bean 会消耗 J2EE Server 较多的内存,然而 Stateful Session Bean 的优势却在于他可以维持使用者的状态.
8.XML的解析方法
Sax,DOM,JDOM
9.什么是Web Service?
Web Service就是为了使原来各孤立的站点之间的信息能够相互通信、共享而提出的一种接口。
Web Service所使用的是Internet上统一、开放的标准,如HTTP、XML、SOAP(简单对象访问协议)、WSDL等,所以Web Service可以在任何支持这些标准的环境(Windows,Linux)中使用。
注:SOAP协议(Simple Object Access Protocal,简单对象访问协议),它是一个用于分散和分布式环境下网络信息交换的基于XML的通讯协议。在此协议下,软件组件或应用程序能够通过标准的HTTP协议进行通讯。它的设计目标就是简单性和扩展性,这有助于大量异构程序和平台之间的互操作性,从而使存在的应用程序能够被广泛的用户访问。
优势:
(1).跨平台。
(2).SOAP协议是基于XML和HTTP这些业界的标准的,得到了所有的重要公司的支持。
(3).由于使用了SOAP,数据是以ASCII文本的方式而非二进制传输,调试很方便;并且由于这样,它的数据容易通过防火墙,不需要防火墙为了程序而单独开一个“漏洞”。
(4).此外,WebService实现的技术难度要比CORBA和DCOM小得多。
(5).要实现B2B集成,EDI比较完善与比较复杂;而用WebService则可以低成本的实现,小公司也可以用上。
(6).在C/S的程序中,WebService可以实现网页无整体刷新的与服务器打交道并取数。
缺点:
(1).WebService使用了XML对数据封装,会造成大量的数据要在网络中传输。
(2).WebService规范没有规定任何与实现相关的细节,包括对象模型、编程语言,这一点,它不如CORBA。
10.多线程有几种实现方法,都是什么?同步有几种实现方法,都是什么?
答:多线程有两种实现方法,分别是继承Thread类与实现Runnable接口
同步的实现方面有两种,分别是synchronized,wait与notify
11.JSP中动态INCLUDE与静态INCLUDE的区别?
动态INCLUDE用jsp:include动作实现
它总是会检查所含文件中的变化,适合用于包含动态页面,并且可以带参数
静态INCLUDE用include伪码实现,定不会检查所含文件的变化,适用于包含静态页面
二、Java编程与程序运行结果
1.Java编程,打印昨天的当前时刻
public class YesterdayCurrent{
public void main(String[] args){
Calendar cal = Calendar.getInstance();
cal.add(Calendar.DATE, -1);
System.out.println(cal.getTime());
}
}
2.文件读写,实现一个计数器
public int getNum(){
int i = -1;
try{
String stri="";
BufferedReader in = new BufferedReader(new FileReader(f));
while((stri=in.readLine())!=null){
i = Integer.parseInt(stri.trim());
}
in.close();
}catch(Exception e){
e.printStackTrace();
}
return i;
}
本面试的来源于
求职找工作的 人才网的 java论坛
人才网 http://www.palmjob.net/
java论坛 http://bbs.palmjob.net/
public void setNum(){
int i = getNum();
i++;
try{
PrintWriter out=new PrintWriter(new BufferedWriter(new FileWriter(f,false)));
out.write(String.valueOf(i)); //可能是编码的原因,如果直接写入int的话,将出现java编码和windows编码的混乱,因此此处写入的是String
out.close() ;
}catch(Exception e){
e.printStackTrace();
}
}
更多java信息请参考 java论坛
java论坛 http://bbs.palmjob.net/
一、基础问答
1.下面哪些类可以被继承?
java.lang.Thread (T)
java.lang.Number (T)
java.lang.Double (F)
java.lang.Math (F)
java.lang.Void (F)
java.lang.Class (F)
java.lang.ClassLoader (T)
2.抽象类和接口的区别
(1)接口可以被多重implements,抽象类只能被单一extends
(2)接口只有定义,抽象类可以有定义和实现
(3)接口的字段定义默认为:public static final, 抽象类字段默认是"friendly"(本包可见)
3.Hashtable的原理,并说出HashMap与Hashtable的区别
HashTable的原理:通过节点的关键码确定节点的存储位置,即给定节点的关键码k,通过一定的函数关系H(散列函数),得到函数值H(k),将此值解释为该节点的存储地址.
HashMap 与Hashtable很相似,但HashMap 是非同步(unsynchronizded)和可以以null为关键码的.
4.forward和redirect的区别
forward: an internal transfer in servlet
redirect: 重定向,有2次request,第2次request将丢失第一次的attributs/parameters等
5.什么是Web容器?
实现J2EE规范中web协议的应用.该协议定义了web程序的运行时环境,包括:并发性,安全性,生命周期管理等等.
6.解释下面关于J2EE的名词
(1)JNDI:Java Naming & Directory Interface,JAVA命名目录服务.主要提供的功能是:提供一个目录系统,让其它各地的应用程序在其上面留下自己的索引,从而满足快速查找和定位分布式应用程序的功能.
(2)JMS:Java Message Service,JAVA消息服务.主要实现各个应用程序之间的通讯.包括点对点和广播.
(3)JTA:Java Transaction API,JAVA事务服务.提供各种分布式事务服务.应用程序只需调用其提供的接口即可.
(4)JAF: Java Action FrameWork,JAVA安全认证框架.提供一些安全控制方面的框架.让开发者通过各种部署和自定义实现自己的个性安全控制策略.
(5)RMI:Remote Method Interface,远程方法调用
7.EJB是基于哪些技术实现的?并说 出SessionBean和EntityBean的区别,StatefulBean和StatelessBean的区别.
EJB包括Session Bean、Entity Bean、Message Driven Bean,基于JNDI、RMI、JAT等技术实现.
SessionBean在J2EE应用程序中被用来完成一些服务器端的业务操作,例如访问数据库、调用其他EJB组件.EntityBean被用来代表应用系统中用到的数据.对于客户机,SessionBean是一种非持久性对象,它实现某些在服务器上运行的业务逻辑;EntityBean是一种持久性对象,它代表一个存储在持久性存储器中的实体的对象视图,或是一个由现有企业应用程序实现的实体.
Session Bean 还可以再细分为 Stateful Session Bean 与 Stateless Session Bean .这两种的 Session Bean都可以将系统逻辑放在 method之中执行,不同的是 Stateful Session Bean 可以记录呼叫者的状态,因此通常来说,一个使用者会有一个相对应的 Stateful Session Bean 的实体.Stateless Session Bean 虽然也是逻辑组件,但是他却不负责记录使用者状态,也就是说当使用者呼叫 Stateless Session Bean 的时候,EJB Container 并不会找寻特定的 Stateless Session Bean 的实体来执行这个 method.换言之,很可能数个使用者在执行某个 Stateless Session Bean 的 methods 时,会是同一个 Bean 的 Instance 在执行.从内存方面来看, Stateful Session Bean 与 Stateless Session Bean 比较, Stateful Session Bean 会消耗 J2EE Server 较多的内存,然而 Stateful Session Bean 的优势却在于他可以维持使用者的状态.
8.XML的解析方法
Sax,DOM,JDOM
9.什么是Web Service?
Web Service就是为了使原来各孤立的站点之间的信息能够相互通信、共享而提出的一种接口。
Web Service所使用的是Internet上统一、开放的标准,如HTTP、XML、SOAP(简单对象访问协议)、WSDL等,所以Web Service可以在任何支持这些标准的环境(Windows,Linux)中使用。
注:SOAP协议(Simple Object Access Protocal,简单对象访问协议),它是一个用于分散和分布式环境下网络信息交换的基于XML的通讯协议。在此协议下,软件组件或应用程序能够通过标准的HTTP协议进行通讯。它的设计目标就是简单性和扩展性,这有助于大量异构程序和平台之间的互操作性,从而使存在的应用程序能够被广泛的用户访问。
优势:
(1).跨平台。
(2).SOAP协议是基于XML和HTTP这些业界的标准的,得到了所有的重要公司的支持。
(3).由于使用了SOAP,数据是以ASCII文本的方式而非二进制传输,调试很方便;并且由于这样,它的数据容易通过防火墙,不需要防火墙为了程序而单独开一个“漏洞”。
(4).此外,WebService实现的技术难度要比CORBA和DCOM小得多。
(5).要实现B2B集成,EDI比较完善与比较复杂;而用WebService则可以低成本的实现,小公司也可以用上。
(6).在C/S的程序中,WebService可以实现网页无整体刷新的与服务器打交道并取数。
缺点:
(1).WebService使用了XML对数据封装,会造成大量的数据要在网络中传输。
(2).WebService规范没有规定任何与实现相关的细节,包括对象模型、编程语言,这一点,它不如CORBA。
10.多线程有几种实现方法,都是什么?同步有几种实现方法,都是什么?
答:多线程有两种实现方法,分别是继承Thread类与实现Runnable接口
同步的实现方面有两种,分别是synchronized,wait与notify
11.JSP中动态INCLUDE与静态INCLUDE的区别?
动态INCLUDE用jsp:include动作实现
它总是会检查所含文件中的变化,适合用于包含动态页面,并且可以带参数
静态INCLUDE用include伪码实现,定不会检查所含文件的变化,适用于包含静态页面
二、Java编程与程序运行结果
1.Java编程,打印昨天的当前时刻
public class YesterdayCurrent{
public void main(String[] args){
Calendar cal = Calendar.getInstance();
cal.add(Calendar.DATE, -1);
System.out.println(cal.getTime());
}
}
2.文件读写,实现一个计数器
public int getNum(){
int i = -1;
try{
String stri="";
BufferedReader in = new BufferedReader(new FileReader(f));
while((stri=in.readLine())!=null){
i = Integer.parseInt(stri.trim());
}
in.close();
}catch(Exception e){
e.printStackTrace();
}
return i;
}
本面试的来源于
求职找工作的 人才网的 java论坛
人才网 http://www.palmjob.net/
java论坛 http://bbs.palmjob.net/
public void setNum(){
int i = getNum();
i++;
try{
PrintWriter out=new PrintWriter(new BufferedWriter(new FileWriter(f,false)));
out.write(String.valueOf(i)); //可能是编码的原因,如果直接写入int的话,将出现java编码和windows编码的混乱,因此此处写入的是String
out.close() ;
}catch(Exception e){
e.printStackTrace();
}
}
更多java信息请参考 java论坛
java论坛 http://bbs.palmjob.net/
#8
顶 2楼,不错值得一赞~~~
#9
#10
关注
#11
关注
#12
可以借鉴网易聊天室的技术。socket 通讯,客户端封装成flash
#13
支持。。。
#14
一台服务器有65535个通信端口,除开系统端口和系统通信端口,能用的大概3万个,长连接超过3万需要多台的服务器支持,web聊天可以参考facebook的web聊天插件,它的千万级用户都用这个聊天系统,听说facebook要开源,从年前叫到现在也没看到开源,意外的是今天去facebook居然看到我们温总理的facebook
http://www.facebook.com/pages/-Wen-Jia-bao/13823116911
http://www.facebook.com/pages/-Wen-Jia-bao/13823116911
#15
Mark!
#16
回帖接分
#17
up
#18
如果使用dwr框架的话,可以配置 长连接 的。
可以配置3种方式的连接:Polling,Comet,Piggyback
具体看:
http://directwebremoting.org/dwr/reverse-ajax
可以配置3种方式的连接:Polling,Comet,Piggyback
具体看:
http://directwebremoting.org/dwr/reverse-ajax
#19
进来学习的
#20
学习~~
#21
dwr + jetty6的comet应用
http://www.ibm.com/developerworks/cn/java/j-jettydwr/index.html
刚好在做一个服务器推送的监控系统
共同学习
http://www.ibm.com/developerworks/cn/java/j-jettydwr/index.html
刚好在做一个服务器推送的监控系统
共同学习
#22
facebook早已开源
#23
学习
#24
#25
studying
#26
学习了差不多一个周,理论上和实现上基本都能搞定了.
虽然二楼没有给出代码,但从实现上讲,基本上就是那样.用一个隐藏的frame来建立与服务器的长连接,在隐藏frame中,可以加一个监听和控制,以此来与服务器端通过信.所以打算把分给二楼.
我参考的源代码是pushlet框架,非常欢迎大家与我交流 QQ:21562501
虽然二楼没有给出代码,但从实现上讲,基本上就是那样.用一个隐藏的frame来建立与服务器的长连接,在隐藏frame中,可以加一个监听和控制,以此来与服务器端通过信.所以打算把分给二楼.
我参考的源代码是pushlet框架,非常欢迎大家与我交流 QQ:21562501
#27
推荐基于socket的flash或者silverlight。
flash communication server、silverlight原本就是来解决这种问题的,为什么不用呢,干嘛用Comet。
flash communication server、silverlight原本就是来解决这种问题的,为什么不用呢,干嘛用Comet。
#28
不错,以前接触一些,看了有更深的理解
#29
dddddd
#30
iis里面打开keepalive,虽然打开这个选项,但还是http还是无状态的。
#31
#32
#33
引用 30 楼 onlytiancai 的回复:
iis里面打开keepalive,虽然打开这个选项,但还是http还是无状态的。
iis里面打开keepalive,虽然打开这个选项,但还是http还是无状态的。
#34
这个功能用 RIA 来实现最省资源,通过建立 SOCKET 连接
#35
关注
#36
呵呵,好贴,学习
#37
其实他们没讲什么,好什么哦
#38
学习 现在用不上 了解一下
#39
看不懂。。。。。。。。
#40
#41
今朝软件2008年再推最新qq辅助软件--『QQ神通』
拥有10大超强功能:
★强制视频功能 ★暴力破解QQ密码
★发送QQ洪水消息 ★查看好友IP地址
★聊天记录监视 ★破解QQ相册密码
★自动互踩QQ空间 ★强制对方掉线
★生成QQ木马大盗 ★查看同网吧女性
试用软件下载地址:
http://www.52shentong.cn/?20026-1.html
拥有10大超强功能:
★强制视频功能 ★暴力破解QQ密码
★发送QQ洪水消息 ★查看好友IP地址
★聊天记录监视 ★破解QQ相册密码
★自动互踩QQ空间 ★强制对方掉线
★生成QQ木马大盗 ★查看同网吧女性
试用软件下载地址:
http://www.52shentong.cn/?20026-1.html
#42
Mark!
#43
#44
mark
#45
mark
#46
顶,太强了,我也想学习一下
#47
顶顶,强
#48
有些高深,暂时理解不了。
#49
看看这段jsp的push。
<%@ page language="java" contentType="text/html; charset=utf8"%>
<%
response
.setContentType("multipart/x-mixed-replace;boundary=BOUNDARY");
%>
--BOUNDARY
<%
for (int i = 0; i <= 5000; i++) {
%>Content-Type: text/html; charset=utf8
<HTML>
<BODY>
<h1>
<%
for (int j = 0; j < i; j++) {
out.println(j);
out.println("\n");
}
%>
</h1>
</BODY>
</HTML>
--BOUNDARY
<%
out.flush();
Thread.sleep(1000);
}
%>
--BOUNDARY--
#50
mark
#1
用ajax 的 timer 定时获取或提交数据。
也可用一个宽为0 高为0的iframe 包含一个自动提交数据的页。 这样就能http长链接了,session 也就不会过期了
也可用一个宽为0 高为0的iframe 包含一个自动提交数据的页。 这样就能http长链接了,session 也就不会过期了
#2
可以参考下:
http://bbs.chinaunix.net/thread-1088810-1-1.html
服务端:
<?php
$filename = dirname(__FILE__).'/data.txt';
// store new message in the file
$msg = isset($_GET['msg']) ? $_GET['msg'] : '';
if ($msg != '')
{
file_put_contents($filename,$msg);
die();
}
// infinite loop until the data file is not modified
$lastmodif = isset($_GET['timestamp']) ? $_GET['timestamp'] : 0;
$currentmodif = filemtime($filename);
while ($currentmodif <= $lastmodif) // check if the data file has been modified
{
usleep(10000); // sleep 10ms to unload the CPU
clearstatcache();
$currentmodif = filemtime($filename);
}
// return a json array
$response = array();
$response['msg'] = file_get_contents($filename);
$response['timestamp'] = $currentmodif;
echo json_encode($response);
flush();
?>
http://bbs.chinaunix.net/thread-1088810-1-1.html
服务端:
<?php
$filename = dirname(__FILE__).'/data.txt';
// store new message in the file
$msg = isset($_GET['msg']) ? $_GET['msg'] : '';
if ($msg != '')
{
file_put_contents($filename,$msg);
die();
}
// infinite loop until the data file is not modified
$lastmodif = isset($_GET['timestamp']) ? $_GET['timestamp'] : 0;
$currentmodif = filemtime($filename);
while ($currentmodif <= $lastmodif) // check if the data file has been modified
{
usleep(10000); // sleep 10ms to unload the CPU
clearstatcache();
$currentmodif = filemtime($filename);
}
// return a json array
$response = array();
$response['msg'] = file_get_contents($filename);
$response['timestamp'] = $currentmodif;
echo json_encode($response);
flush();
?>
#3
谢谢两位的up!对于HTTP长连接技术我这两天才开始学习,这方面的知识很弱.
因为老大叫我搞一个web版的聊天系统(IM),没得办法只有硬起头皮搞哦.
像用JS来定时发请求获得数据这种ajax技术,主要是太浪费网络带宽了;
所以关注一下HTTP的长连接,只要有心跳,服务器端就向客户端推送数据---->服务器推技术.
服务器推技术理论上了解,但是技术上还没有掌握,在网上找了个框架pushlet,据说比较轻量(JAVA写的),研究中...
服务器推技术有两个技术点不明白:
1. 建立HTTP长连接的request格式和response格式是什么?
2. 因为是长连接,所以服务器端要保存住连接,这就要消耗服务器系统资源,
请问一下非服务器的双核台式机(CPU 1.8GHZ) 1G内存能支持多少长连接?
因为老大叫我搞一个web版的聊天系统(IM),没得办法只有硬起头皮搞哦.
像用JS来定时发请求获得数据这种ajax技术,主要是太浪费网络带宽了;
所以关注一下HTTP的长连接,只要有心跳,服务器端就向客户端推送数据---->服务器推技术.
服务器推技术理论上了解,但是技术上还没有掌握,在网上找了个框架pushlet,据说比较轻量(JAVA写的),研究中...
服务器推技术有两个技术点不明白:
1. 建立HTTP长连接的request格式和response格式是什么?
2. 因为是长连接,所以服务器端要保存住连接,这就要消耗服务器系统资源,
请问一下非服务器的双核台式机(CPU 1.8GHZ) 1G内存能支持多少长连接?
#4
通信双方以客户-服务器方式建立TCP连接,用于双方信息的相互提交。当信道上没有数据传输时,通信双方应每隔时间C发送链路检测包以维持此连接,当链路检测包发出超过时间T后未收到响应,应立即再发送链路检测包,再连续发送N-1次后仍未得到响应则断开此连接。
#5
服务器推技术,学习受教了!
#6
dwr 可以实现
#7
J2EE面试题集锦(附答案)
一、基础问答
1.下面哪些类可以被继承?
java.lang.Thread (T)
java.lang.Number (T)
java.lang.Double (F)
java.lang.Math (F)
java.lang.Void (F)
java.lang.Class (F)
java.lang.ClassLoader (T)
2.抽象类和接口的区别
(1)接口可以被多重implements,抽象类只能被单一extends
(2)接口只有定义,抽象类可以有定义和实现
(3)接口的字段定义默认为:public static final, 抽象类字段默认是"friendly"(本包可见)
3.Hashtable的原理,并说出HashMap与Hashtable的区别
HashTable的原理:通过节点的关键码确定节点的存储位置,即给定节点的关键码k,通过一定的函数关系H(散列函数),得到函数值H(k),将此值解释为该节点的存储地址.
HashMap 与Hashtable很相似,但HashMap 是非同步(unsynchronizded)和可以以null为关键码的.
4.forward和redirect的区别
forward: an internal transfer in servlet
redirect: 重定向,有2次request,第2次request将丢失第一次的attributs/parameters等
5.什么是Web容器?
实现J2EE规范中web协议的应用.该协议定义了web程序的运行时环境,包括:并发性,安全性,生命周期管理等等.
6.解释下面关于J2EE的名词
(1)JNDI:Java Naming & Directory Interface,JAVA命名目录服务.主要提供的功能是:提供一个目录系统,让其它各地的应用程序在其上面留下自己的索引,从而满足快速查找和定位分布式应用程序的功能.
(2)JMS:Java Message Service,JAVA消息服务.主要实现各个应用程序之间的通讯.包括点对点和广播.
(3)JTA:Java Transaction API,JAVA事务服务.提供各种分布式事务服务.应用程序只需调用其提供的接口即可.
(4)JAF: Java Action FrameWork,JAVA安全认证框架.提供一些安全控制方面的框架.让开发者通过各种部署和自定义实现自己的个性安全控制策略.
(5)RMI:Remote Method Interface,远程方法调用
7.EJB是基于哪些技术实现的?并说 出SessionBean和EntityBean的区别,StatefulBean和StatelessBean的区别.
EJB包括Session Bean、Entity Bean、Message Driven Bean,基于JNDI、RMI、JAT等技术实现.
SessionBean在J2EE应用程序中被用来完成一些服务器端的业务操作,例如访问数据库、调用其他EJB组件.EntityBean被用来代表应用系统中用到的数据.对于客户机,SessionBean是一种非持久性对象,它实现某些在服务器上运行的业务逻辑;EntityBean是一种持久性对象,它代表一个存储在持久性存储器中的实体的对象视图,或是一个由现有企业应用程序实现的实体.
Session Bean 还可以再细分为 Stateful Session Bean 与 Stateless Session Bean .这两种的 Session Bean都可以将系统逻辑放在 method之中执行,不同的是 Stateful Session Bean 可以记录呼叫者的状态,因此通常来说,一个使用者会有一个相对应的 Stateful Session Bean 的实体.Stateless Session Bean 虽然也是逻辑组件,但是他却不负责记录使用者状态,也就是说当使用者呼叫 Stateless Session Bean 的时候,EJB Container 并不会找寻特定的 Stateless Session Bean 的实体来执行这个 method.换言之,很可能数个使用者在执行某个 Stateless Session Bean 的 methods 时,会是同一个 Bean 的 Instance 在执行.从内存方面来看, Stateful Session Bean 与 Stateless Session Bean 比较, Stateful Session Bean 会消耗 J2EE Server 较多的内存,然而 Stateful Session Bean 的优势却在于他可以维持使用者的状态.
8.XML的解析方法
Sax,DOM,JDOM
9.什么是Web Service?
Web Service就是为了使原来各孤立的站点之间的信息能够相互通信、共享而提出的一种接口。
Web Service所使用的是Internet上统一、开放的标准,如HTTP、XML、SOAP(简单对象访问协议)、WSDL等,所以Web Service可以在任何支持这些标准的环境(Windows,Linux)中使用。
注:SOAP协议(Simple Object Access Protocal,简单对象访问协议),它是一个用于分散和分布式环境下网络信息交换的基于XML的通讯协议。在此协议下,软件组件或应用程序能够通过标准的HTTP协议进行通讯。它的设计目标就是简单性和扩展性,这有助于大量异构程序和平台之间的互操作性,从而使存在的应用程序能够被广泛的用户访问。
优势:
(1).跨平台。
(2).SOAP协议是基于XML和HTTP这些业界的标准的,得到了所有的重要公司的支持。
(3).由于使用了SOAP,数据是以ASCII文本的方式而非二进制传输,调试很方便;并且由于这样,它的数据容易通过防火墙,不需要防火墙为了程序而单独开一个“漏洞”。
(4).此外,WebService实现的技术难度要比CORBA和DCOM小得多。
(5).要实现B2B集成,EDI比较完善与比较复杂;而用WebService则可以低成本的实现,小公司也可以用上。
(6).在C/S的程序中,WebService可以实现网页无整体刷新的与服务器打交道并取数。
缺点:
(1).WebService使用了XML对数据封装,会造成大量的数据要在网络中传输。
(2).WebService规范没有规定任何与实现相关的细节,包括对象模型、编程语言,这一点,它不如CORBA。
10.多线程有几种实现方法,都是什么?同步有几种实现方法,都是什么?
答:多线程有两种实现方法,分别是继承Thread类与实现Runnable接口
同步的实现方面有两种,分别是synchronized,wait与notify
11.JSP中动态INCLUDE与静态INCLUDE的区别?
动态INCLUDE用jsp:include动作实现
它总是会检查所含文件中的变化,适合用于包含动态页面,并且可以带参数
静态INCLUDE用include伪码实现,定不会检查所含文件的变化,适用于包含静态页面
二、Java编程与程序运行结果
1.Java编程,打印昨天的当前时刻
public class YesterdayCurrent{
public void main(String[] args){
Calendar cal = Calendar.getInstance();
cal.add(Calendar.DATE, -1);
System.out.println(cal.getTime());
}
}
2.文件读写,实现一个计数器
public int getNum(){
int i = -1;
try{
String stri="";
BufferedReader in = new BufferedReader(new FileReader(f));
while((stri=in.readLine())!=null){
i = Integer.parseInt(stri.trim());
}
in.close();
}catch(Exception e){
e.printStackTrace();
}
return i;
}
本面试的来源于
求职找工作的 人才网的 java论坛
人才网 http://www.palmjob.net/
java论坛 http://bbs.palmjob.net/
public void setNum(){
int i = getNum();
i++;
try{
PrintWriter out=new PrintWriter(new BufferedWriter(new FileWriter(f,false)));
out.write(String.valueOf(i)); //可能是编码的原因,如果直接写入int的话,将出现java编码和windows编码的混乱,因此此处写入的是String
out.close() ;
}catch(Exception e){
e.printStackTrace();
}
}
更多java信息请参考 java论坛
java论坛 http://bbs.palmjob.net/
一、基础问答
1.下面哪些类可以被继承?
java.lang.Thread (T)
java.lang.Number (T)
java.lang.Double (F)
java.lang.Math (F)
java.lang.Void (F)
java.lang.Class (F)
java.lang.ClassLoader (T)
2.抽象类和接口的区别
(1)接口可以被多重implements,抽象类只能被单一extends
(2)接口只有定义,抽象类可以有定义和实现
(3)接口的字段定义默认为:public static final, 抽象类字段默认是"friendly"(本包可见)
3.Hashtable的原理,并说出HashMap与Hashtable的区别
HashTable的原理:通过节点的关键码确定节点的存储位置,即给定节点的关键码k,通过一定的函数关系H(散列函数),得到函数值H(k),将此值解释为该节点的存储地址.
HashMap 与Hashtable很相似,但HashMap 是非同步(unsynchronizded)和可以以null为关键码的.
4.forward和redirect的区别
forward: an internal transfer in servlet
redirect: 重定向,有2次request,第2次request将丢失第一次的attributs/parameters等
5.什么是Web容器?
实现J2EE规范中web协议的应用.该协议定义了web程序的运行时环境,包括:并发性,安全性,生命周期管理等等.
6.解释下面关于J2EE的名词
(1)JNDI:Java Naming & Directory Interface,JAVA命名目录服务.主要提供的功能是:提供一个目录系统,让其它各地的应用程序在其上面留下自己的索引,从而满足快速查找和定位分布式应用程序的功能.
(2)JMS:Java Message Service,JAVA消息服务.主要实现各个应用程序之间的通讯.包括点对点和广播.
(3)JTA:Java Transaction API,JAVA事务服务.提供各种分布式事务服务.应用程序只需调用其提供的接口即可.
(4)JAF: Java Action FrameWork,JAVA安全认证框架.提供一些安全控制方面的框架.让开发者通过各种部署和自定义实现自己的个性安全控制策略.
(5)RMI:Remote Method Interface,远程方法调用
7.EJB是基于哪些技术实现的?并说 出SessionBean和EntityBean的区别,StatefulBean和StatelessBean的区别.
EJB包括Session Bean、Entity Bean、Message Driven Bean,基于JNDI、RMI、JAT等技术实现.
SessionBean在J2EE应用程序中被用来完成一些服务器端的业务操作,例如访问数据库、调用其他EJB组件.EntityBean被用来代表应用系统中用到的数据.对于客户机,SessionBean是一种非持久性对象,它实现某些在服务器上运行的业务逻辑;EntityBean是一种持久性对象,它代表一个存储在持久性存储器中的实体的对象视图,或是一个由现有企业应用程序实现的实体.
Session Bean 还可以再细分为 Stateful Session Bean 与 Stateless Session Bean .这两种的 Session Bean都可以将系统逻辑放在 method之中执行,不同的是 Stateful Session Bean 可以记录呼叫者的状态,因此通常来说,一个使用者会有一个相对应的 Stateful Session Bean 的实体.Stateless Session Bean 虽然也是逻辑组件,但是他却不负责记录使用者状态,也就是说当使用者呼叫 Stateless Session Bean 的时候,EJB Container 并不会找寻特定的 Stateless Session Bean 的实体来执行这个 method.换言之,很可能数个使用者在执行某个 Stateless Session Bean 的 methods 时,会是同一个 Bean 的 Instance 在执行.从内存方面来看, Stateful Session Bean 与 Stateless Session Bean 比较, Stateful Session Bean 会消耗 J2EE Server 较多的内存,然而 Stateful Session Bean 的优势却在于他可以维持使用者的状态.
8.XML的解析方法
Sax,DOM,JDOM
9.什么是Web Service?
Web Service就是为了使原来各孤立的站点之间的信息能够相互通信、共享而提出的一种接口。
Web Service所使用的是Internet上统一、开放的标准,如HTTP、XML、SOAP(简单对象访问协议)、WSDL等,所以Web Service可以在任何支持这些标准的环境(Windows,Linux)中使用。
注:SOAP协议(Simple Object Access Protocal,简单对象访问协议),它是一个用于分散和分布式环境下网络信息交换的基于XML的通讯协议。在此协议下,软件组件或应用程序能够通过标准的HTTP协议进行通讯。它的设计目标就是简单性和扩展性,这有助于大量异构程序和平台之间的互操作性,从而使存在的应用程序能够被广泛的用户访问。
优势:
(1).跨平台。
(2).SOAP协议是基于XML和HTTP这些业界的标准的,得到了所有的重要公司的支持。
(3).由于使用了SOAP,数据是以ASCII文本的方式而非二进制传输,调试很方便;并且由于这样,它的数据容易通过防火墙,不需要防火墙为了程序而单独开一个“漏洞”。
(4).此外,WebService实现的技术难度要比CORBA和DCOM小得多。
(5).要实现B2B集成,EDI比较完善与比较复杂;而用WebService则可以低成本的实现,小公司也可以用上。
(6).在C/S的程序中,WebService可以实现网页无整体刷新的与服务器打交道并取数。
缺点:
(1).WebService使用了XML对数据封装,会造成大量的数据要在网络中传输。
(2).WebService规范没有规定任何与实现相关的细节,包括对象模型、编程语言,这一点,它不如CORBA。
10.多线程有几种实现方法,都是什么?同步有几种实现方法,都是什么?
答:多线程有两种实现方法,分别是继承Thread类与实现Runnable接口
同步的实现方面有两种,分别是synchronized,wait与notify
11.JSP中动态INCLUDE与静态INCLUDE的区别?
动态INCLUDE用jsp:include动作实现
它总是会检查所含文件中的变化,适合用于包含动态页面,并且可以带参数
静态INCLUDE用include伪码实现,定不会检查所含文件的变化,适用于包含静态页面
二、Java编程与程序运行结果
1.Java编程,打印昨天的当前时刻
public class YesterdayCurrent{
public void main(String[] args){
Calendar cal = Calendar.getInstance();
cal.add(Calendar.DATE, -1);
System.out.println(cal.getTime());
}
}
2.文件读写,实现一个计数器
public int getNum(){
int i = -1;
try{
String stri="";
BufferedReader in = new BufferedReader(new FileReader(f));
while((stri=in.readLine())!=null){
i = Integer.parseInt(stri.trim());
}
in.close();
}catch(Exception e){
e.printStackTrace();
}
return i;
}
本面试的来源于
求职找工作的 人才网的 java论坛
人才网 http://www.palmjob.net/
java论坛 http://bbs.palmjob.net/
public void setNum(){
int i = getNum();
i++;
try{
PrintWriter out=new PrintWriter(new BufferedWriter(new FileWriter(f,false)));
out.write(String.valueOf(i)); //可能是编码的原因,如果直接写入int的话,将出现java编码和windows编码的混乱,因此此处写入的是String
out.close() ;
}catch(Exception e){
e.printStackTrace();
}
}
更多java信息请参考 java论坛
java论坛 http://bbs.palmjob.net/
#8
顶 2楼,不错值得一赞~~~
#9
#10
关注
#11
关注
#12
可以借鉴网易聊天室的技术。socket 通讯,客户端封装成flash
#13
支持。。。
#14
一台服务器有65535个通信端口,除开系统端口和系统通信端口,能用的大概3万个,长连接超过3万需要多台的服务器支持,web聊天可以参考facebook的web聊天插件,它的千万级用户都用这个聊天系统,听说facebook要开源,从年前叫到现在也没看到开源,意外的是今天去facebook居然看到我们温总理的facebook
http://www.facebook.com/pages/-Wen-Jia-bao/13823116911
http://www.facebook.com/pages/-Wen-Jia-bao/13823116911
#15
Mark!
#16
回帖接分
#17
up
#18
如果使用dwr框架的话,可以配置 长连接 的。
可以配置3种方式的连接:Polling,Comet,Piggyback
具体看:
http://directwebremoting.org/dwr/reverse-ajax
可以配置3种方式的连接:Polling,Comet,Piggyback
具体看:
http://directwebremoting.org/dwr/reverse-ajax
#19
进来学习的
#20
学习~~
#21
dwr + jetty6的comet应用
http://www.ibm.com/developerworks/cn/java/j-jettydwr/index.html
刚好在做一个服务器推送的监控系统
共同学习
http://www.ibm.com/developerworks/cn/java/j-jettydwr/index.html
刚好在做一个服务器推送的监控系统
共同学习
#22
facebook早已开源
#23
学习
#24
#25
studying
#26
学习了差不多一个周,理论上和实现上基本都能搞定了.
虽然二楼没有给出代码,但从实现上讲,基本上就是那样.用一个隐藏的frame来建立与服务器的长连接,在隐藏frame中,可以加一个监听和控制,以此来与服务器端通过信.所以打算把分给二楼.
我参考的源代码是pushlet框架,非常欢迎大家与我交流 QQ:21562501
虽然二楼没有给出代码,但从实现上讲,基本上就是那样.用一个隐藏的frame来建立与服务器的长连接,在隐藏frame中,可以加一个监听和控制,以此来与服务器端通过信.所以打算把分给二楼.
我参考的源代码是pushlet框架,非常欢迎大家与我交流 QQ:21562501
#27
推荐基于socket的flash或者silverlight。
flash communication server、silverlight原本就是来解决这种问题的,为什么不用呢,干嘛用Comet。
flash communication server、silverlight原本就是来解决这种问题的,为什么不用呢,干嘛用Comet。
#28
不错,以前接触一些,看了有更深的理解
#29
dddddd
#30
iis里面打开keepalive,虽然打开这个选项,但还是http还是无状态的。
#31
#32
#33
引用 30 楼 onlytiancai 的回复:
iis里面打开keepalive,虽然打开这个选项,但还是http还是无状态的。
iis里面打开keepalive,虽然打开这个选项,但还是http还是无状态的。
#34
这个功能用 RIA 来实现最省资源,通过建立 SOCKET 连接
#35
关注
#36
呵呵,好贴,学习
#37
其实他们没讲什么,好什么哦
#38
学习 现在用不上 了解一下
#39
看不懂。。。。。。。。
#40
#41
今朝软件2008年再推最新qq辅助软件--『QQ神通』
拥有10大超强功能:
★强制视频功能 ★暴力破解QQ密码
★发送QQ洪水消息 ★查看好友IP地址
★聊天记录监视 ★破解QQ相册密码
★自动互踩QQ空间 ★强制对方掉线
★生成QQ木马大盗 ★查看同网吧女性
试用软件下载地址:
http://www.52shentong.cn/?20026-1.html
拥有10大超强功能:
★强制视频功能 ★暴力破解QQ密码
★发送QQ洪水消息 ★查看好友IP地址
★聊天记录监视 ★破解QQ相册密码
★自动互踩QQ空间 ★强制对方掉线
★生成QQ木马大盗 ★查看同网吧女性
试用软件下载地址:
http://www.52shentong.cn/?20026-1.html
#42
Mark!
#43
#44
mark
#45
mark
#46
顶,太强了,我也想学习一下
#47
顶顶,强
#48
有些高深,暂时理解不了。
#49
看看这段jsp的push。
<%@ page language="java" contentType="text/html; charset=utf8"%>
<%
response
.setContentType("multipart/x-mixed-replace;boundary=BOUNDARY");
%>
--BOUNDARY
<%
for (int i = 0; i <= 5000; i++) {
%>Content-Type: text/html; charset=utf8
<HTML>
<BODY>
<h1>
<%
for (int j = 0; j < i; j++) {
out.println(j);
out.println("\n");
}
%>
</h1>
</BODY>
</HTML>
--BOUNDARY
<%
out.flush();
Thread.sleep(1000);
}
%>
--BOUNDARY--
#50
mark