配置概览
优质
小牛编辑
128浏览
2023-12-01
MOSN 配置文件概览。
MOSN 的配置文件可以分为以下四大部分:
- Servers 配置,目前仅支持最多 1 个 Server 的配置,Server 中包含一些基础配置以及对应的 Listener 配置
ClusterManager
配置,包含 MOSN 的 Upstream 详细信息- 对接控制平面(Pilot)的 xDS 相关配置
- 其他配置
- Trace、Metrics、Debug、Admin API 相关配置
- 扩展配置,提供自定义配置扩展需求
配置文件概览
MOSN 的基本配置部分如下所示:
{
"servers": [],
"cluster_manager": {},
"dynamic_resources": {},
"static_resources": {},
"admin":{},
"pprof":{},
"tracing":{},
"metrics":{}
}
配置类型
MOSN 的配置包括以下几种类型:
- 静态配置
- 动态配置
- 混合模式
静态配置
- 静态配置是指 MOSN 启动时,不对接控制平面 Pilot 的配置,用于一些相对固定的简单场景(如 MOSN 的示例)。
- 使用静态配置启动的 MOSN,也可以通过扩展代码,调用动态更新配置的接口实现动态修改。
- 静态配置启动时必须包含一个 Server 以及至少一个 Cluster。
动态配置
动态配置是指 MOSN 启动时,只有访问控制平面相关的配置,没有 MOSN 运行时所需要的配置。
使用动态配置启动的 MOSN,会向管控面请求获取运行时所需要的配置,管控面也可能在运行时推送更新 MOSN 运行配置。
动态配置启动时必须包含
DynamicResources
和StaticResources
配置。
混合模式
MOSN 启动时的配置可以同时包含静态模式与动态模式,以混合模式启动的 MOSN 会先以静态配置完成初始化,随后可能由控制平面获取配置更新。
配置示例
静态配置示例
静态配置的示例如下所示。
{
"servers": [
{
"default_log_path": "/home/admin/logs/mosn/default.log",
"default_log_level": "DEBUG",
"processor": 4,
"listeners": [
{
"address": "0.0.0.0:12220",
"bind_port": true,
"filter_chains": [
{
"filters": [
{
"type": "proxy",
"config": {
"downstream_protocol": "SofaRpc",
"upstream_protocol": "SofaRpc",
"router_config_name": "test_router"
}
},
{
"type": "connection_manager",
"config": {
"router_config_name": "test_router",
"virtual_hosts": []
}
}
]
}
]
}
]
}
],
"cluster_manager": {
"clusters": [
{
"name":"example",
"lb_type": "LB_ROUNDROBIN",
"hosts": [
{"address": "127.0.0.1:12200"}
]
}
]
}
}
动态配置示例
动态配置的示例如下所示。
{
"dynamic_resources": {
"ads_config": {
"api_type": "GRPC",
"grpc_services": [
{
"envoy_grpc": {"cluster_name": "xds-grpc"}
}
]
}
}
},
"static_resources": {
"clusters": [
{
"name": "xds-grpc",
"type": "STRICT_DNS",
"connect_timeout": "10s",
"lb_policy": "ROUND_ROBIN",
"hosts": [
{
"socket_address": {"address": "pilot", "port_value": 15010}
}
],
"upstream_connection_options": {
"tcp_keepalive": {
"keepalive_time": 300
}
},
"http2_protocol_options": { }
}
]
}
}
ClusterManager 配置
MOSN ClusterManager 配置说明。
Server 配置
MOSN server 配置说明。
Trace 配置
MOSN trace 配置说明。
自定义配置
MOSN 自定义配置说明。