123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172 |
- /**
- * 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.
- */
- var App = require('app');
- require('controllers/main/admin/serviceAccounts_controller');
- App.HighAvailabilityWizardStep4Controller = Em.Controller.extend({
- name:"highAvailabilityWizardStep4Controller",
- POLL_INTERVAL: 1000,
- isNextEnabled: false,
- isNameNodeStarted: true,
- pullCheckPointStatus: function () {
- var hostName = this.get('content.masterComponentHosts').findProperty('isCurNameNode', true).hostName;
- App.ajax.send({
- name: 'admin.high_availability.getNnCheckPointStatus',
- sender: this,
- data: {
- hostName: hostName
- },
- success: 'checkNnCheckPointStatus'
- });
- },
- checkNnCheckPointStatus: function (data) {
- if (data.HostRoles.desired_state === 'STARTED') {
- this.set('isNameNodeStarted', true);
- var self = this;
- var journalTransactionInfo = $.parseJSON(data.metrics.dfs.namenode.JournalTransactionInfo);
- var isInSafeMode = (data.metrics.dfs.namenode.Safemode != "");
- journalTransactionInfo = parseInt(journalTransactionInfo.LastAppliedOrWrittenTxId) - parseInt(journalTransactionInfo.MostRecentCheckpointTxId);
- if (journalTransactionInfo <= 1 && isInSafeMode) {
- this.set("isNextEnabled", true);
- return;
- }
- window.setTimeout(function () {
- self.pullCheckPointStatus()
- }, self.POLL_INTERVAL);
- } else {
- this.set('isNameNodeStarted', false);
- }
- },
- done: function () {
- if (this.get('isNextEnabled')) {
- App.router.send('next');
- }
- }
- });
|