Kylin配置文件加载源码解读

原创
2019/06/20 09:38
阅读数 755

配置文件的加载是在类AdminService中。

我们来看下前后端是如何调用的:

1. getEnv(前端)

$scope.getEnv = function () {
    AdminService.env({}, function (env) {
      $scope.envStr = env.env;
      MessageService.sendMsg('Server environment get successfully', 'success', {});
//            SweetAlert.swal('Success!', 'Server environment get successfully', 'success');
    }, function (e) {
      if (e.data && e.data.exception) {
        var message = e.data.exception;
        var msg = !!(message) ? message : 'Failed to take action.';
        SweetAlert.swal('Oops...', msg, 'error');
      } else {
        SweetAlert.swal('Oops...', "Failed to take action.", 'error');
      }
    });
  }

2. getConfig(前端)


$scope.getConfig = function () {
  AdminService.config({}, function (config) {
    $scope.configStr = config.config;
    MessageService.sendMsg('Server config get successfully', 'success', {});
  }, function (e) {
    if (e.data && e.data.exception) {
      var message = e.data.exception;
      var msg = !!(message) ? message : 'Failed to take action.';
      SweetAlert.swal('Oops...', msg, 'error');
    } else {
      SweetAlert.swal('Oops...', "Failed to take action.", 'error');
    }
  });
}

AdminService类中包含了环境变量加载和配置文件的加载更新等

上面两个前端的方法分别对应后台的getEnv和getPublicConfig方法

1.getEnv方法则是System.getenv();然后将所有的环境变量设置到OrderedProperties中,然后封装到PropertiesConfiguration中,PropertiesConfiguration对象的实例会使用OutputStreamWriter(ByteArrayOutputStream)将环境变量写入到流中,所以genEnv的作用是将系统环境变量读取后写入到流中。

2.getPublicConfig方法

public String getPublicConfig() throws IOException {
        final String whiteListProperties = KylinConfig.getInstanceFromEnv().getPropertiesWhiteList();

        Collection<String> propertyKeys = Lists.newArrayList();
        if (StringUtils.isNotEmpty(whiteListProperties)) {
            propertyKeys.addAll(Arrays.asList(whiteListProperties.split(",")));
        }

        return KylinConfig.getInstanceFromEnv().exportToString(propertyKeys);
    }

第一步getInstanceFromEnv:方法中会调用reloadKylinConfig(buildSiteProperties()),buildSiteProperties会调用buildSiteOrderedProps,这个方法首先从classpath加载kylin-defaults.properties(kylin/core-common/src/main/resources )。

第二步加载kylin.properties(会读取KYLIN_HOME)。

第三步想要覆盖这个文件,后缀需要为.override,就是kylin.properties.override 界面上看到的所有属性就是KylinConfig.getInstanceFromEnv().exportToString(propertyKeys);返回值

展开阅读全文
加载中

作者的其它热门文章

打赏
1
1 收藏
分享
打赏
1 评论
1 收藏
1
分享
返回顶部
顶部