注册 登录  
 加关注
   显示下一条  |  关闭
温馨提示!由于新浪微博认证机制调整,您的新浪微博帐号绑定已过期,请重新绑定!立即重新绑定新浪微博》  |  关闭

逍遥子 曰:

得失失得 何必患得患失 舍得得舍 不妨不舍不得

 
 
 

日志

 
 

[原] ip别名及其在tcp压力测试时候的作用  

2015-07-31 17:24:15|  分类: 计算机网络 |  标签: |举报 |字号 订阅

  下载LOFTER 我的照片书  |


通常在对服务器程序进行压力测试时,需要客户端模拟大量的tcp连接,以对服务器端产生强大的压力,但是由于linux端口号的限制,每个客户端ip顶多能发起6.4w左右的连接,
详情可参考:
http://blog.csdn.net/houjixin/article/details/18737881
或者:
http://houjixin.blog.163.com/blog/static/3562841020140244532368/
为使进行压力测试的客户端能突破这个限制,例如可以让一个压测客户端模拟50万虚拟用户连接,则需要为当前主机增加ip别名,即对一个网卡配置多个ip;


以centos 7为例,只需修改文件/etc/sysconfig/network-scripts/ifcfg-p2p1,这里的文件名ifcfg-p2p1可能不一样,我本机中该文件的内容为:

TYPE="Ethernet"
BOOTPROTO=static
DEFROUTE="yes"
PEERDNS="yes"
IPV4_FAILURE_FATAL="no"
IPV6INIT="yes"
IPV6_AUTOCONF="yes"
IPV6_DEFROUTE="yes"
IPV6_FAILURE_FATAL="no"
NAME="p2p1"
UUID="5481414f-fa75-45be-97c1-ac8beb45ac82"
DEVICE="p2p1"
ONBOOT="yes"
IPADDR="192.168.1.205"
NETMASK="255.255.255.0"
HWADDR="b0:83:fe:b2:a4:7d"
PREFIX="24"
NM_CONTROLLED="no"
GATEWAY="192.168.1.3"
DNS1="192.168.1.11"
IPV6_PEERDNS="yes"
IPV6_PEERROUTES="yes"
IPV6_PRIVACY="no"


可以看到它就一个ip地址:192.168.1.205,它对应的网卡的mac地址为:b0:83:fe:b2:a4:7d,如果要添加再为此网卡添加新的ip,例如再添加两个IP:192.168.1.251和192.168.1.252,
则直接修改文件:/etc/sysconfig/network-scripts/ifcfg-p2p1,将新的ip添加进去,添加之后的内容为:

TYPE="Ethernet"
BOOTPROTO=static
DEFROUTE="yes"
PEERDNS="yes"
IPV4_FAILURE_FATAL="no"
IPV6INIT="yes"
IPV6_AUTOCONF="yes"
IPV6_DEFROUTE="yes"
IPV6_FAILURE_FATAL="no"
NAME="p2p1"
UUID="5481414f-fa75-45be-97c1-ac8beb45ac82"
DEVICE="p2p1"
ONBOOT="yes"
IPADDR0="192.168.1.205"
IPADDR1="192.168.1.251"
IPADDR2="192.168.1.252"
NETMASK="255.255.255.0"
HWADDR="b0:83:fe:b2:a4:7d"
PREFIX="24"
NM_CONTROLLED="no"
GATEWAY="192.168.1.3"
DNS1="192.168.1.11"
IPV6_PEERDNS="yes"
IPV6_PEERROUTES="yes"
IPV6_PRIVACY="no"


添加完成之后,执行网络重启命令(centos7可用,之前版本命令不一样):service network restart

此时,在其他机子上直接ping新添加的ip地址即可ping通。

在完成上述配置多ip操作之后,开发压测客户端时还需注意为在创建socket之后要绑定不同的ip,例如原来写客户端程序时的步骤基本为:

client_addr.sin_family = AF_INET;
client_addr.sin_addr.s_addr = htons(INADDR_ANY);
client_addr.sin_port = htons(0);
client_socket = socket(AF_INET, SOCK_STREAM, 0);
...
connect(client_socket, (struct sockaddr*)&server_addr, server_addr_length);


注意这里的client_addr.sin_addr.s_addr = htons(INADDR_ANY),这种方式就没有指定本地ip,此时系统会自动为当前的socket选择默认的ip。如果我们想使用刚才配置的多个ip,则需要在这里绑定自己的ip,其代码如下所示:

struct sockaddr_in client_addr;
bzero(&client_addr, sizeof(client_addr));
client_addr.sin_family = AF_INET;
client_addr.sin_addr.s_addr = inet_addr(iplist[i]);
client_addr.sin_port = htons(0);
int client_socket = socket(AF_INET, SOCK_STREAM, 0);
bind(client_socket, (struct sockaddr*)&client_addr, sizeof(client_addr))

connect(client_socket, (struct sockaddr*)&server_addr, server_addr_length);


这里client_addr.sin_addr.s_addr = inet_addr(iplist[i])中iplist[i]存放的就是本机的所有地址列表;

如此以来,在压测过程中,一个客户端的ip可以发出6.4万左右各连接,如果客户端所在的主机上配置了10个ip,那么它就可以压出64万个连接,前提是这台机子的性能够好,系统参数也要调试好。


  评论这张
 
阅读(291)| 评论(0)
推荐 转载

历史上的今天

在LOFTER的更多文章

评论

<#--最新日志,群博日志--> <#--推荐日志--> <#--引用记录--> <#--博主推荐--> <#--随机阅读--> <#--首页推荐--> <#--历史上的今天--> <#--被推荐日志--> <#--上一篇,下一篇--> <#-- 热度 --> <#-- 网易新闻广告 --> <#--右边模块结构--> <#--评论模块结构--> <#--引用模块结构--> <#--博主发起的投票-->
 
 
 
 
 
 
 
 
 
 
 
 
 
 

页脚

网易公司版权所有 ©1997-2017