123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239 |
- /**
- * Licensed to the Apache Software Foundation (ASF) under one
- * or more contributor license agreements. See the NOTICE file
- * distributed with this work for additional information
- * regarding copyright ownership. The ASF licenses this file
- * to you under the Apache License, Version 2.0 (the
- * "License"); you may not use this file except in compliance
- * with the License. You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- */
- /**
- * @typedef {object} rmHaConfigDependencies
- * @property {string|number} webAddressPort
- * @property {string|number} httpsWebAddressPort
- * @property {string|number} zkClientPort
- */
- var App = require('app');
- var blueprintUtils = require('utils/blueprint');
- require('utils/configs/rm_ha_config_initializer');
- App.RMHighAvailabilityWizardStep3Controller = Em.Controller.extend(App.BlueprintMixin, {
- name: "rMHighAvailabilityWizardStep3Controller",
- selectedService: null,
- versionLoaded: true,
- hideDependenciesInfoBar: true,
- isLoaded: false,
- isSubmitDisabled: Em.computed.not('isLoaded'),
- loadStep: function () {
- this.renderConfigs();
- },
- /**
- * Render configs to show them in <code>App.ServiceConfigView</code>
- */
- renderConfigs: function () {
- var configs = $.extend(true, {}, require('data/HDP2/rm_ha_properties').haConfig);
- var serviceConfig = App.ServiceConfig.create({
- serviceName: configs.serviceName,
- displayName: configs.displayName,
- configCategories: [],
- showConfig: true,
- configs: []
- });
- configs.configCategories.forEach(function (configCategory) {
- if (App.Service.find().someProperty('serviceName', configCategory.name)) {
- serviceConfig.configCategories.pushObject(configCategory);
- }
- }, this);
- this.renderConfigProperties(configs, serviceConfig);
- App.ajax.send({
- name: 'config.tags',
- sender: this,
- success: 'loadConfigTagsSuccessCallback',
- error: 'loadConfigsErrorCallback',
- data: {
- serviceConfig: serviceConfig
- }
- });
- },
- loadConfigTagsSuccessCallback: function (data, opt, params) {
- var urlParams = '(type=zoo.cfg&tag=' + data.Clusters.desired_configs['zoo.cfg'].tag + ')|' +
- '(type=yarn-site&tag=' + data.Clusters.desired_configs['yarn-site'].tag + ')|' +
- '(type=yarn-env&tag=' + data.Clusters.desired_configs['yarn-env'].tag + ')';
- App.ajax.send({
- name: 'reassign.load_configs',
- sender: this,
- data: {
- urlParams: urlParams,
- serviceConfig: params.serviceConfig
- },
- success: 'loadConfigsSuccessCallback',
- error: 'loadConfigsSuccessCallback'
- });
- },
- loadConfigsSuccessCallback: function (data, opt, params) {
- var self = this;
- var blueprintConfigurations = Em.getWithDefault(data || {}, 'items', []).reduce(function(prev, cur) {
- prev[cur.type] = { properties: cur.properties };
- return prev;
- }, {});
- params = params.serviceConfig ? params.serviceConfig : arguments[4].serviceConfig;
- this.setDynamicConfigValues(params, data);
- this.loadRecommendations(blueprintConfigurations).always(function(recommendations) {
- self.applyRecommendedConfigurations(recommendations, data, params);
- self.setProperties({
- selectedService: params,
- isLoaded: true
- });
- });
- },
- /**
- * Get dependencies for new configs
- *
- * @param {{items: object[]}} data
- * @returns {rmHaConfigDependencies}
- * @private
- * @method _prepareDependencies
- */
- _prepareDependencies: function (data) {
- var ret = {};
- var zooCfg = data && data.items ? data.items.findProperty('type', 'zoo.cfg') : null;
- var yarnSite = data && data.items ? data.items.findProperty('type', 'yarn-site') : null;
- var portValue = zooCfg && Em.get(zooCfg, 'properties.clientPort');
- var webAddressPort = yarnSite && yarnSite.properties ? yarnSite.properties['yarn.resourcemanager.webapp.address'] : '';
- var httpsWebAddressPort = yarnSite && yarnSite.properties ? yarnSite. properties['yarn.resourcemanager.webapp.https.address'] : '';
- ret.webAddressPort = webAddressPort && webAddressPort.contains(':') ? webAddressPort.split(':')[1] : '8088';
- ret.httpsWebAddressPort = httpsWebAddressPort && httpsWebAddressPort.contains(':') ? httpsWebAddressPort.split(':')[1] : '8090';
- ret.zkClientPort = portValue ? portValue : '2181';
- return ret;
- },
- /**
- * Set values to the new configs
- *
- * @param {object} configs
- * @param {object} data
- * @returns {object}
- * @method setDynamicConfigValues
- */
- setDynamicConfigValues: function (configs, data) {
- var topologyLocalDB = this.get('content').getProperties(['masterComponentHosts', 'slaveComponentHosts', 'hosts']);
- var yarnUser = data.items.findProperty('type', 'yarn-env').properties.yarn_user;
- App.RmHaConfigInitializer.setup({
- yarnUser: yarnUser
- });
- var dependencies = this._prepareDependencies(data);
- // /** add dynamic property 'hadoop.proxyuser.' + yarnUser + '.hosts' **/
- // var proxyUserConfig = App.ServiceConfigProperty.create(App.config.createDefaultConfig('hadoop.proxyuser.' + yarnUser + '.hosts',
- // 'core-site', false, {category : "HDFS", isUserProperty: false, isEditable: false, isOverridable: false, serviceName: 'MISC'}));
- // configs.configs.pushObject(proxyUserConfig);
- configs.configs.forEach(function (config) {
- App.RmHaConfigInitializer.initialValue(config, topologyLocalDB, dependencies);
- });
- App.RmHaConfigInitializer.cleanup();
- return configs;
- },
- /**
- * Load child components to service config object
- * @param _componentConfig
- * @param componentConfig
- */
- renderConfigProperties: function (_componentConfig, componentConfig) {
- _componentConfig.configs.forEach(function (_serviceConfigProperty) {
- var serviceConfigProperty = App.ServiceConfigProperty.create(_serviceConfigProperty);
- componentConfig.configs.pushObject(serviceConfigProperty);
- serviceConfigProperty.set('isEditable', serviceConfigProperty.get('isReconfigurable'));
- }, this);
- },
- submit: function () {
- if (!this.get('isSubmitDisabled')) {
- App.get('router.mainAdminKerberosController').getKDCSessionState(function() {
- App.router.send("next");
- });
- }
- },
- loadRecommendations: function(blueprintConfigurations) {
- var dfd = $.Deferred();
- var blueprint = this.getCurrentMasterSlaveBlueprint();
- // host group where new ResourceManager will be added
- var hostGroupName = blueprintUtils.getHostGroupByFqdn(blueprint, this.get('content.rmHosts.additionalRM'));
- var dataToSend = {
- recommend: 'configurations',
- hosts: App.get('allHostNames'),
- services: App.Service.find().mapProperty('serviceName').uniq(),
- recommendations: {}
- };
- if (!!hostGroupName) {
- blueprintUtils.addComponentToHostGroup(blueprint, 'RESOURCEMANAGER', hostGroupName);
- }
- blueprint.blueprint.configurations = blueprintConfigurations;
- dataToSend.recommendations = blueprint;
- return App.ajax.send({
- name: 'config.recommendations',
- sender: this,
- data: {
- stackVersionUrl: App.get('stackVersionURL'),
- dataToSend: dataToSend
- }
- });
- },
- applyRecommendedConfigurations: function(recommendations, configurations, stepConfigs) {
- var yarnEnv = Em.getWithDefault(configurations || {}, 'items', []).findProperty('type', 'yarn-env') || {},
- yarnUser = Em.getWithDefault(yarnEnv, 'properties.yarn_user', false),
- coreSite = Em.getWithDefault(recommendations, 'resources.0.recommendations.blueprint.configurations.core-site.properties', {}),
- proxyHostName = 'hadoop.proxyuser.' + yarnUser + '.hosts',
- recommendedHosts = coreSite[proxyHostName] || false,
- newProp;
- if (yarnUser && recommendedHosts) {
- if (stepConfigs.get('configs').someProperty('name', proxyHostName)) {
- stepConfigs.get('configs').findProperty('name', proxyHostName).setProperties({
- recommendedValue: recommendedHosts,
- value: recommendedHosts
- });
- } else {
- newProp = App.config.createDefaultConfig(proxyHostName, 'core-site', false, {
- category : "HDFS",
- isUserProperty: false,
- isEditable: false,
- isOverridable: false,
- serviceName: 'MISC',
- value: recommendedHosts,
- recommendedValue: recommendedHosts
- });
- newProp.filename = App.config.getConfigTagFromFileName(newProp.filename);
- stepConfigs.get('configs').pushObject(App.ServiceConfigProperty.create(newProp));
- }
- }
- }
- });
|