mirror of
https://github.com/ossrs/srs.git
synced 2025-03-09 15:49:59 +00:00
Support HTTP-API for fetching reload result. v5.0.176 v6.0.71 (#3779)
## Reload Error Ignore During a Reload, several stages will be passed through: 1. Parsing new configurations: Parse. 2. Transforming configurations: Transform. 3. Applying configurations: Apply. Previously, any error at any stage would result in a direct exit, making the system completely dependent on configuration checks: ```bash ./objs/srs -c conf/srs.conf -t echo $? #0 ``` Optimized to: If an error occurs before applying the configuration, it can be ignored. If an error occurs during the application of the configuration, some of the configuration may have already taken effect, leading to unpredictable behavior, so SRS will exit directly. ## Reload Fetch API Added a new HTTP API to query the result of the reload. ```nginx http_api { enabled on; raw_api { enabled on; allow_reload on; } } ``` ```bash curl http://localhost:1985/api/v1/raw?rpc=reload-fetch ``` ```json { "code": 0, "data": { "err": 0, "msg": "Success", "state": 0, "rid": "0s6y0n9" } } { "code": 0, "data": { "err": 1023, "msg": "code=1023(ConfigInvalid) : parse file : parse buffer containers/conf/srs.release-local.conf : root parse : parse dir : parse include buffer containers/data/config/srs.vhost.conf : read token, line=0, state=0 : line 3: unexpected end of file, expecting ; or \"}\"", "state": 1, "rid": "0g4z471" } } ``` This way, you can know if the last reload of the system was successful. --------- Co-authored-by: Haibo Chen <495810242@qq.com>
This commit is contained in:
parent
bb9331186b
commit
aa5ec87fcb
10 changed files with 84 additions and 20 deletions
|
@ -256,6 +256,19 @@ private:
|
|||
virtual srs_error_t read_token(srs_internal::SrsConfigBuffer* buffer, std::vector<std::string>& args, int& line_start, SrsDirectiveState& state);
|
||||
};
|
||||
|
||||
// The state for reloading config.
|
||||
enum SrsReloadState {
|
||||
SrsReloadStateInit = 0,
|
||||
// Start to parse the new config file.
|
||||
SrsReloadStateParsing = 10,
|
||||
// Start to transform the new config file to new version.
|
||||
SrsReloadStateTransforming = 20,
|
||||
// Start to apply the new config file.
|
||||
SrsReloadStateApplying = 30,
|
||||
// The reload is finished.
|
||||
SrsReloadStateFinished = 90,
|
||||
};
|
||||
|
||||
// The config service provider.
|
||||
// For the config supports reload, so never keep the reference cross st-thread,
|
||||
// that is, never save the SrsConfDirective* get by any api of config,
|
||||
|
@ -308,7 +321,7 @@ public:
|
|||
virtual void unsubscribe(ISrsReloadHandler* handler);
|
||||
// Reload the config file.
|
||||
// @remark, user can test the config before reload it.
|
||||
virtual srs_error_t reload();
|
||||
virtual srs_error_t reload(SrsReloadState *pstate);
|
||||
private:
|
||||
// Reload the vhost section of config.
|
||||
virtual srs_error_t reload_vhost(SrsConfDirective* old_root);
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue