add MS_RDR_ENABLE and MS_RDR_PATH

MS_RDR_ENABLE should be in {0, 1}. if it is set as other value, it will
be 0 and WARNING information will be printed to tell user.
The settings in config file set by the user takes precedence over the
environment variables. If 'rdr_enable' is 0 in environment variable,
and then 'enable' is true in config file, the RDR will turned on.
This commit is contained in:
luopengting 2021-03-17 15:06:46 +08:00
parent defcc51641
commit 23ba47df6c
4 changed files with 73 additions and 14 deletions

View File

@ -14,6 +14,7 @@
* limitations under the License.
*/
#include "debug/env_config_parser.h"
#include <algorithm>
#include <fstream>
#include "nlohmann/json.hpp"
#include "utils/log_adapter.h"
@ -22,12 +23,46 @@
#include "utils/convert_utils_base.h"
namespace {
constexpr auto kEnableEnv = "MS_RDR_ENABLE";
constexpr auto kPathEnv = "MS_RDR_PATH";
constexpr auto kRdrSettings = "rdr";
constexpr auto kPath = "path";
constexpr auto kEnable = "enable";
} // namespace
namespace mindspore {
std::optional<bool> GetRdrEnableFromEnv() {
// get environment variable to configure RDR
const char *env_enable_char = std::getenv(kEnableEnv);
if (env_enable_char != nullptr) {
std::string env_enable_str = env_enable_char;
(void)std::transform(env_enable_str.begin(), env_enable_str.end(), env_enable_str.begin(), ::tolower);
if (env_enable_str != "0" && env_enable_str != "1") {
MS_LOG(WARNING) << "The environment variable '" << kEnableEnv << "' should be 0 or 1.";
}
if (env_enable_str == "1") {
return true;
}
return false;
}
return std::nullopt;
}
std::optional<std::string> GetRdrPathFromEnv() {
// get environment variable to configure RDR
const char *path_char = std::getenv(kPathEnv);
if (path_char != nullptr) {
std::string err_msg = "RDR path parse from environment variable failed. Please check the settings about '" +
std::string(kPathEnv) + "' in environment variables.";
std::string path = path_char;
if (!Common::IsPathValid(path, maxDirectoryLength, err_msg, false)) {
return std::string("");
}
return path;
}
return std::nullopt;
}
bool EnvConfigParser::CheckJsonStringType(const nlohmann::json &content, const std::string &setting_key,
const std::string &key) {
if (!content.is_string()) {
@ -55,13 +90,24 @@ std::string EnvConfigParser::GetIfstreamString(const std::ifstream &ifstream) {
return buffer.str();
}
void EnvConfigParser::Parse() {
std::lock_guard<std::mutex> guard(lock_);
if (already_parsed_) {
return;
void EnvConfigParser::ParseFromEnv() {
// Get RDR seetings from environment variables
auto rdr_enable_env = GetRdrEnableFromEnv();
if (rdr_enable_env.has_value()) {
has_rdr_setting_ = true;
rdr_enabled_ = rdr_enable_env.value();
}
already_parsed_ = true;
auto path_env = GetRdrPathFromEnv();
if (path_env.has_value()) {
has_rdr_setting_ = true;
std::string path = path_env.value();
if (!path.empty()) {
rdr_path_ = path;
}
}
}
void EnvConfigParser::ParseFromFile() {
auto context = MsContext::GetInstance();
MS_EXCEPTION_IF_NULL(context);
auto config_file = context->get_param<std::string>(MS_CTX_ENV_CONFIG_PATH);
@ -92,10 +138,22 @@ void EnvConfigParser::Parse() {
std::string cfg = ss.str();
MS_LOG(INFO) << "Env config json:" << cfg;
// Parse rdr seetings from file
ParseRdrSetting(j);
ConfigToString();
}
void EnvConfigParser::Parse() {
std::lock_guard<std::mutex> guard(lock_);
if (already_parsed_) {
return;
}
already_parsed_ = true;
ParseFromEnv();
ParseFromFile();
}
void EnvConfigParser::ParseRdrSetting(const nlohmann::json &content) {
auto rdr_setting = content.find(kRdrSettings);
if (rdr_setting == content.end()) {
@ -142,7 +200,6 @@ void EnvConfigParser::ParseRdrEnable(const nlohmann::json &content) {
if (!content.is_boolean()) {
MS_LOG(WARNING) << "Json parse failed. 'enable' in " << kRdrSettings << " should be boolean."
<< " Please check the config file '" << config_file_ << "' set by 'env_config_path' in context.";
rdr_enabled_ = false;
return;
}
rdr_enabled_ = content;

View File

@ -32,11 +32,11 @@ class EnvConfigParser {
}
void Parse();
std::string config_path() const { return config_file_; }
std::string ConfigPath() const { return config_file_; }
bool has_rdr_setting() const { return has_rdr_setting_; }
bool rdr_enabled() const { return rdr_enabled_; }
std::string rdr_path() const { return rdr_path_; }
bool HasRdrSetting() const { return has_rdr_setting_; }
bool RdrEnabled() const { return rdr_enabled_; }
std::string RdrPath() const { return rdr_path_; }
private:
EnvConfigParser() {}
@ -50,6 +50,8 @@ class EnvConfigParser {
bool has_rdr_setting_{false};
std::string rdr_path_{"./rdr/"};
void ParseFromFile();
void ParseFromEnv();
std::string GetIfstreamString(const std::ifstream &ifstream);
void ParseRdrSetting(const nlohmann::json &content);

View File

@ -30,7 +30,7 @@ class BaseRecorder {
public:
BaseRecorder() : module_(""), name_(""), directory_(""), filename_(""), timestamp_("") {}
BaseRecorder(const std::string &module, const std::string &name) : module_(module), name_(name), filename_("") {
directory_ = mindspore::EnvConfigParser::GetInstance().rdr_path();
directory_ = mindspore::EnvConfigParser::GetInstance().RdrPath();
if (name.length() > maxNameLength) {
name_ = name.substr(0, maxNameLength);

View File

@ -25,11 +25,11 @@ void RecorderManager::UpdateRdrEnable() {
return;
}
auto &config_parser = mindspore::EnvConfigParser::GetInstance();
rdr_enable_ = config_parser.rdr_enabled();
if (config_parser.has_rdr_setting()) {
rdr_enable_ = config_parser.RdrEnabled();
if (config_parser.HasRdrSetting()) {
#ifdef __linux__
if (!rdr_enable_) {
MS_LOG(WARNING) << "Please set the 'enable' as true using 'rdr' setting in file '" << config_parser.config_path()
MS_LOG(WARNING) << "Please set the 'enable' as true using 'rdr' setting in file '" << config_parser.ConfigPath()
<< "' if you want to use RDR.";
}
#else