avatar
Today is 星期天
2010年09月5日

搜索结果 分类目录: 网络

2009年02月24日

Erlang性能初测

由 晨笛 — 分类目录: 网络评论暂缺

安装的CentOS的最初目地是为了进行对Erlang的测试,因为在Windows 2003上连接数到达1024时就出问题了。

昨天已经把Erlang编译安装好了,于是马上就可以进行测试了。

测试服务器端程序很简单,服务器为每个连接分配一个Erlang进程来为它服务。

测试内容是连接10000个客户端。

可是结果和Windows系统下一样,到达1024就不行了。

原来问题还是出在操作系统对进程数的限制,用
ulimit -n 102400
把最大进程数调整到102400个,哈哈。

这下顺利通过了10000个连接。可是对性能结果不是很满意,成功连接1000个客户端总共花了9秒多,汗~
直觉告诉我应该是我的错,得知Erlang默认没有使用epoll,于是使用
erl +K true
打开kernel-poll后,这次的结果是3秒多,还是不够理想。这个问题待日后优化吧。

2008年10月24日

IIS中如何添加iso类型文件下载的方法

由 晨笛 — 分类目录: 网络评论暂缺

在Microsoft Internet Information Services (IIS) 即Internet 信息服务中,链接了”iso、gho” 文件类型,但是浏览时点击”iso、gho”文件下载地址,会出现”无法找到该页面”的提示,相关软件也无法下载。
解决办法如下:
1.在 IIS 管理器中,右键单击要为其添加 MIME 类型的网站或网站目录,单击”属性”。
2.单击”HTTP 头”选项卡。
3.单击”MIME 类型”。
4.单击”新建”。
5.在”扩展名”框中,键入文件扩展名:.iso。
6.在”MIME 类型”框中,键入ISO File
7.单击”确定”。
8.添加iso文件后,前台点击,大功告成。
9.若要再增加更多类型,可同样按照此方法修改。

2008年06月25日

深入研究表单提交方式–GET/POST

由 晨笛 — 分类目录: 网络评论暂缺

本文平台:Windows 2000 Professional + Apache 1.3.17 + Perl 5.6.1 + Internet Explorer 5.00.2920.0000

  大家知道目前表单提交的方式有GET和POST。我在这里不多说什么,给大家看一个以GET方式提交的表单的请求:

GET /cgi-bin/tech/method.cgi?GET=GET HTTP/1.1
Accept: image/gif, image/x-xbitmap, image/jpeg, image/pjpeg, application/vnd.ms-powerpoint, application/vnd.ms-excel, application/msword, */*
Referer: http://localhost//other.html
Accept-Language: zh-cn
Accept-Encoding: gzip, deflate
User-Agent: Mozilla/4.0 (compatible; MSIE 5.01; Windows NT 5.0)
Host: localhost:8080
Connection: Keep-Alive

  这个请求是我们通过这个HTML代码发出的:

<form action=http://localhost:8080/cgi-bin/tech/method.cgi method=GET>
<input type=text size=10 value=GET name=GET>
<input type=submit value=GET方式>
</form>

  这个请求已经超出了我们研究的范围,我们只研究其中的第一行。其中,第一个GET说出了提交的方式,是以GET方式提交的;中间的就是提交给服务器上哪个程序,前面一部分/cgi-bin/tech/method.cgi就是我们HTML的form中action的内容,而后面的GET=GET就是HTML的form中,input的内容:我们发现IE已经把这个表单的内容转换成特定格式了。在Perl中,通过$GET=$ENV{QUERY_STRING}获得以GET发送的数据。

  我们再看一个以POST方式提交的表单的请求:

POST /cgi-bin/tech/method.cgi HTTP/1.1
Accept: image/gif, image/x-xbitmap, image/jpeg, image/pjpeg, application/vnd.ms-
powerpoint, application/vnd.ms-excel, application/msword, */*
Referer: http://localhost//other.html
Accept-Language: zh-cn
Content-Type: application/x-www-form-urlencoded
Accept-Encoding: gzip, deflate
User-Agent: Mozilla/4.0 (compatible; MSIE 5.01; Windows NT 5.0)
Host: localhost:8080
Content-Length: 9
Connection: Keep-Alive

POST=POST

  同样给出HTML:

<form action=http://localhost:8080/cgi-bin/tech/method.cgi method=POST>
<input type=text size=10 value=POST name=POST>
<input type=submit value=POST方式>
</form>

  我们发现其中的数据跑到了最下面。在Perl中,通过read(STDIN,$POST,$ENV{CONTENT_LENGTH})获得以POST发送的数据。我记得GET发送数据最多只能1024字节,而POST好像很大很大!

  思考:如果我有这么一段HTML代码,它将会出现什么问题呢?

<form action=http://localhost:8080/cgi-bin/tech/method.cgi?GET=GET method=POST>
<input type=text size=10 value=POST name=POST>
<input type=submit value=GET/POST方式>
</form>

  这个代码在很多程序上可能用到过,但是大多数人不会好好的想一想,究竟哪些内容是以GET发送的,哪些内容是以POST发送的。我们看看它的请求是什么:

POST /cgi-bin/tech/method.cgi?GET=GET HTTP/1.1
Accept: image/gif, image/x-xbitmap, image/jpeg, image/pjpeg, application/vnd.ms-
powerpoint, application/vnd.ms-excel, application/msword, */*
Referer: http://localhost//other.html
Accept-Language: zh-cn
Content-Type: application/x-www-form-urlencoded
Accept-Encoding: gzip, deflate
User-Agent: Mozilla/4.0 (compatible; MSIE 5.01; Windows NT 5.0)
Host: localhost:8080
Content-Length: 9
Connection: Keep-Alive

POST=POST

  哈!原来是以POST发送的。但是,你一定发现了有一部分数据放在了第一行,就是和GET的情况一样的。其实这个例子很典型,是POST和GET混发!
  不相信你在Perl中,用read(STDIN,$POST,$ENV{CONTENT_LENGTH})和$GET=$ENV{QUERY_STRING}看看,到底哪个里面有GET=GET这个数据。

  我给大家提供设备,大家自己去研究研究:

HTML部分:  

<html>
<head>
<title>Get-Post</title>
</head>

<body>
<form action=/cgi-bin/tech/method.cgi method=GET>
<input type=text size=10 value=GET name=GET>
<input type=submit value=GET方式>
</form>
<form action=/cgi-bin/tech/method.cgi method=POST>
<input type=text size=10 value=POST name=POST>
<input type=submit value=POST方式>
</form>
<form action=/cgi-bin/tech/method.cgi?GET=GET method=POST>
<input type=text size=10 value=POST name=POST>
<input type=submit value=GET/POST方式>
</form>
<form action=/cgi-bin/tech/method.cgi?name=Hackfan&age=16&email=hackfan@163.net method=POST>
<input type=text size=10 value=Suzhou name=address>
<input type=text size=10 value=msger.net name=homepage>
<input type=text size=10 value=106814 name=qq>
<input type=submit value=复杂GET/POST方式>
</form>
</body>
</html>

Perl部分:

#!c:\perl\bin\perl.exe

$|=1;

print Content-type:text/html\n\n;

print 发送方式:$ENV{REQUEST_METHOD}<br>\n;
if(read(STDIN,$POST,$ENV{CONTENT_LENGTH})){
 print POST得到的数据:$POST<br>\n;
}
if($GET=$ENV{QUERY_STRING}){
 print GET得到的数据:$GET<br>\n;
}

$METHOD=POST;

for($i=0;$i<=1;$i++){
 foreach(split(/&/,$$METHOD)){
  $_=~s/\+//g;
  ($name,$value)=split(/=/,$_);
  $name=~s/%([a-fA-f0-9][a-fA-f0-9])/pack(C,hex($1))/eg;
  $value=~s/%([a-fA-f0-9][a-fA-f0-9])/pack(C,hex($1))/eg;
  $$METHOD{$name}=$value;
 }
 $METHOD=GET;
}
$METHOD=POST;

for($i=0;$i<=1;$i++){
 print Hash形式的$METHOD数据遍历:<br>\n;
 foreach(keys %{$METHOD}){
  print \$.$METHOD.{.$_.}=$$METHOD{$_}<br>\n;
 }
 print <br>\n;
 $METHOD=GET;
}

exit;
####代码结束####
  好了,我要说的是,搞这个研究究竟有什么意义呢?
  意义是:让你知道,用户提交的数据哪些是用POST方式,哪些使用GET方式的!
  其实我上面那段Perl代码已经包括了很多的技术。你通过阅读就可以知道%GET里面放的是用GET方式提交的,%POST同理!

2008年04月27日

网络异常断开的处理

由 晨笛 — 分类目录: 网络评论暂缺

在服务端开发中我碰到了各种各样的网络异常断开现象。在处理这些异常的时候有了一些心得,现在写出来和大家分享一下。
那网络异常断开原因主要有那些呢?归纳起来主要有以下两种:

1、客户端程序异常。
对于这种情况,我们很好处理,因为客户端程序异常退出会在服务端引发ConnectionReset的Socket异常(就是WinSock2中的10054异常)。只要在服务端处理这个异常就可以了。

2、网络链路异常。
如:网线拔出、交换机掉电、客户端机器掉电。当出现这些情况的时候服务端不会出现任何异常。这样的话上面的代码就不能处理这种情况了。对于这种情况在MSDN里面是这样处理的,我在这里贴出MSDN的原文:

如果您需要确定连接的当前状态,请进行非阻止、零字节的Send调用。如果该调用成功返回或引发WAEWOULDBLOCK错误代码(10035),则该套接字仍然处于连接状态;否则,该套接字不再处于连接状态。

但是我在实际应用中发现,MSDN说的这种处理方法在很多时候根本无效,无法检测出网络已经异常断开了。那我们该怎么办呢?

我们知道,TCP有一个连接检测机制,就是如果在指定的时间内(一般为2个小时)没有数据传送,会给对端发送一个Keep-Alive数据报,使用的序列号是曾经发出的最后一个报文的最后一个字节的序列号,对端如果收到这个数据,回送一个TCP的ACK,确认这个字节已经收到,这样就知道此连接没有被断开。如果一段时间没有收到对方的响应,会进行重试,重试几次后,向对端发一个reset,然后将连接断掉。

在Windows中,第一次探测是在最后一次数据发送的两个小时,然后每隔1秒探测一次,一共探测5次,如果5次都没有收到回应的话,就会断开这个连接。但两个小时对于我们的项目来说显然太长了。我们必须缩短这个时间。

© 2010 晨笛的博客 All rights reserved - Wallow theme by TwoBeers Crew - Powered by WordPress - 使用愉快!