mirror of
https://github.com/XTLS/Xray-core.git
synced 2025-01-19 08:51:45 +03:00
fa5d7a255b
* v5: Health Check & LeastLoad Strategy (rebased from 2c5a71490368500a982018a74a6d519c7e121816) Some changes will be necessary to integrate it into V2Ray * Update proto * parse duration conf with time.Parse() * moving health ping to observatory as a standalone component * moving health ping to observatory as a standalone component: auto generated file * add initialization for health ping * incorporate changes in router implementation * support principle target output * add v4 json support for BurstObservatory & fix balancer reference * update API command * remove cancelled API * return zero length value when observer is not found * remove duplicated targeted dispatch * adjust test with updated structure * bug fix for observer * fix strategy selector * fix strategy least load * Fix ticker usage ticker.Close does not close ticker.C * feat: Replace default Health Ping URL to HTTPS (#1991) * fix selectLeastLoad() returns wrong number of nodes (#2083) * Test: fix leastload strategy unit test * fix(router): panic caused by concurrent map read and write (#2678) * Clean up code --------- Co-authored-by: Jebbs <qjebbs@gmail.com> Co-authored-by: Shelikhoo <xiaokangwang@outlook.com> Co-authored-by: 世界 <i@sekai.icu> Co-authored-by: Bernd Eichelberger <46166740+4-FLOSS-Free-Libre-Open-Source-Software@users.noreply.github.com> Co-authored-by: 秋のかえで <autmaple@protonmail.com> Co-authored-by: Rinka <kujourinka@gmail.com>
84 lines
2.0 KiB
Protocol Buffer
84 lines
2.0 KiB
Protocol Buffer
syntax = "proto3";
|
|
|
|
package xray.core.app.observatory;
|
|
option csharp_namespace = "Xray.App.Observatory";
|
|
option go_package = "github.com/xtls/xray-core/app/observatory";
|
|
option java_package = "com.xray.app.observatory";
|
|
option java_multiple_files = true;
|
|
|
|
message ObservationResult {
|
|
repeated OutboundStatus status = 1;
|
|
}
|
|
|
|
message HealthPingMeasurementResult {
|
|
int64 all = 1;
|
|
int64 fail = 2;
|
|
int64 deviation = 3;
|
|
int64 average = 4;
|
|
int64 max = 5;
|
|
int64 min = 6;
|
|
}
|
|
|
|
message OutboundStatus{
|
|
/* @Document Whether this outbound is usable
|
|
@Restriction ReadOnlyForUser
|
|
*/
|
|
bool alive = 1;
|
|
/* @Document The time for probe request to finish.
|
|
@Type time.ms
|
|
@Restriction ReadOnlyForUser
|
|
*/
|
|
int64 delay = 2;
|
|
/* @Document The last error caused this outbound failed to relay probe request
|
|
@Restriction NotMachineReadable
|
|
*/
|
|
string last_error_reason = 3;
|
|
/* @Document The outbound tag for this Server
|
|
@Type id.outboundTag
|
|
*/
|
|
string outbound_tag = 4;
|
|
/* @Document The time this outbound is known to be alive
|
|
@Type id.outboundTag
|
|
*/
|
|
int64 last_seen_time = 5;
|
|
/* @Document The time this outbound is tried
|
|
@Type id.outboundTag
|
|
*/
|
|
int64 last_try_time = 6;
|
|
|
|
HealthPingMeasurementResult health_ping = 7;
|
|
}
|
|
|
|
message ProbeResult{
|
|
/* @Document Whether this outbound is usable
|
|
@Restriction ReadOnlyForUser
|
|
*/
|
|
bool alive = 1;
|
|
/* @Document The time for probe request to finish.
|
|
@Type time.ms
|
|
@Restriction ReadOnlyForUser
|
|
*/
|
|
int64 delay = 2;
|
|
/* @Document The error caused this outbound failed to relay probe request
|
|
@Restriction NotMachineReadable
|
|
*/
|
|
string last_error_reason = 3;
|
|
}
|
|
|
|
message Intensity{
|
|
/* @Document The time interval for a probe request in ms.
|
|
@Type time.ms
|
|
*/
|
|
uint32 probe_interval = 1;
|
|
}
|
|
message Config {
|
|
/* @Document The selectors for outbound under observation
|
|
*/
|
|
repeated string subject_selector = 2;
|
|
|
|
string probe_url = 3;
|
|
|
|
int64 probe_interval = 4;
|
|
|
|
bool enable_concurrency = 5;
|
|
} |