在Debian上配置SFTP帶寬限制可以通過使用tc
(Traffic Control)工具和cgroups
(Control Groups)來實現。以下是一個基本的步驟指南:
tc
工具安裝必要的軟件包:
sudo apt-get update
sudo apt-get install iproute2
創建一個隊列規則: 假設你想限制SFTP的帶寬為1Mbps,可以使用以下命令:
sudo tc qdisc add dev eth0 root handle 1: htb default 30
sudo tc class add dev eth0 parent 1: classid 1:1 htb rate 1mbit
sudo tc class add dev eth0 parent 1:1 classid 1:10 htb rate 1mbit ceil 1mbit
創建一個過濾器來匹配SFTP流量: 假設SFTP使用默認的SSH端口22:
sudo tc filter add dev eth0 protocol ip parent 1:0 prio 1 u32 match ip dport 22 0xffff flowid 1:10
cgroups
工具安裝必要的軟件包:
sudo apt-get update
sudo apt-get install cgroup-tools
創建一個新的cgroup:
sudo cgcreate -g net_cls:/sftp_limit
設置cgroup的網絡類:
編輯 /etc/cgconfig.conf
文件,添加以下內容:
group sftp_limit {
net_cls {
net_cls.classid = 0x100001;
}
}
重啟cgroup服務:
sudo systemctl restart cgconfig
sudo systemctl restart cgred
將SFTP進程分配到cgroup: 假設SFTP進程的PID是1234:
echo 1234 | sudo tee /sys/fs/cgroup/net_cls/sftp_limit/net_cls.classid
配置tc來限制帶寬:
使用與上面相同的tc
命令來限制帶寬。
eth0
)調整命令中的設備名稱。通過以上步驟,你應該能夠在Debian上成功配置SFTP的帶寬限制。