URN Logo
UNIX Resources » Linux » China Linux Forum » C/C++编程版 » 36 » 总结的频繁修改防火墙规则提高效率的办法
announcement 声明: 本页内容为中国Linux论坛的内容镜像,文章的版权以及其他所有的相关权利属于中国Linux论坛和相应文章的作者,如果转载,请注明文章来源及相关版权信息。
Resources
China Linux Forum(finished)
Linux Forum(finished)
FreeBSD China(finished)
linuxforum.net
  业界新闻与评论
  自由软件杂谈
  IT 人生
  Linux软件快递
  翻译作坊
  Linux图书与评论
  GNU Emacs/XEmacs
  Linux 中文环境和中文化
  Linux桌面与办公软件
  Linux 多媒体与娱乐版
  自由之窗Mozilla
  笔记本电脑上的Linux
  Gentoo
  Debian 一族
  网络管理技术
  Linux 安装与入门
  WEB服务器和FTP服务器
  域名服务器和邮件服务器
  Linux防火墙和代理服务器应用
  文件及打印服务器
  技术培训与认证
  Linux内核技术
  Linux 嵌入技术
  Linux设备驱动程序
  Linux 集群技术
  LINUX平台数据库
  系统和网络安全
  CPU 与 编译器
  系统计算研究所专栏
  Linux下的GUI软件开发
  C/C++编程版
  PHP 技 术
  Java&jsp技术
  Shell编程技术
  Perl 编 程
  Python 编 程
  XML/Web Service 技术
  永远的Unix
  FreeBSD世界
   
总结的频繁修改防火墙规则提高效率的办法
Author: cbchen    Posted: 2005-03-27 11:33    Length: 2,759 byte(s)
[Original] [Print] [Top]
如果应用程序需要频繁的修改防火墙规则,那么可以用如下的办法来提高性能。
比如需要执行iptables -s 10.10.1.1 -j DROP等诸如此类。
对比一下前后效率(以循环5次来比较):
1 直接执行system("iptables ...."); 用时46914us
2 不用system,而用iptables中的函数do_command; 用时622us
性能有差不多70倍的提升
代码如下:

#include <stdio.h>
#include <stdlib.h>
#include <errno.h>
#include <string.h>
#include <iptables.h>
#include<sys/time.h>
#include<sys/ioctl.h>
#include <unistd.h>
unsigned long span;
struct timeval time1,time2;

int
main(int argc, char *argv[])
{
int ret;
char *table = "filter";
iptc_handle_t handle = NULL;

program_name = "iptables";
program_version = IPTABLES_VERSION;

#ifdef NO_SHARED_LIBS
init_extensions();
#endif
//FILE *file;
//int oldfd = dup( STDOUT_FILENO );
int i;
//freopen( "/dev/null", "w", stdout );
gettimeofday(&time1,NULL);
argv[0] = "myipt";
argv[1] = "-A";
argv[2] = "INPUT";
argv[3] = "-s";
argv[4] = "10.10.1.1";
argv[5] = "-j";
argv[6] = "DROP";

argc = 7;
for(i=0;i<5;i++)
{
ret = do_command(argc,argv, &table, &handle);
if (ret)
ret = iptc_commit(&handle);

if (!ret)
fprintf(stderr, "iptables: %s ",
iptc_strerror(errno));
}
gettimeofday(&time2,NULL);
span=(time2.tv_sec-time1.tv_sec)*1000000+(time2.tv_usec-time1.tv_usec);
//file = fdopen( oldfd, "w" );
//stdout = file;
printf("times cost: %lu us ",span);
gettimeofday(&time1,NULL);
char exec_str[128];

for(i=0;i<5;i++)
{
strcpy(exec_str,"iptables -A INPUT -s 10.10.1.1 -j DROP");
system(exec_str);
}
gettimeofday(&time2,NULL);
span=(time2.tv_sec-time1.tv_sec)*1000000+(time2.tv_usec-time1.tv_usec);
printf("times cost: %lu us ",span);
exit(!ret);
}


[Original] [Print] [Top]
« Previous thread
关于内核较验的问题,请诸位大侠看看,谢谢!!
C/C++编程版
36
Next thread »
fork后的父子进程先后执行问题
     

Copyright © 2007 UNIX Resources Network, All Rights Reserved.      About URN | Privacy & Legal | Help | Contact us
备案序号: 京ICP备05006143    webmaster: webmaster@unixresources.net
This page created on 2008-07-17 03:53:05, cost 0.034557819366455 ms.