linux 限速 目前公认最流畅的linux

linux如何限制每个进程的网速

1、用 iptables的 owner模块,给--pid-owner加上 MARK,然后 tc里针对这个 MARK做限速现在的服务器上,基本已经普及了 SMP,更进一步的,内核已经在自动发现支持 SMP的时候,在 iptables里把 owner模块的 pid/cmd/sid三个 match都去掉了!现在的 owner里只有 uid/gid两个。所以这条路,在生产环境上基本行不通。所以推荐下面的两种方法:

2、使用 pipeviewer和 trickle这两个工具。trickle是在BSD上诞生的项目,这个工具使用ELF的 preloader机制,在命令执行的时候替换掉标准库中的 socket recv()()和 send()部分,达到限速的效

3、cgroup,它有 net_cls控制器。不过和其他控制器不太一样的是它不直接控制网络读写,只是给网络包打上一个标记,然后把专业的事情交给专业的 TC去做。嗯,思路和原先的 iptable是很类似的。

如何用linux做路由器限速

linux的开源和免费使得越来越多的厂家用它来做防火墙和路由器,如海蜘蛛,飞鱼星等,其实我们也可以用linux来打造一台高性能的路由器。下面就以redhat为例(其他版本大同小异)教大家做一台能限速的路由器,如何在linux下进行路由器限速就不再困难了。

安装linux如果是新手请安装时安装图形桌面。Linux路由器限速的'设置步骤如下:

路由器限速第一步:建立adsl连接,在系统设置——网络设置处有。在图形界面下很容易搞定。

路由器限速第二步:打开IP转发和伪装(也就是路由与NAT)

1、作为根用户打开/etc/sysconfig/network文件,在文件增加以下一行:

GATEWAYDEV=PPP0这句话的作用是设定默认路由,有时没有也可

2、打开IP转发功能:打开/etc/sysctl.conf文件,修改net.ipv4.ip_forward=0一行,改0改为1

3、重启系统

路由器限速第三步:设置iptables防火墙,决定那些IP能通过linux主机上网。

下面以允许192.168.0.0网段为例:

1、打开终端在#字提示符下输入以下命令:

iptables-tnat-IPOSTROUTING-oppp0-jMASQUERADE#这句意思是伪装从pppo出去的IPiptables-AFORWARD-s192.168.0.0/24-jACCEPT#这句意思是转发来自192。168。0。0网段的通讯iptables-AFORWARD-d192.168.0.0/24-jACCEPT#这句意思是转发到达192。168。0。0网段的通讯iptables-AFORWARD-s!192.168.0.0/24-jDROP#这句意思是拒绝转发非192.168.0.0网段的通讯。

2、保存以上防火墙规则,以保证重启后还有效,输入命令:iptables-save>/etc/sysconfig/iptables,这样,你的linux路由器应该就能跑起来了。

linux做路由器限速的实现:在linux中有专门限速的软件--tc,但TC的语法新手难以掌握,我们可以在防火墙上通过限定某个IP或某段IP在一秒内通过的数据包的数量来限速。

下面以限制192.168.0.2这个IP的网速为例说说,在桌面环境下打开/etc/syscofngi/iptables有没有发现,刚才的设定全记录在这个文件里,现在做的就在这个文件里添加规则就得了。

1、先要找到filter

2、在filter下面一行增加以下两行:

-AFORWARD-mlimit-d192.168.0.2--limit30/sec-jACCEPT#这句意思是限定每秒只转发30个到达192。168。0。2的数据包(约每秒45KB一个数据包是1.5KB)

-AFORWARD-d192.168.0.2-jDROP#这句作用是超过限制的到达192.168.0.2的数据包不通过)

3、路由器限速经过重启系统就实现了。

Linux下实现带宽限制的方法linux带宽限制

随着互联网应用的普及,控制网络带宽的需求也越来越大。有时候,我们可能需要控制个别协议或服务(如HTTP、FTP等)在网络中可以占用的最大带宽,以便公平地分配网络带宽。Linux操作系统下也可以给指定协议或服务实现带宽限制。

首先,安装Linux下的网络体系结构。iproute2工具集,用以实现Linux下的高级路由和流量控制。它的典型的实现形式为。

sudo apt-get install iproute2

该工具包提供了tc工具,可以在Linux下实现限速带宽,其使用方法如下:

(1)找到网卡的名字:

sudo ethtool–i eth0

(2)限制某个 IP的某个端口号的带宽,下面设置最大出站/入站带宽上限分别为 10Kbyte/s和 20Kbyte/s:

sudo tc qdisc add dev eth0 root handle 1:0 htb sudo tc filter add dev eth0 parent 1:0 protocol ip prio 1 u32 match ip dst 192.168.0.2/32 match ip dport 80 0xffff flowid 1:1 sudo tc class add dev eth0 parent 1:0 classi1:1 htb rate 10kbyte/s sudo tc class add dev eth0 parent 1:0 classi1:2 htb rate 20kbyte/s sudo tc qdisc add dev eth0 parent 1:1 handle 10: sfq perturb 10 sudo tc filter add dev eth0 protocol ip prio 2 u32 match ip src 192.168.0.2/32 flowid 1:2

最后,使用tc命令查看配置情况:

sudo tc-s class show dev eth0

上述方法可以一定程度上限制Linux下某网络流量的最大网络带宽。但是需要考虑到,在实践应用也还存在许多不可预料的情况,我们也要结合实际情况来做出决定和调整。

阅读剩余
THE END