飞牛OS给容器魔方上行宽带限速
下面我将详细讲解(容器网络命名空间限速)的持久化配置步骤,确保在飞牛OS重启后自动生效。请严格按照顺序执行以下操作:
️ 完整持久化配置教程(带详细解释)
步骤1:确认容器魔方名称
# 查看运行的容器列表
docker ps
# 从输出中找到容器魔方的名称(通常在NAMES列)
# 示例输出:
# CONTAINER ID IMAGE ... NAMES
# a1b2c3d4e5f6 wxedge-image ... wxedge
确认容器名称(如上例的 wxedge),后续步骤将用到这个名称。容器魔方的名字默认wxedge
步骤2:创建限速脚本
# 创建脚本目录
sudo mkdir -p /opt/scripts
# 创建脚本文件
sudo nano /opt/scripts/limit_container_traffic.sh
在编辑器中粘贴以下内容(记得替换 YOUR_CONTAINER_NAME 为你的实际容器名称):容器魔方的名字为wxedge
eth0是网卡名称,可以在飞牛OS中的网络设置中查看自己的网卡名称,替换自己的使用网卡即可
#!/bin/bash
# 容器名称(必须修改)
CONTAINER_NAME="wxedge"
# 等待容器完全启动(重要!)
echo "等待容器启动..."
while ! docker inspect --format='{{.State.Running}}' $CONTAINER_NAME | grep -q "true"; do
sleep 3
done
# 额外等待5秒确保网络初始化
sleep 5
# 获取容器PID
PID=$(docker inspect -f '{{.State.Pid}}' "$CONTAINER_NAME")
if [ -z "$PID" ]; then
echo "错误:无法获取容器 $CONTAINER_NAME 的PID"
exit 1
fi
# 应用上行带宽限制(20Mbps) 注意,如下是在飞牛OS中网络设置中看到的网卡名称,此处为eth0
echo "为容器 $CONTAINER_NAME (PID:$PID) 设置上行带宽限制..."
nsenter -t $PID -n tc qdisc replace dev eth0 root tbf \
rate 20mbit \
burst 320kbit \
latency 400ms
# 检查结果
if [ $? -eq 0 ]; then
echo "成功设置上行带宽限制:20Mbps"
else
echo "限速设置失败!"
exit 2
fi
按 Ctrl+O 保存文件,然后 Ctrl+X 退出编辑器。
给脚本添加可执行权限:
sudo chmod +x /opt/scripts/limit_container_traffic.sh
步骤3:创建Systemd服务单元
# 创建服务配置文件
sudo nano /etc/systemd/system/container-bandwidth.service
粘贴以下内容:
[Unit]
Description=Container Bandwidth Limiter for Magic Container
After=docker.service
Requires=docker.service
[Service]
Type=simple
ExecStart=/opt/scripts/limit_container_traffic.sh
Restart=on-failure
RestartSec=30
StartLimitInterval=0
[Install]
WantedBy=multi-user.target
保存并退出(Ctrl+O → Enter → Ctrl+X)
步骤4:启用并启动服务
# 重载systemd配置
sudo systemctl daemon-reload
# 启用服务(开机自启)
sudo systemctl enable container-bandwidth.service
# 立即启动服务
sudo systemctl start container-bandwidth.service
步骤5:验证服务状态
# 检查服务状态
sudo systemctl status container-bandwidth.service
# 预期看到 "active (running)" 状态
# 检查日志(查看限速是否成功)
journalctl -u container-bandwidth.service -n 50 --no-pager
日志中应看到类似:
等待容器启动...
为容器 container_magic (PID:12345) 设置上行带宽限制...
成功设置上行带宽限制:20Mbps
步骤6:测试限速效果,理论上如果容器魔方正在上传,不需要测试,直接看效果,立竿见影。
飞牛OS系统中的UI界面有网速,看那个即可。比如之前是7Mb/s,限制完上传后变为了2.4Mb/s,速度根据自己需求调整
- 在容器内安装测试工具:
# 进入容器魔方Shell
docker exec -it YOUR_CONTAINER_NAME /bin/bash
# 在容器内安装speedtest-cli
apt-get update && apt-get install -y speedtest-cli # 对于Debian系
# 或(如果使用Alpine):
# apk add curl
- 运行上行速度测试:
# 方法1: 使用speedtest-cli
speedtest --simple
# 方法2: 使用curl测试上传
curl -T /dev/zero http://speedtest.ftp.otenet.gr/files/test10Mb.db
# 观察输出速度(应稳定在~2.5MB/s左右,因为20Mbps = 2.5MB/s)
步骤7:重启验证持久化
# 重启飞牛OS
sudo reboot
# 重启后检查
sudo systemctl status container-bandwidth.service
docker exec YOUR_CONTAINER_NAME tc qdisc show dev eth0
应看到类似:
qdisc tbf 800d: root refcnt 2 rate 20Mbit burst 32Kb lat 400.0ms
排错指南
问题现象 | 解决方案 |
---|---|
"无法获取容器PID" | 检查容器名称是否正确、容器是否正常运行 |
"No such file or directory" | 确认已创建 /opt/scripts/limit_container_traffic.sh 并有执行权限 |
"RTNETLINK answers: File exists" | 添加 replace 关键字:tc qdisc replace... |
网卡名称不是eth0 | 修改脚本中的 dev eth0 → 使用 docker exec 容器名 ip addr 查看正确网卡名 |
限速不精确 | 调整 burst 值:burst = rate/8 * 1.5 |
服务启动过早 | 增加脚本中的 sleep 时间 |
更新限速配置
如需修改带宽限制(例如改为30Mbps):
编辑脚本文件:
sudo nano /opt/scripts/limit_container_traffic.sh
修改 rate 20mbit → rate 30mbit
修改 burst 320kbit → burst 480kbit (30÷8×1.5=5.625,约480kbit)
重启服务:
sudo systemctl restart container-bandwidth.service
此方案通过Systemd在宿主机层面自动管理,避免修改容器内部,确保每次重启飞牛OS后自动生效且不影响容器魔方的正常功能。
飞牛OS给容器魔方上行宽带限速的更多相关文章
- 在http编程的门口----飞牛网自动下单,查单
刚进这个公司,以前没接触过http编程,所以这两天做了个小例子来熟悉http编程,有点晕..... 不过还是做出来了,虽然有点粗糙,总结一下这个小软件: 主要使用QNetworkAccessManag ...
- 【容器魔方解读】AWS Re:Invent 2018大会
每年云计算领域技术与商业风向标之一的AWS Re:Invent大会上周在美国拉斯维加斯召开,如往届一样,AWS密集发布了上百项的新产品或新技术.随着国内近两年云计算尤其是公有云的普及度越来越高,国内各 ...
- 异数OS-织梦师-异数OS虚拟容器交换机(七) 走进4Tbps网络应用时代,加速5G应用真正落地
. 异数OS-织梦师-异数OS虚拟容器交换机(七) 走进4Tbps网络应用时代,加速5G应用真正落地 本文来自异数OS社区 github: https://github.com/yds086/Here ...
- Openstack 虚拟机宽带限速
修改Neutron配置文件,使其支持Qos 修改Neutron.conf service_plugins = neutron.services.qos.qos_plugin.QoSPlugin 修改p ...
- 深入解析DC/OS 1.8 – 高可靠的微服务及大数据管理平台
深入解析DC/OS 1.8 – 高可靠的微服务及大数据管理平台 大家好,欢迎大家参加这次DC/OS的技术分享. 先做个自我介绍,刘超,Linker Networks首席架构师,Open DC/OS社区 ...
- paper 61:计算机视觉领域的一些牛人博客,超有实力的研究机构等的网站链接
转载出处:blog.csdn.net/carson2005 以下链接是本人整理的关于计算机视觉(ComputerVision, CV)相关领域的网站链接,其中有CV牛人的主页,CV研究小组的主页,CV ...
- docker容器安全
title: docker容器安全 tags: Docker,容器,安全策略 grammar_cjkRuby: true --- Docker容器的安全性 1.安全策略-Cgroup 1.限制Cpu ...
- Docker Kubernetes 容器重启策略
Docker Kubernetes 容器重启策略 当容器被创建时,容器会根据重启策略来进行容器重启. 支持三种策略: Always:当容器终止退出后,总是重启容器,默认策略. OnFailure:当容 ...
- Docker学习笔记——制作容器与容器概念
Docker能做些什么? 1.docker能够解决虚拟机能够解决的问题 2.隔离应用依赖 3.创建应用镜像并复制 4.创建容易分发的即启即用的应用 5.docker的想法是创建软件程序可移植的轻量容器 ...
- 关于国内外CV领域牛人的博客链接 .
此文为转载文章,尊重知识产权http://blog.csdn.net/carson2005/article/details/6601109此为原文链接,感谢作者! 以下链接是关于计算机视觉(Compu ...
随机推荐
- 记线上+线下培训思想i技巧感悟
刚刚结束一场线下+线上培训 梳理一下,有几个问题: 1.虽然课件自己过了几遍,同时备注里写了一些提示 ,但是真正讲课的时候基本是没有过程特意去扫备注 注意备注应清晰,写核心关键字 2.分屏过程 需要在 ...
- wordpress无法显示gitee图床的图片
wordpress无法显示gitee图床的图片 Question:如题 Solution:是防盗链的问题,gitee官网给出了防盗链的方法,而github貌似没有. Reference:你已经是个成熟 ...
- 浅说树形dp
@ 目录 前言 树形dp的转移方式 树形dp的使用的场景 小结 初步感知--简单的树形dp 例题1 例题2 深入分析--树形dp的经典模型 最大独立集 最小点覆盖 最小支配集 树上直径 前言 因为树的 ...
- Peach-Printer2.0 Web 打印服务解决方案
Peach-Printer1.0在沉寂许久后迎来了一个使用客户,非常感谢客户的支持和理解. 通过客户的使用反馈本人尝试对1.0版本进行完善修改,但始终打印效果未能实现预期.思索许久后决心更改打印控件的 ...
- kubernetes failed to create kubelet: misconfiguration: kubelet cgroup driver: "cgroupfs" is different from docker cgroup driver: "systemd"
错误原因 kubernetes 的文件驱动与 docker 不一致,导致镜像无法启动. docker info 可以看到驱动方式 Cgroup Driver: systemd. 解决方案 统一资源管理 ...
- 使用命令行控制wireshark对抓包文件进行针对性处理的命令总结
近日,工作中有开发对抓包文件进行针对性过滤的小程序的需求,兜兜转转踩了很多坑后还是绕回了wireshark. 作为最出名的开源软件之一,wireshark也具有使用命令行进行操作的功能,这就是我们今天 ...
- Delphi 动态生成进度条窗体
在implementation加入下面 uses Gauges; var Gauge1: TGauge; 加入Timer1控件,设为false procedure TForm1.Button1Clic ...
- 卧槽!C 语言宏定义原来可以玩出这些花样?高手必看!
大家好啊!我是小康. 今天我们来聊一个听起来枯燥但实际上暗藏玄机的话题 -- C 语言的宏定义. 啥?宏定义?那不就是个简单的替换工具吗? 兄dei,如果你也是这么想的,那可就大错特错了!宏定义在 C ...
- study Rust-4【所有权】这个太重要了!
由于Rust内存垃圾自动回收,那就得搞清楚这个所有权玩意.这个太重要了.因为关系到贯穿于你以后的程序编写. 几个概念: 一.移动 1.咱们一般语言,自己申请内存,自己管理和释放.就是new和free. ...
- 在Linux终端管理你的密码!
大家好,我是良许. 现在是互联网时代,我们每天都要跟各种 APP .网站打交道,而这些东西基本上都需要注册才可以使用. 但是账号一多,我们自己都经常记不清对应的密码了.有些小伙伴就一把梭,所有的账号密 ...