首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何在单个rego策略中压缩和优化开放策略代理

如何在单个rego策略中压缩和优化开放策略代理
EN

Stack Overflow用户
提问于 2021-02-08 07:00:43
回答 1查看 221关注 0票数 0

我是雷戈OPA (开放策略代理)的新手。

我试图为允许策略重写的实现创建一个默认策略,但在正常情况下,在一个简单的JSON文档中使用“策略配置”。

我使用输入作为“策略配置”,数据是要由策略处理的数据。数据本身是预处理的,其中"$error“是用错误计算的JSON元素。

该策略似乎运行良好,但据我所知,它必须是在rego中表达相同内容的一种更简单的方法,因此也可以更多地使用优化的(当前的策略大约需要1ms来评估)。

游乐场包含以下要在线评估的设置.

干杯,马里奥:)

input.json

代码语言:javascript
复制
{
  "range": {"IDT**": [-100, 100], "RHCS**": [20, 200]},
  "report": ["ODT", "IDT_*_O2"],
  "skip": ["IDT**"]
}

data.json

代码语言:javascript
复制
{
  "target": {
    "IDT": 22,
    "IDT_C1_O1": 22.2,
    "IDT_C1_O2": 101,
    "IDT_C1_O3": "$error",
    "IDT_C1_O4": "$error",
    "ODT": "$error",
    "RHCS_C13_O44": "$error"
  }
}

计算cbprovider rego策略后的输出为

代码语言:javascript
复制
{
    "all_errors": [ "RHCS_C13_O44", "IDT_C1_O3", "IDT_C1_O4", "ODT", "IDT_C1_O2" ],
    "report": [ "ODT", "IDT_C1_O2" ],
    "skip": [ "IDT_C1_O3", "IDT_C1_O4" ]
}
代码语言:javascript
复制
package cbprovider

# Errors to be skipped
# If present in report as well it will not be skipped
# (report overrides skip)
skip[dp] {
    my := data.target[dp]
    my == "$error"   
    
    matchSkip(dp)
    
    not matchReport(dp)
}

# Errors to be skipped when out of range
skip[dp] {
    my := data.target[dp]
    my != "$error"   
    
    matchSkip(dp)
    
    not matchReport(dp)
    
    range := get_range(dp)
    not in_range(my, range[0], range[1])    
}


# Errors to be reported
# If matches both in skip and report -> report overrides skip
report[dp] {
    my := data.target[dp]
    my == "$error"   
    
    matchReport(dp)
}

# Errors to be reported when out of range
report[dp] {
    my := data.target[dp]
    my != "$error"   
    
    matchReport(dp)

    range := get_range(dp)
    not in_range(my, range[0], range[1])
}


all_errors[dp] {
    my := data.target[dp]
    my == "$error"     
}

all_errors[dp] {
    my := data.target[dp]
    my != "$error"
    
    range := get_range(dp)
    not in_range(my, range[0], range[1])
}

in_range(num, low, high) {
    num >= low
    num <= high
}

get_range(dp) = range {
    some key
    range := input.range[key]
    
    glob.match(key, ["_"], dp)
}

matchSkip(dp) {
    some i
    input.skip[i]
    glob.match(input.skip[i], ["_"], dp)
}

matchReport(dp) {
    some i
    input.report[i]
    glob.match(input.report[i], ["_"], dp)
}
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2021-02-08 11:50:55

我觉得你的政策看起来不错。如果您需要进一步调优它以提高性能,我建议您考虑如何调整您的数据,以便您的策略不需要依赖glob.match。从临时测试来看,目前大约有一半的评估时间是在那里度过的。

票数 3
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/66097149

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档