当前位置: 首页 > article >正文

从零到一:手把手教你用Docker在Ubuntu 22.04上部署Open5GS 5G核心网

从零到一手把手教你用Docker在Ubuntu 22.04上部署Open5GS 5G核心网1. 环境准备与基础配置在开始部署Open5GS之前我们需要确保基础环境满足要求。Ubuntu 22.04 LTS作为长期支持版本提供了稳定的运行基础。以下是详细的准备工作硬件要求至少4核CPU推荐8核以上16GB内存32GB更佳100GB可用存储空间支持虚拟化的x86_64架构系统配置# 更新系统软件包 sudo apt update sudo apt upgrade -y # 安装基础工具 sudo apt install -y git curl wget net-tools # 检查内核版本需5.15或更高 uname -r提示如果使用云服务器请确保安全组开放以下端口范围3000-4000WebUI、2123GTP-U、38412S1AP、2152NGAP网络配置建议为Docker创建独立网桥避免与主机网络冲突配置静态IP或确保DHCP租约稳定禁用UFW防火墙或精确配置规则2. Docker环境搭建与优化现代容器化部署离不开Docker的支撑以下是针对5G核心网场景的特别配置安装Docker CE# 移除旧版本 sudo apt remove docker docker-engine docker.io containerd runc # 设置仓库 sudo apt install -y ca-certificates curl gnupg lsb-release sudo mkdir -p /etc/apt/keyrings curl -fsSL https://download.docker.com/linux/ubuntu/gpg | sudo gpg --dearmor -o /etc/apt/keyrings/docker.gpg echo deb [arch$(dpkg --print-architecture) signed-by/etc/apt/keyrings/docker.gpg] https://download.docker.com/linux/ubuntu $(lsb_release -cs) stable | sudo tee /etc/apt/sources.list.d/docker.list /dev/null # 安装引擎 sudo apt update sudo apt install -y docker-ce docker-ce-cli containerd.io docker-compose-plugin性能调优参数# 创建或修改daemon.json sudo tee /etc/docker/daemon.json EOF { default-ulimits: { nofile: { Name: nofile, Hard: 1048576, Soft: 1048576 } }, log-driver: json-file, log-opts: { max-size: 100m, max-file: 3 } } EOF # 应用配置并重启 sudo systemctl restart docker验证安装docker version docker run hello-world3. Open5GS容器化部署实战Open5GS官方提供了Docker支持但生产环境需要额外配置克隆仓库与准备配置git clone --recursive https://github.com/open5gs/open5gs cd open5gs/docker # 修改基础配置 cp .env.sample .env nano .env # 调整PLMN、IP等参数核心组件对比表组件功能容器名称暴露端口AMF接入和移动性管理open5gs-amf38412, 7777SMF会话管理open5gs-smf8805, 7777UPF用户面功能open5gs-upf2152, 8805NRF网络功能仓库open5gs-nrf7777启动核心网服务# 完整部署开发模式 docker-compose up -d # 仅启动SA核心网 docker-compose -f sa.yaml up -d验证服务状态# 查看容器日志 docker logs -f open5gs-amf # 检查网络功能注册 curl http://localhost:7777/nnrf-nfm/v1/nf-instances4. 网络配置与连通性测试正确的网络配置是5G核心网正常工作的关键Docker网络拓扑# 创建专属网络 docker network create --subnet10.0.100.0/24 open5gs # 查看网络详情 docker network inspect open5gs关键配置示例AMF# configs/amf.yaml 关键片段 amf: sbi: - addr: 10.0.100.10 port: 7777 ngap: - addr: 10.0.100.10 guami: - plmn_id: mcc: 901 mnc: 70 amf_id: region: 2 set: 1连通性测试方法Ping测试docker exec -it open5gs-amf ping 10.0.100.20 # 测试SMF连通性API测试# 使用curl测试NRF接口 curl -X GET http://10.0.100.30:7777/nnrf-nfm/v1/nf-instances -H accept: application/json抓包分析# 在UPF容器中抓取GTP-U流量 docker exec -it open5gs-upf tcpdump -i any -nn port 2152 -w gtpu.pcap5. 常见问题排查与优化部署过程中可能遇到的典型问题及解决方案端口冲突处理# 查找占用端口 sudo netstat -tulnp | grep 7777 # 解决方案 # 1. 修改docker-compose端口映射 # 2. 调整configs/*.yaml中的端口配置性能优化建议为UPF配置大页内存sudo sysctl vm.nr_hugepages1024启用CPU亲和性# 在docker-compose中为关键NF添加 cpuset: 0-3日志分析技巧# 实时监控AMF日志 docker logs -f open5gs-amf | grep -E ERROR|WARN # 使用jq解析SBI消息 docker exec open5gs-nrf cat /var/log/open5gs/nrf.log | jq .message配置热更新方法# 修改配置后重启单个NF docker-compose restart open5gs-amf # 验证配置生效 docker exec open5gs-amf ps aux | grep yaml6. 进阶部署与扩展满足基本部署后可进一步优化架构高可用方案# docker-compose-ha.yaml片段 services: amf: image: open5gs-amf deploy: replicas: 3 update_config: parallelism: 1 delay: 10s healthcheck: test: [CMD, curl, -f, http://localhost:7777/status]监控系统集成# 添加Prometheus监控 docker-compose -f docker-compose.yml -f monitoring.yml up -d生产环境建议使用单独的物理网卡处理用户面流量为控制面和用户面配置独立Docker网络启用TLS加密SBI接口通信定期备份关键配置和数据库实际部署中遇到过UPF性能瓶颈问题通过将GTP-U流量卸载到专用网卡并启用DPDK加速吞吐量从5Gbps提升到40Gbps。关键配置如下# UPF启动参数优化 docker run --privileged --ulimit memlock-1 -v /dev/hugepages:/dev/hugepages open5gs-upf

相关文章:

从零到一:手把手教你用Docker在Ubuntu 22.04上部署Open5GS 5G核心网

从零到一:手把手教你用Docker在Ubuntu 22.04上部署Open5GS 5G核心网 1. 环境准备与基础配置 在开始部署Open5GS之前,我们需要确保基础环境满足要求。Ubuntu 22.04 LTS作为长期支持版本,提供了稳定的运行基础。以下是详细的准备工作&#xff1…...

远程手术技术解析:5G与AI如何重塑医疗未来

1. 医疗远程手术的现状与技术挑战 远程手术已经从科幻概念转变为医疗领域的迫切需求。根据世界卫生组织预测,到2030年全球外科医生缺口将达到450万,而偏远地区医疗机构获取专家资源的难度更是雪上加霜。传统解决方案如患者转运不仅成本高昂,…...

多智能体系统架构解析:从模块化设计到Python实践

1. 项目概述与核心价值 最近在开源社区里,一个名为 Mohammadibrahim55/agents 的项目引起了我的注意。乍一看,这只是一个以“agents”命名的仓库,但当你深入进去,会发现它远不止一个简单的代码集合。它实际上是一个围绕“智能体…...

RISC-V向量扩展(V Extension)在AI推理场景适配翻车实录:为何你的ResNet50推理速度反降40%?

更多请点击: https://intelliparadigm.com 第一章:RISC-V向量扩展(V Extension)在AI推理场景适配翻车实录:为何你的ResNet50推理速度反降40%? 当团队将 ResNet50 从 x86 AVX-512 迁移至 RISC-V V Extensio…...

多模态文档检索系统:从原理到工程实践

1. 项目背景与核心价值文档检索系统正在经历从传统关键词匹配到语义理解的范式转变。我在过去三年参与的企业知识库升级项目中,深刻体会到单纯依赖文本嵌入的局限性——当用户用"那个蓝色封面的操作手册"或"去年会上展示的柱状图报告"进行搜索时…...

12.人工智能实战:RAG 检索命中了但回答仍然错误?上下文压缩、引用约束与反幻觉 Prompt 的工程实践

人工智能实战:RAG 检索命中了但回答仍然错误?上下文压缩、引用约束与反幻觉 Prompt 的工程实践 一、问题场景:资料明明找到了,模型还是胡说 上一篇我们解决了 RAG 系统里最常见的问题: 召回不准通过: 结…...

别再乱用uni.navigateTo了!uni-app五种路由跳转API的保姆级选择指南

别再乱用uni.navigateTo了!uni-app五种路由跳转API的保姆级选择指南 在uni-app开发中,路由跳转是构建应用导航的基础能力,但很多开发者往往只停留在"能用"层面,对五种核心API的区别和适用场景缺乏深度理解。你是否遇到过…...

Arm Fast Models硬件追踪组件在嵌入式调试中的应用

1. Arm Fast Models追踪组件概述在嵌入式系统开发领域,硬件行为追踪是调试和验证的关键手段。Arm Fast Models提供的trace组件系统能够实时捕获硬件模块的寄存器访问、状态转换和中断信号等关键事件。这套系统特别适用于以下场景:驱动开发阶段的寄存器操…...

11.人工智能实战:RAG 问答总是“答非所问”?从召回失败到重排优化的完整工程排查与解决方案

人工智能实战:RAG 问答总是“答非所问”?从召回失败到重排优化的完整工程排查与解决方案一、问题场景:模型不傻,但它拿到的上下文是错的 在做企业知识库问答系统时,很多人第一版架构通常是这样: 用户问题↓…...

用贪心算法搞定多机调度:一个Python实现带你理解最长处理时间优先策略

用贪心算法实现高效多机调度:Python实战与策略优化 在分布式计算和任务调度领域,如何合理分配有限的计算资源以最小化总完成时间是一个经典难题。想象一下这样的场景:你手头有数十个数据处理任务,每项任务耗时不同,而可…...

猫抓Cat-Catch资源嗅探工具终极实战指南:3步轻松捕获网页多媒体资源

猫抓Cat-Catch资源嗅探工具终极实战指南:3步轻松捕获网页多媒体资源 【免费下载链接】cat-catch 猫抓 浏览器资源嗅探扩展 / cat-catch Browser Resource Sniffing Extension 项目地址: https://gitcode.com/GitHub_Trending/ca/cat-catch 你是否经常遇到这样…...

核心组件大换血:Backbone与Neck魔改篇:YOLO26缝合FasterNet主干:基于PConv(部分卷积)的延迟与算力双优化

一、为什么你的“轻量级”YOLO跑不快?——问题的根源 很多做目标检测落地的开发者都有这样的困惑:用了各种“轻量级”骨干网络替换YOLO原生Backbone,FLOPs(浮点运算次数)确实降了,但实际跑起来延迟还是高、吞吐上不去,尤其在边缘设备和CPU上更加明显。这就好比你买了一…...

核心组件大换血:Backbone与Neck魔改篇:YOLO26引入VanillaNet基础极简架构:反直觉的无跳连接也能涨点?

导语:一个违反“深度学习常识”的实验 2026年1月,Ultralytics正式发布了YOLO26——一个从底层重新设计、专为边缘和低功耗环境打造的统一检测架构。根据Ultralytics官方在2026年1月发布的介绍,YOLO26并非一次渐进式升级,而是代表了生产级视觉AI在训练、部署和扩展方式上的…...

为什么你的Windows资源管理器需要QTTabBar?3个理由告诉你答案

为什么你的Windows资源管理器需要QTTabBar?3个理由告诉你答案 【免费下载链接】qttabbar QTTabBar is a small tool that allows you to use tab multi label function in Windows Explorer. https://www.yuque.com/indiff/qttabbar 项目地址: https://gitcode.co…...

Java代码优化技巧:循环展开与内存访问优化

循环展开优化循环展开&#xff08;Loop Unrolling&#xff09;是一种减少循环控制开销的技术&#xff0c;通过减少循环次数、增加每次迭代的工作量来提升性能。适用于循环体简单且迭代次数固定的场景。示例代码&#xff1a;未展开的循环for (int i 0; i < 100; i) {sum ar…...

Docker容器化部署OpenClaw AI智能体:安全隔离与自动化实践指南

1. 项目概述&#xff1a;在Docker中安全运行OpenClaw如果你和我一样&#xff0c;对AI智能体&#xff08;Agent&#xff09;的潜力感到兴奋&#xff0c;但又对让它直接在你的开发机上“为所欲为”心存顾虑&#xff0c;那么今天分享的这个项目绝对值得你花时间了解一下。我最近在…...

第五部分-后期特效与着色器——24. 后期特效基础

24. 后期特效基础 1. 概述 后期特效&#xff08;Post-Processing&#xff09;是在场景渲染完成后&#xff0c;对渲染结果进行额外处理的技术。通过 EffectComposer 合成器&#xff0c;可以叠加多种特效&#xff0c;如泛光、景深、颜色校正等。 ┌───────────────…...

云原生部署技能包:为智能体与自动化工作流提供多云一键部署能力

1. 项目概述&#xff1a;一个云原生部署的智能“副驾驶”最近在折腾一个挺有意思的开源项目&#xff0c;叫cloud-deploy-skill。简单来说&#xff0c;它不是一个独立的部署工具&#xff0c;而是一个可以被集成到智能体&#xff08;Agent&#xff09;或自动化工作流中的“技能包…...

Bonsai:为Cursor AI瘦身的本地化规则集,节省65% Token

1. 项目概述&#xff1a;Bonsai - 为 Cursor AI 瘦身的本地化规则集如果你和我一样&#xff0c;日常重度依赖 Cursor 这类 AI 编程助手&#xff0c;那你肯定也经历过那种“话痨式”的回复。每次问一个简单的技术问题&#xff0c;它总会先来一段“当然可以&#xff01;”&#x…...

5个实战技巧:用VinXiangQi深度AI分析突破象棋对弈瓶颈

5个实战技巧&#xff1a;用VinXiangQi深度AI分析突破象棋对弈瓶颈 【免费下载链接】VinXiangQi Xiangqi syncing tool based on Yolov5 / 基于Yolov5的中国象棋连线工具 项目地址: https://gitcode.com/gh_mirrors/vi/VinXiangQi 你是否经常在象棋对弈中陷入开局被动、中…...

创业团队如何利用Taotoken管理多个项目的API Key与访问权限

创业团队如何利用Taotoken管理多个项目的API Key与访问权限 1. 多项目环境下的API Key管理挑战 小型创业团队在同时推进多个AI应用原型开发时&#xff0c;通常会面临模型API调用的管理难题。不同项目可能使用不同的模型供应商&#xff0c;团队成员权限需要差异化控制&#xf…...

PORTool:基于奖励树的LLM工具调用优化方案

1. 项目背景与核心价值在大型语言模型&#xff08;LLM&#xff09;应用落地的过程中&#xff0c;工具调用&#xff08;Tool Calling&#xff09;能力正成为区分模型实用性的关键指标。传统方法通常采用监督微调&#xff08;SFT&#xff09;或人类反馈强化学习&#xff08;RLHF&…...

Stable Diffusion风格优化器:LoRA与参数调优实战指南

1. 项目概述与核心价值最近在折腾一个挺有意思的开源项目&#xff0c;叫vibeforge1111/vibeship-optimizer。乍一看这个标题&#xff0c;可能会有点摸不着头脑&#xff0c;但如果你对AI生成内容&#xff0c;特别是Stable Diffusion这类文生图模型的应用和优化感兴趣&#xff0c…...

YOLOv5实战:手把手教你用BiFPN替换PANet,实测疵点检测mAP提升7个点

YOLOv5工业质检实战&#xff1a;BiFPN特征融合在疵点检测中的性能突破 在工业质检领域&#xff0c;毫米级的表面缺陷往往决定着产品的最终品质。传统人工检测不仅效率低下&#xff0c;且漏检率常高达15%-20%。我们团队在最近三个月的产线测试中发现&#xff0c;基于YOLOv5的深度…...

生成式AI性能评估:核心指标与GenAI-Perf实战

1. 生成式AI性能评估的挑战与机遇在生成式AI模型的实际部署中&#xff0c;性能评估远比传统机器学习模型复杂得多。作为一名长期从事AI基础设施优化的工程师&#xff0c;我深刻体会到&#xff1a;当面对动辄数十亿参数的大语言模型&#xff08;LLM&#xff09;时&#xff0c;简…...

C++实现Windows防休眠工具:模拟鼠标移动与系统API调用详解

1. 项目概述&#xff1a;一个让鼠标指针“动起来”的Windows小工具 如果你和我一样&#xff0c;在Windows系统上工作或学习时&#xff0c;偶尔会离开电脑前&#xff0c;但又不想让屏幕进入休眠或锁屏状态&#xff08;比如正在下载大文件&#xff0c;或者需要保持某个远程会话在…...

大模型动态记忆管理:MemAct框架原理与实践

1. 项目概述&#xff1a;当大模型学会"记笔记"在自然语言处理领域&#xff0c;大型语言模型&#xff08;LLM&#xff09;的上下文窗口就像人类的工作记忆——容量有限却至关重要。传统方法中&#xff0c;模型被动接收全部对话历史&#xff0c;导致重要信息淹没在文本…...

Java字节流详解FileInputStream和FileOutputStream

Java 字节流详解&#xff1a;FileInputStream 和 FileOutputStream 从入门到实践 一、前言 在 Java 中&#xff0c;文件的读写操作是最基础也是最高频的 I/O 场景之一。字节流&#xff08;Byte Stream&#xff09;作为 Java I/O 体系的两大分支之一&#xff0c;负责处理所有二进…...

AI智能体开发实战:从开源Cookbook到生产级应用构建指南

1. 项目概述&#xff1a;一份面向开发者的AI实战手册最近在整理自己的技术工具箱时&#xff0c;我重新审视了Dave Ebbelaar维护的“AI Cookbook”项目。这并非一个需要你从零开始部署的复杂系统&#xff0c;而是一个开源的、由代码片段和教程组成的集合库。它的核心价值在于&am…...

Kapitan配置管理:基于Jsonnet与Jinja2的多环境云原生配置实践

1. 项目概述&#xff1a;为什么我们需要Kapitan这样的配置管理工具&#xff1f;在云原生和基础设施即代码&#xff08;IaC&#xff09;的时代&#xff0c;我们手里的配置文件正以前所未有的速度膨胀。Kubernetes的YAML清单、Terraform的HCL文件、Helm的Chart、Ansible的Playboo…...