zoukankan      html  css  js  c++  java
  • Diameter消息应用层的路由

    1. 1.      创建和发送Request消息:http://blog.csdn.net/minico/article/details/5723503

    1)      产生一个Request消息时,必须遵守下列规则:

    • 设置头部的Command code;
    • 设置头部的 'R' 位;
    • 设置头部的End-to-End 为本地的唯一值;
    • Origin-Host 和 Origin-Realm AVPs 必须携带, 用来标识消息的源地址;
    • Destination-Host 和 Destination-Realm AVPs 需根据以下规则设置;

    a)      不能被Proxy的消息一定不能带Destination-Realm and Destination-Host AVPs;

    b)      如果消息是发往某个realm而不是具体的host,则只携带Destination-Realm AVP;

    c)      如果消息是发往某个具体的host,则需要同时携带Destination-Realm and Destination-Host AVPs;

    • 如果消息有可能被转发,则消息中还必须携带下列AVP之一:an Acct-Application-Id AVP, an Auth-Application-Id AVP or a Vendor-Specific-Application-Id AVP;

    2)      当发送一个Request消息时,无论是源主机发送还是Agent转发,都需要执行下列操作:

    a)      设置头部的Hop-by-Hop为本地的唯一值;

    b)      将该消息放入Pending Request消息队列;

    1. 2.      收到Request消息:

    1)      当一个Diameter节点收到一个Request消息后,有如下四种可能的处理方式:

    a)      如果满足如下条件,则本地处理:

    • Destination-Host AVP包含了本地host的标识,或者
    • Destination-Host AVP 不存在, Destination-Realm AVP 经过在路由表中查询被配置为本地处理, 或者
    • Destination-Host 和 Destination-Realm 都不存在;

    b)      如果Destination-Host AVP存在于本地的Peer table中,则执行Request Forwarding:

    c)      如果没有本地处理也没有进行Request forwarding,则根据 Destination-Realm AVP 和 Auth-Application-Id 或 Acct-Application-Id 或 Vendor-Specific-Application-Id 查找Realm Routing Table,执行Request Routing;

    d)     返回错误DIAMETER_UNABLE_TO_DELIVER ;

    注意:这里区分了Request forwarding和Request Routing;本文其它地方提到的“转发”都是泛指消息非本地处理的情况;

    2)      Request消息在被Relay或者Proxy的时候,Relay Agent和Proxy Agent需要做如下工作:

    a)      在转发出去的Request消息中插入Route-Record AVP,里面包含发送该Request消息的主机标识;

    b)      保存和该Request消息相关的:Protocol, IP Address, Port, Hop-by-Hop标识;保存这些信息是为了收到与该Reqeuest消息对应的Answer消息后能够将Answer消息正确的转发出去;

    1. 3. 创建Answer消息:

    当一个Request消息被本地处理后,必须按照如下规则创建并发送Answer消息:

    • 从Request消息中拷贝Hop-by-Hop填入Answer消息;
    • 将本地主机标识作为Origin-Host AVP;
    • Destination-Host 和 Destination-Realm AVPs 不允许出现在Answer消息中;
    • 加上 Result-Code AVP 指示成功与否.
    • 如果Reqeust消息中包含了Session-Id,那么Answer消息中也应该包含该值;
    • 在Request消息中的任何Proxy-Info AVPs 都应原封不动的拷贝到Answer消息中;
    • 'P' 位需要和Request消息中保持一致;
    • End-to-End 需要和Request消息中保持一致;
    1. 收到Answer消息:

    当收到一个Answer消息时需要如下操作:

    • 检查其Hop-by-Hop,从Pending Request队列中找到与其一致的Reqeust消息,然后将Reqeust消息从Pending Request队列中删除;
    • 如果是Agent收到Answer消息,Agent需要将Hop-by-Hop替换为先前保存的Reqeust中的Hop-by-Hop,然后再将Answer消息转发出去;

    下图是Diameter节点abc.example.com经由Relay Agent发送一个Request消息给xyz.example.net并收到Answer消息的示意图,该图主要为了说明Hop-by-Hop和End-to-End两个标识的作用:

    http://hi.csdn.net/attachment/201007/10/0_1278740717r5ai.gif

  • 相关阅读:
    Docker从入门到精通(四)——常用命令
    Docker从入门到精通(二)——安装Docker
    Docker从入门到精通(一)——初识
    Java设计模式之(十三)——模板方法模式
    Java设计模式之(十四)——策略模式
    Docker从入门到精通(七)——容器数据共享
    YCFramework版本更新:V1.0.2
    YCFramework版本更新:V1.0.3
    我的分布式微服务框架:YCFramework
    mysql 多表多字段报表填充查询
  • 原文地址:https://www.cnblogs.com/iloveyoucc/p/2537716.html
Copyright © 2011-2022 走看看