yaml中的锚点和引用

项目引入yaml语言来写配置文件,最近发现利用其锚点&和引用*的功能,可以极大减少配置文件中的重复内容,将相同配置内容收敛到锚点处,修改时,只需要修改锚点处的内容,即可在所有引用处生效。

yaml基础参考自阮老师的blog: http://www.ruanyifeng.com/blog/2016/07/yaml.html?f=tt

具体练习也是使用阮老师推荐的http://nodeca.github.io/js-yaml/

举例,在server对redis的访问配置中,针对不同的db可能会写成如下配置:

复制代码
user:
    host: 127.0.0.1
    db: 8

book:
    host: 127.0.0.1
    db: 9

comment:
    host: 127.0.0.1
    db: 10
复制代码

此处host其实配置都是一样的,只有db不一样,通过锚点和引用的功能,可以写成如下:

复制代码
localhost: &localhost1
    host: 127.0.0.1
user:
    <<: *localhost1
    db: 8

book:
    <<: *localhost1
    db: 9

comment:
    <<: *localhost1
    db: 10
复制代码

其中&表示将localhost1作为localhost的别名,*标识取别名localhost1对应的value,<<表示将*localhost1代表的map合并入当前map数据。

针对远端服务多台机器的访问配置,针对不同情况可能存在不同的优先级访问顺序,可以写成如下形式:

复制代码
server_order_0:
    -
        - 127.0.0.1
        - 8050
    -
        - 10.0.1.1
        - 8050
    -
        - 10.0.2.1
        - 8050

server_order_1:
    -
        - 10.0.1.1
        - 8050
    -
        - 127.0.0.1
        - 8050
    -
        - 10.0.2.1
        - 8050

server_order_2:
    -
        - 10.0.2.1
        - 8050
    -
        - 10.0.1.1
        - 8050
    -
        - 127.0.0.1
        - 8050
复制代码

利用锚点和引用,可以写为下面的配置:

复制代码
server0: &server0
    - 127.0.0.1
    - 8050

server1: &server1
    - 10.0.1.1
    - 8050

server2: &server2
    - 10.0.2.1
    - 8050    

server_order_0:
    -
        *server0
    -
        *server1
    -
        *server2

server_order_1:
    -
        *server1
    -
        *server0
    -
        *server2

server_order_2:
    -
        *server2
    -
        *server1
    -
        *server0
复制代码

 

posted @   及时  阅读(18849)  评论(1编辑  收藏  举报
编辑推荐:
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
阅读排行:
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· 单线程的Redis速度为什么快?
· SQL Server 2025 AI相关能力初探
· 展开说说关于C#中ORM框架的用法!
· AI编程工具终极对决:字节Trae VS Cursor,谁才是开发者新宠?
点击右上角即可分享
微信分享提示