CHF功能及5G融合计费(Converged Charging)概述

2023-10-23 09:59

本文主要是介绍CHF功能及5G融合计费(Converged Charging)概述,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

一 5G计费架构 vs 4G计费架构

1.1 4G计费架构

4G中将离线计费和在线计费分离,其中:

- 离线计费:由PGW产生话单CDR,发给CG计费网关,处理后送给BOSS扣费。对应的接口为Ga和Gz接口。

- 在线计费:由OCS根据用户的账户余额产生配额(quota),并下发给PGW,配额耗尽,代表用户账上没钱了。自动触发重定向和短信提醒,引导UE充值。对应接口为Gy接口。

如下图所示:

1.2 5G计费架构

1.2.1 主要变化

而5G中将离线计费和在线计费融合了,因此也叫5G融合计费(规范叫Converged Charging)。

这意味着相关网元功能也发生了变化。主要有:

1)SMF不再产生话单,由CHF产生话单CDR。

2)CHF不仅要产生话单,还需要像OCS一样,为SMF提供在线计费所需要的配额。

3)SMF的角色下沉为CTF(Charging Trigger Function:计费触发功能),只能通过给CHF发送报告的形式请求CTF来产生话单,SMF自己不产生话单。

4)CHF同时还承担CGF(Charging Gateway Function:计费网关功能),完成话单的产生、合并、整理、格式化等工作,相当于集成了4G中CG的功能。

5)计费协议也做了升级;

- 4G离线计费协议为FTP或GTP',在线计费为DIameter,5G则统一为基于SBI的Nchf接口,走HTTP2。

架构图如下两图所示,一个是3GPP定义的5G融合计费架构图,一个是51学通信自己画的简化版。

【tips:理解Charging vs Charging Control的差别:

Charging和Charging Control意义完全不同。前者说的是扣钱,这个是由BOSS侧完成的。而计费控制说的是按不同场景动态(例如闲时忙时)的提供计费策略(不同的资费标准),通常可以由SMF/PCF/CHF配合来完成。】

1.2.2 相关规范

建议看3个规范,按顺序看。

1)TS 32.255(SMF相关的5G连接和会话管理的融合计费架构、流程)

2)TS 32.290(5G计费的SBI流程和Nchf的服务)

3)TS 32.291(Nchf及SBI接口的主要参数)

如果想看话单,还可以看

4)TS 32.298(CDR的格式参数)

以及

TS 23.503 (5G的PCC架构)。

二 计费相关网元的具体要求

结合实际网络,通常对5G计费相关网元有以下要求;

2.1 CHF的要求

- 作为服务提供者,支持Nchf_Converged_Charging接口的计费会话流程;

- 提供配额;

- 提供重授权触发条件

- 转发BOSS过来的通知给SMF

- 接收来自NF服务消费者(SMF)的服务用量报告;

- 可支持向NRF注册、更新、去注册;

- 可生成CHF-CDR话单;

2.2 SMF(CTF)的要求

- 支持选择CHF;

- 作为服务使用者,支持Nchf_Converged_Charging接口的计费会话流程请求并接收配额;

- 按配额或门限跟踪记录业务使用量;

- 上报配额用量、业务用量报告给CHF;

- 处理配额重授权触发条件和相应上报给CHF;

- 处理通知;

2.3 其他网元的要求:

1)UPF:支持按照接收PDR/URR等规则,能根据业务检测规则检测流量,并上报使用量。

2)PCF:能为SMF提供CHF的地址。

3)UDM:为SMF传递用户签约的CC值(计费特征码。)

4)NRF:支持CHF的注册、更新、去注册,支持SMF发现CHF。


三 CHF的融合计费服务:Nchf_Converged_Charging

CHF的融合计费服务接口在32.290中定义。

一共有4个服务操作,Create、Update、Release、Notify。

主要的消费者网元有SMF、AMF、SMSF。

【注:AMF也具有CTF功能,但AMF触发产生的话单,通常不作为扣费的依据,就不展开了。】

这里有一个坑,说一下。在3GPP的计费相关的信令流程中,并不会写SBI接口的消息名称,而是Charging Data Request、Charging Data Response、ChargingNotifyRequest、ChargingNotifyResponse。

因此需要建立SBI接口与这俩消息的对应关系。这个对应关系在32.291中有一张表,注明了。如下:

所以,我们在3GPP的信令流程图里看到的消息Charging Data Request和Charging Data Response。

但在我们的log中,是找不到的。对应的是HTTP的GET、POST这种方法。就需要根据上面这个映射关系表,

查32.290和32.291进行手工翻译。

呵呵,是不是觉得有点麻烦?

不用担心哈,有51学通信知识星球呢。

咱帮您翻。

关注这个图文专栏就行,有必要的话,也可以录成视频。

Create、Update、Release、Notify这4个服务操作对应的HTTP方法和参数也在32.291中定义。

如下几张图所示:

图1:Nchf_ ConvergedCharging_Create服务操作

图2:Nchf_ ConvergedCharging_Update服务操作

图3:Nchf_ConvergedCharging_Release服务操作

图4:Nchf_ConvergedCharging_Notify服务操作

根据学习路径,应该是看架构--->流程-->消息-->参数,(流程后面慢慢介绍吧。)

接下来应该看参数了。

找到32.291里的这个表,这个就是Nchf接口对应的所有参数索引。然后根据第2列中的章节,就可以找到具体的参数详细信息了。

由于相关的参数太多了,无法一一列举,具体您可以去看看32.291的6.1.6节的参数定义。

本文这里放一个消息Charging Data Request的参数。

Charging Data Request有两类参数,一类叫公共参数(即其他网元可能也有这个参数),一类叫特有参数(就只有它有。)公共参数在6.1.6.2.1 Common Data Type下的6.1.6.2.1.1 Type ChargingDataRequest定义。特有参数在6.1.6.2.2 5G Data Connectivity Specified Data Type下的6.1.6.2.2.1 Type ChargingDataRequest定义。

1)Charging Data Request消息的公共参数主要有:

-- subscriberIdentifier

--nfConsumerIdentification

--chargingId

--invocationTimeStamp

--invocationSequenceNumber

--retransmissionIndicator

--oneTimeEvent

--oneTimeEventType

--notifyUri

--supportedFeatures

--serviceSpecificationInfo

--multipleUnitUsage

--triggers

2)Charging Data Request的特有参数主要有:

--pDUSessionChargingInformation

--roamingQBCInformation

好了,理论铺垫就是这么多了。

后面直接上实践了。



更多精彩内容,请阅知识星球800+篇精华合集帖。

该链接收录了知识星球800+篇的精华内容,

涵盖了5G核心网、IMS绝大多数知识点:

含视频、图文专栏、精华帖、问答等等精华内容。

无论是想学习课程、看视频、看案例、看log、看实战,统统都有。

各位星友必看!!!

知识星球800+篇精华合集(链接永久不变,内容自动更新):

Docs

飞书域名太长,还创建了一个短链接:

http://gg.gg/15t0bu

这篇关于CHF功能及5G融合计费(Converged Charging)概述的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/267105

相关文章

水位雨量在线监测系统概述及应用介绍

在当今社会,随着科技的飞速发展,各种智能监测系统已成为保障公共安全、促进资源管理和环境保护的重要工具。其中,水位雨量在线监测系统作为自然灾害预警、水资源管理及水利工程运行的关键技术,其重要性不言而喻。 一、水位雨量在线监测系统的基本原理 水位雨量在线监测系统主要由数据采集单元、数据传输网络、数据处理中心及用户终端四大部分构成,形成了一个完整的闭环系统。 数据采集单元:这是系统的“眼睛”,

C++11第三弹:lambda表达式 | 新的类功能 | 模板的可变参数

🌈个人主页: 南桥几晴秋 🌈C++专栏: 南桥谈C++ 🌈C语言专栏: C语言学习系列 🌈Linux学习专栏: 南桥谈Linux 🌈数据结构学习专栏: 数据结构杂谈 🌈数据库学习专栏: 南桥谈MySQL 🌈Qt学习专栏: 南桥谈Qt 🌈菜鸡代码练习: 练习随想记录 🌈git学习: 南桥谈Git 🌈🌈🌈🌈🌈🌈🌈🌈🌈🌈🌈🌈🌈�

让树莓派智能语音助手实现定时提醒功能

最初的时候是想直接在rasa 的chatbot上实现,因为rasa本身是带有remindschedule模块的。不过经过一番折腾后,忽然发现,chatbot上实现的定时,语音助手不一定会有响应。因为,我目前语音助手的代码设置了长时间无应答会结束对话,这样一来,chatbot定时提醒的触发就不会被语音助手获悉。那怎么让语音助手也具有定时提醒功能呢? 我最后选择的方法是用threading.Time

Java 创建图形用户界面(GUI)入门指南(Swing库 JFrame 类)概述

概述 基本概念 Java Swing 的架构 Java Swing 是一个为 Java 设计的 GUI 工具包,是 JAVA 基础类的一部分,基于 Java AWT 构建,提供了一系列轻量级、可定制的图形用户界面(GUI)组件。 与 AWT 相比,Swing 提供了许多比 AWT 更好的屏幕显示元素,更加灵活和可定制,具有更好的跨平台性能。 组件和容器 Java Swing 提供了许多

韦季李输入法_输入法和鼠标的深度融合

在数字化输入的新纪元,传统键盘输入方式正悄然进化。以往,面对实体键盘,我们常需目光游离于屏幕与键盘之间,以确认指尖下的精准位置。而屏幕键盘虽直观可见,却常因占据屏幕空间,迫使我们在操作与视野间做出妥协,频繁调整布局以兼顾输入与界面浏览。 幸而,韦季李输入法的横空出世,彻底颠覆了这一现状。它不仅对输入界面进行了革命性的重构,更巧妙地将鼠标这一传统外设融入其中,开创了一种前所未有的交互体验。 想象

Spring框架5 - 容器的扩展功能 (ApplicationContext)

private static ApplicationContext applicationContext;static {applicationContext = new ClassPathXmlApplicationContext("bean.xml");} BeanFactory的功能扩展类ApplicationContext进行深度的分析。ApplicationConext与 BeanF

JavaFX应用更新检测功能(在线自动更新方案)

JavaFX开发的桌面应用属于C端,一般来说需要版本检测和自动更新功能,这里记录一下一种版本检测和自动更新的方法。 1. 整体方案 JavaFX.应用版本检测、自动更新主要涉及一下步骤: 读取本地应用版本拉取远程版本并比较两个版本如果需要升级,那么拉取更新历史弹出升级控制窗口用户选择升级时,拉取升级包解压,重启应用用户选择忽略时,本地版本标志为忽略版本用户选择取消时,隐藏升级控制窗口 2.

【编程底层思考】垃圾收集机制,GC算法,垃圾收集器类型概述

Java的垃圾收集(Garbage Collection,GC)机制是Java语言的一大特色,它负责自动管理内存的回收,释放不再使用的对象所占用的内存。以下是对Java垃圾收集机制的详细介绍: 一、垃圾收集机制概述: 对象存活判断:垃圾收集器定期检查堆内存中的对象,判断哪些对象是“垃圾”,即不再被任何引用链直接或间接引用的对象。内存回收:将判断为垃圾的对象占用的内存进行回收,以便重新使用。

Android 10.0 mtk平板camera2横屏预览旋转90度横屏拍照图片旋转90度功能实现

1.前言 在10.0的系统rom定制化开发中,在进行一些平板等默认横屏的设备开发的过程中,需要在进入camera2的 时候,默认预览图像也是需要横屏显示的,在上一篇已经实现了横屏预览功能,然后发现横屏预览后,拍照保存的图片 依然是竖屏的,所以说同样需要将图片也保存为横屏图标了,所以就需要看下mtk的camera2的相关横屏保存图片功能, 如何实现实现横屏保存图片功能 如图所示: 2.mtk

Spring+MyBatis+jeasyui 功能树列表

java代码@EnablePaging@RequestMapping(value = "/queryFunctionList.html")@ResponseBodypublic Map<String, Object> queryFunctionList() {String parentId = "";List<FunctionDisplay> tables = query(parent