1、实验环境:

联想小型机:

操作系统:RedHat Enterprise LinuxServer release6.4(Santiago)

内核版本号:Linux server1 2.6.32-358.el6.x86_64#1 SMP

CPU型号:Intel(R)Xeon(R)CPU
E7-4820 @2.00Ghz。

内存:132G

磁盘:289G

、基于erlang开发设计了TCPserver,

)tcp连接过程序的建立,server端的port数=clientport数+1;(2)port的打开的数量上限决定着tcp连接的个数。

,通过ulimit
–n 1000000。该值不能超过硬限制的个数。

假设要进一步提高。须要从软限制和硬限制双方面考虑,详细可參考:还有一方面/proc/sys/net/ipv4/ip_local_port_range的值决定了一个侦听端口所能接收的最大tcp连接数,改动该值能够通过vi
/etc/sysctl.conf,改动后运行sysctcl -p使其生效。提高连接数的一个方法是通过开多个侦听端口来接收client的连接。怎样改动操作系统所能打开的最大文件数和ip_local_port_range成为影响tcp连接总数的两个关键点。

Erlang虚拟机默认的port上限为65536, erlang17通过erl
+Q 1000000能够改动端口上限为1000000,利用erlang:system_info(port_limit)进行查询,系统能够打开的最大文件描写叙述符能够通过erlang:system_info(check_io)中的max_fds进行查看,查看系统当前port数量能够用erlang:length(erlang:ports())得到

、代码:

tcp_client

-module(tcp_client).

]).

loop_start(Port,Num)->

case start(Port)of

system_limit
-> io:format("");

)

end.

start(Port)->

try

case gen_tcp:connect("127.0.0.1",Port,
[binary,{packet,raw},{active,true},{reuseaddr,true}])of

{ok,Socket}->Socket;

{error,Reason}-> {error,Reason}

end

catch

throw:T->T;

exit:R->R;

error:E->E

end.

send_data(Socket,Data)when
is_list(Data)orelse is_binary(Data)->

gen_tcp:send(Socket,Data),

receive

{tcp,Socket,Bin}->

io:format("recv~p~n",[Bin]);

{tcp_closed,Socket}->

io:format("receive server don't accept connection!~n")

end.

close(Socket)when is_port(Socket)->

gen_tcp:close(Socket).

generic_server:

-module(generic_server).

-behaviour(gen_server).

-define(TCP_OPTIONS,[binary,{packet,raw},{reuseaddr,true},{active,false}]).

]).

-export([]).

,maxconn}).

start(ServerName,Port,Max,{M,F})->

gen_server:start_link({local,ServerName},?MODULE,[#server_state{port=Port,maxconn=Max,loop={M,F}}],[]).

init([State=#server_state{port=Port}])->

case gen_tcp:listen(Port,?

TCP_OPTIONS)of

{ok,LSocket}->

{ok,accept(State#server_state{lsocket=LSocket})};

{error,Reason}->

{stop,{create_listen_socket,Reason}}

end.

accept(State=#server_state{lsocket=LSocket,loop=Loop,conn=Conn,maxconn=Max})->

Pid = spawn(generic_server,accept_loop,[self(),LSocket,Loop,Conn,Max]),

State.

accept_loop(Server,LSocket,{M,F},Conn,Max)->

erlang:group_leader(erlang:whereis(user),self()),

{ok,Sock} = gen_tcp:accept(LSocket),

if

true ->

gen_server:cast(Server,{accept_new,self()}),

M:F(Sock)

end.

handle_cast({accept_new,FromPid},State)->

Conn =State#server_state.conn,

]),

LSocket =State#server_state.lsocket,

Loop=State#server_state.loop,

Max=State#server_state.maxconn,

,Max]),

{noreply,
State}};

handle_cast({connect_close,FromPid},State)->

Conn=State#server_state.conn,

]),

}}.

echo_server:

-module(echo_server).

]).

start(Port)->

,

generic_server:start(echo_server,
Port, Max, {?

MODULE,loop}).

loop(Sock)->

)of

{ok,Data}->

gen_tcp:send(Sock,Data),

loop(Sock);

{error,closed}
->

io:format("client sock close~n"),

gen_server:cast(echo_server,{connect_close,self()})

end.

、通信流程

watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvemNjXzAwMTU=/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/Center">

5、结论

设定ulimit  –n 100000。假定ip_local_port_range   1   65535,侦听一个port的连接数为65534,再打开一个侦听port为100000-65534=34466,  
单端口受制于ip_local_port_range的范围。总共的连接数为打开的文件描写叙述符个数。

Linux下基于Erlang的高并发TCP连接压力实验的更多相关文章

  1. 配置开发支持高并发TCP连接的Linux应用程序全攻略

    http://blog.chinaunix.net/uid-20733992-id-3447120.html http://blog.chinaunix.net/space.php?uid=16480 ...

  2. Linux配置支持高并发TCP连接(socket最大连接数)

    Linux配置支持高并发TCP连接(socket最大连接数) Linux配置支持高并发TCP连接(socket最大连接数)及优化内核参数 2011-08-09 15:20:58|  分类:LNMP&a ...

  3. 高并发TCP连接数目问题

    linux可通过五元组唯一确定一个链接:源IP,源端口,目的IP,目的端口,传输层协议.而一个端口不允许被两个及以上进程占用(一个进程可同时占用多个端口),据此是否可以推测一台linux服务器最多可以 ...

  4. linux下突破10万高并发的nginx性能优化经验

    一.这里的优化主要是指对nginx的配置优化,一般来说nginx配置文件中对优化比较有作用的主要有以下几项:1)nginx进程数,建议按照cpu数目来指定,一般跟cpu核数相同或为它的倍数.worke ...

  5. 基于RTKLIB构建高并发通信测试工具

    1. RTKLIB基础动态库生成 RTKLIB是全球导航卫星系统GNSS(global navigation satellite system)的标准&精密定位开源程序包,由日本东京海洋大学的 ...

  6. Linux C++ Socket 高并发短连接 TIME_WAIT 挥之不去解决方法

    近期遇到一个项目 需要在Linux上建立一个Socket 进行 HTTP_GET , 需要线程高并发的 使用TCP Socket 进行Send 发送HTTP_GET请求到 指定网站 . 而且不需要re ...

  7. Linux 下 简单客户端服务器通讯模型(TCP)

    原文:Linux 下 简单客户端服务器通讯模型(TCP) 服务器端:server.c #include<stdio.h> #include<stdlib.h> #include ...

  8. 分享知识-快乐自己:Linux下安装 erlang 及 RabbitmMQ

    Linux下安装 erlang 及 RabbitmMQ: 下载地址一  下载地址二 下载地址三 安装依赖: yum install ncurses-devel 安装 erlang: 1):下载Erla ...

  9. Linux下基于LDAP统一用户认证的研究

    Linux下基于LDAP统一用户认证的研究                   本文出自 "李晨光原创技术博客" 博客,谢绝转载!

随机推荐

  1. Properties的使用

    Properties的各种相对路径,绝对路径的用法 所在包: package com.test.javaAPI.collections; import java.io.File; import jav ...

  2. Nginx阅读笔记

    Nginx最常用的服务是提供反向代理,大家熟悉的最多的是正向代理,正向代理我们平常接触的最多,例如云梯,我们通过代理服务器作为客户端这边的中介接受请求,隐藏真实的客户,向服务器获取资源.而反向代理顾名 ...

  3. 海量Web日志分析 用Hadoop提取KPI统计指标

    http://blog.fens.me/hadoop-mapreduce-log-kpi/ http://dongxicheng.org/search-engine/scribe-installati ...

  4. hibernate 缓存 4.3

    缓存在hibernate中是天生就有的,是一级缓存,当session关闭时一级缓存就失效了 一级缓存是内置的,生效范围是在同一个session中才行.二级缓存是需要配置才有 判断当前项在不在一级缓存中 ...

  5. perl学习(4) 子程序

    子程序,类比c语言中的函数,在形式上个人认为最大的区别:没有形参 1.1.定义子程序 1.2.调用 #! /usr/bin/perl sub marine { $n += 1 ; print &quo ...

  6. IT第十九天 - 继承、接口、多态、面向对象的编程思想

    IT第十九天 上午 继承 1.一般情况下,子类在继承父类时,会调用父类中的无参构造方法,即默认的构造方法:如果在父类中只写了有参的构造方法,这时如果在子类中继承时,就会出现报错,原因是子类继承父类时无 ...

  7. BZOJ 1756: Vijos1083 小白逛公园

    题目 1756: Vijos1083 小白逛公园 Time Limit: 10 Sec  Memory Limit: 64 MBSubmit: 856  Solved: 264[Submit][Sta ...

  8. hdu 4730 We Love MOE Girls

    http://acm.hdu.edu.cn/showproblem.php?pid=4730 直接用string类处理字符串. AC代码: #include<iostream> #incl ...

  9. 文本图片自适应高度小bug以及解决办法

    自定义cell的文本图片自适应高度代码,如果存在自定义的cell赋值封装,就必须将自适应高度代码写在这个方法中 点击效果: 注:- (void)layoutSubviews 方法不能同时操作,否则会出 ...

  10. android自定义控件 onMeasure() 测量尺寸

    上次讲的自定义控件刷新点屏幕的任意地方都会刷新,而且在xml里自定义控件下面放一个textview的话,这个TextView是显示不出来的,不只这个,以前的几个自定义控件都是 为什么呢?今天来讲下on ...