services_mapper.js 14 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306
  1. /**
  2. * Licensed to the Apache Software Foundation (ASF) under one or more
  3. * contributor license agreements. See the NOTICE file distributed with this
  4. * work for additional information regarding copyright ownership. The ASF
  5. * licenses this file to you under the Apache License, Version 2.0 (the
  6. * "License"); you may not use this file except in compliance with the License.
  7. * You may obtain a copy of the License at
  8. *
  9. * http://www.apache.org/licenses/LICENSE-2.0
  10. *
  11. * Unless required by applicable law or agreed to in writing, software
  12. * distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
  13. * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
  14. * License for the specific language governing permissions and limitations under
  15. * the License.
  16. */
  17. App.servicesMapper = App.QuickDataMapper.create({
  18. model:App.Service,
  19. servicesSortOrder: [
  20. 'HDFS',
  21. 'MAPREDUCE',
  22. 'HBASE',
  23. 'HIVE',
  24. 'OOZIE',
  25. 'GANGLIA',
  26. 'NAGIOS',
  27. 'PIG',
  28. 'SQOOP'
  29. ],
  30. sortByOrder: function (sortOrder, array) {
  31. var sorted = [];
  32. for (var i = 0; i < sortOrder.length; i++)
  33. for (var j = 0; j < array.length; j++) {
  34. if (sortOrder[i] == array[j].id) {
  35. sorted.push(array[j]);
  36. }
  37. }
  38. return sorted;
  39. },
  40. config:{
  41. id:'ServiceInfo.service_name',
  42. service_name:'ServiceInfo.service_name',
  43. $work_status:'DEAD',
  44. $service_audit:[ 1, 2, 3 ],
  45. $alerts:[ 1, 2, 3 ],
  46. components_key:'components',
  47. components_type:'array',
  48. components:{
  49. item:'ServiceComponentInfo.component_name'
  50. },
  51. host_components:'host_components'
  52. },
  53. hdfsConfig:{
  54. version:'nameNodeComponent.ServiceComponentInfo.Version',
  55. name_node_id:'nameNodeComponent.host_components[0].HostRoles.host_name',
  56. sname_node_id:'snameNodeComponent.host_components[0].HostRoles.host_name',
  57. data_nodes:'data_nodes',
  58. name_node_start_time:'nameNodeComponent.ServiceComponentInfo.StartTime',
  59. jvm_memory_heap_used:'nameNodeComponent.host_components[0].metrics.jvm.memHeapUsedM',
  60. jvm_memory_heap_committed:'nameNodeComponent.host_components[0].metrics.jvm.memHeapCommittedM',
  61. live_data_nodes:'live_data_nodes',
  62. dead_data_nodes:'dead_data_nodes',
  63. decommision_data_nodes:'decommission_data_nodes',
  64. capacity_used:'nameNodeComponent.ServiceComponentInfo.CapacityUsed',
  65. capacity_total:'nameNodeComponent.ServiceComponentInfo.CapacityTotal',
  66. dfs_total_blocks:'nameNodeComponent.host_components[0].metrics.dfs.FSNamesystem.BlocksTotal',
  67. dfs_corrupt_blocks:'nameNodeComponent.host_components[0].metrics.dfs.FSNamesystem.CorruptBlocks',
  68. dfs_missing_blocks:'nameNodeComponent.host_components[0].metrics.dfs.FSNamesystem.MissingBlocks',
  69. dfs_under_replicated_blocks:'nameNodeComponent.host_components[0].metrics.dfs.FSNamesystem.UnderReplicatedBlocks',
  70. dfs_total_files:'nameNodeComponent.host_components[0].metrics.dfs.FSNamesystem.FilesTotal',
  71. upgrade_status:'nameNodeComponent.ServiceComponentInfo.UpgradeFinalized',
  72. safe_mode_status:'nameNodeComponent.ServiceComponentInfo.Safemode'
  73. },
  74. mapReduceConfig:{
  75. version:'jobTrackerComponent.ServiceComponentInfo.Version',
  76. job_tracker_id:'jobTrackerComponent.host_components[0].HostRoles.host_name',
  77. task_trackers:'task_trackers',
  78. job_tracker_start_time:'jobTrackerComponent.ServiceComponentInfo.StartTime',
  79. job_tracker_heap_used:'jobTrackerComponent.ServiceComponentInfo.HeapMemoryUsed',
  80. job_tracker_heap_max:'jobTrackerComponent.ServiceComponentInfo.HeapMemoryMax',
  81. alive_trackers:'alive_trackers',
  82. black_list_trackers:'black_list_trackers',
  83. gray_list_trackers:'gray_list_trackers',
  84. map_slots:'map_slots',
  85. reduce_slots:'reduce_slots',
  86. jobs_submitted:'jobTrackerComponent.host_components[0].metrics.mapred.jobtracker.jobs_submitted',
  87. jobs_completed:'jobTrackerComponent.host_components[0].metrics.mapred.jobtracker.jobs_completed',
  88. map_slots_occupied:'jobTrackerComponent.host_components[0].metrics.mapred.jobtracker.occupied_map_slots',
  89. map_slots_reserved:'jobTrackerComponent.host_components[0].metrics.mapred.jobtracker.reserved_map_slots',
  90. reduce_slots_occupied:'jobTrackerComponent.host_components[0].metrics.mapred.jobtracker.occupied_reduce_slots',
  91. reduce_slots_reserved:'jobTrackerComponent.host_components[0].metrics.mapred.jobtracker.reserved_reduce_slots',
  92. maps_running:'jobTrackerComponent.host_components[0].metrics.mapred.jobtracker.running_maps',
  93. maps_waiting:'jobTrackerComponent.host_components[0].metrics.mapred.jobtracker.waiting_maps',
  94. reduces_running:'jobTrackerComponent.host_components[0].metrics.mapred.jobtracker.running_reduces',
  95. reduces_waiting:'jobTrackerComponent.host_components[0].metrics.mapred.jobtracker.waiting_reduces',
  96. trackers_decommisioned:'jobTrackerComponent.host_components[0].metrics.mapred.jobtracker.trackers_decommissioned'
  97. },
  98. hbaseConfig:{
  99. version:'masterComponent.ServiceComponentInfo.Version',
  100. master_id:'masterComponent.host_components[0].HostRoles.host_name',
  101. region_servers:'region_servers',
  102. master_start_time:'masterComponent.ServiceComponentInfo.MasterStartTime',
  103. master_active_time:'masterComponent.ServiceComponentInfo.MasterActiveTime',
  104. average_load:'masterComponent.ServiceComponentInfo.AverageLoad',
  105. regions_in_transition:'regions_in_transition',
  106. revision:'masterComponent.ServiceComponentInfo.Revision',
  107. heap_memory_used:'masterComponent.ServiceComponentInfo.HeapMemoryUsed',
  108. heap_memory_max:'masterComponent.ServiceComponentInfo.HeapMemoryMax'
  109. },
  110. model2:App.Component,
  111. config2:{
  112. id:'ServiceComponentInfo.component_name',
  113. component_name:'ServiceComponentInfo.component_name',
  114. service_id:'ServiceComponentInfo.service_name',
  115. work_status:'host_components[0].HostRoles.state',
  116. host_id:'host_components[0].HostRoles.host_name',
  117. $decommissioned:false
  118. },
  119. model3:App.HostComponent,
  120. config3:{
  121. id:'id',
  122. work_status:'HostRoles.state',
  123. component_name:'HostRoles.component_name',
  124. host_id:'HostRoles.host_name',
  125. service_id:'component[0].ServiceComponentInfo.service_name'
  126. },
  127. map:function (json) {
  128. if (!this.get('model')) {
  129. return;
  130. }
  131. if (json.items) {
  132. var result = [];
  133. json.items.forEach(function (item) {
  134. var finalConfig = jQuery.extend({}, this.config);
  135. item.host_components = [];
  136. item.components.forEach(function (component) {
  137. component.host_components.forEach(function (host_component) {
  138. host_component.id = host_component.HostRoles.component_name + "_" + host_component.HostRoles.host_name;
  139. item.host_components.push(host_component.id);
  140. }, this)
  141. }, this);
  142. if (item && item.ServiceInfo && item.ServiceInfo.service_name == "HDFS") {
  143. // Change the JSON so that it is easy to map
  144. var hdfsConfig = this.hdfsConfig;
  145. item.components.forEach(function (component) {
  146. if (component.ServiceComponentInfo && component.ServiceComponentInfo.component_name == "NAMENODE") {
  147. item.nameNodeComponent = component;
  148. finalConfig = jQuery.extend(finalConfig, hdfsConfig);
  149. // Get the live, dead & decommision nodes from string json
  150. var liveNodesJson = jQuery.parseJSON(component.ServiceComponentInfo.LiveNodes);
  151. var deadNodesJson = jQuery.parseJSON(component.ServiceComponentInfo.DeadNodes);
  152. var decommisionNodesJson = jQuery.parseJSON(component.ServiceComponentInfo.DecomNodes);
  153. item.live_data_nodes = [];
  154. item.dead_data_nodes = [];
  155. item.decommision_data_nodes = [];
  156. for (var ln in liveNodesJson) {
  157. item.live_data_nodes.push(ln);
  158. }
  159. for (var dn in deadNodesJson) {
  160. item.dead_data_nodes.push(dn);
  161. }
  162. for (var dcn in decommisionNodesJson) {
  163. item.decommision_data_nodes.push(dcn);
  164. }
  165. }
  166. if (component.ServiceComponentInfo && component.ServiceComponentInfo.component_name == "SECONDARY_NAMENODE") {
  167. item.snameNodeComponent = component;
  168. }
  169. if (component.ServiceComponentInfo && component.ServiceComponentInfo.component_name == "DATANODE") {
  170. if (!item.data_nodes) {
  171. item.data_nodes = [];
  172. }
  173. if (component.host_components) {
  174. component.host_components.forEach(function (hc) {
  175. item.data_nodes.push(hc.HostRoles.host_name);
  176. });
  177. }
  178. }
  179. });
  180. // Map
  181. var finalJson = this.parseIt(item, finalConfig);
  182. finalJson.quick_links = [1, 2, 3, 4];
  183. result.push(finalJson);
  184. App.store.load(App.HDFSService, finalJson);
  185. } else if (item && item.ServiceInfo && item.ServiceInfo.service_name == "MAPREDUCE") {
  186. // Change the JSON so that it is easy to map
  187. var mapReduceConfig = this.mapReduceConfig;
  188. item.components.forEach(function (component) {
  189. if (component.ServiceComponentInfo && component.ServiceComponentInfo.component_name == "JOBTRACKER") {
  190. item.jobTrackerComponent = component;
  191. finalConfig = jQuery.extend(finalConfig, mapReduceConfig);
  192. // Get the live, gray & black nodes from string json
  193. item.map_slots = 0;
  194. item.reduce_slots = 0;
  195. var liveNodesJson = jQuery.parseJSON(component.ServiceComponentInfo.AliveNodes);
  196. var grayNodesJson = jQuery.parseJSON(component.ServiceComponentInfo.GrayListedNodes);
  197. var blackNodesJson = jQuery.parseJSON(component.ServiceComponentInfo.BlackListedNodes);
  198. item.alive_trackers = [];
  199. item.gray_list_trackers = [];
  200. item.black_list_trackers = [];
  201. if (liveNodesJson != null) {
  202. liveNodesJson.forEach(function (nj) {
  203. item.alive_trackers.push(nj.hostname);
  204. if (nj.slots && nj.slots.map_slots)
  205. item.map_slots += nj.slots.map_slots;
  206. if (nj.slots && nj.slots.map_slots_used)
  207. item.map_slots_used += nj.slots.map_slots_used;
  208. if (nj.slots && nj.slots.reduce_slots)
  209. item.reduce_slots += nj.slots.reduce_slots;
  210. if (nj.slots && nj.slots.reduce_slots_used)
  211. item.reduce_slots_used += nj.slots.reduce_slots_used;
  212. });
  213. }
  214. if (grayNodesJson != null) {
  215. grayNodesJson.forEach(function (nj) {
  216. item.gray_list_trackers.push(nj.hostname);
  217. });
  218. }
  219. if (blackNodesJson != null) {
  220. blackNodesJson.forEach(function (nj) {
  221. item.black_list_trackers.push(nj.hostname);
  222. });
  223. }
  224. }
  225. if (component.ServiceComponentInfo && component.ServiceComponentInfo.component_name == "TASKTRACKER") {
  226. if (!item.task_trackers) {
  227. item.task_trackers = [];
  228. }
  229. if (component.host_components) {
  230. component.host_components.forEach(function (hc) {
  231. item.task_trackers.push(hc.HostRoles.host_name);
  232. });
  233. }
  234. }
  235. });
  236. // Map
  237. finalJson = this.parseIt(item, finalConfig);
  238. finalJson.quick_links = [5, 6, 7, 8, 9, 10, 11, 12];
  239. result.push(finalJson);
  240. App.store.load(App.MapReduceService, finalJson);
  241. } else if (item && item.ServiceInfo && item.ServiceInfo.service_name == "HBASE") {
  242. // Change the JSON so that it is easy to map
  243. var hbaseConfig = this.hbaseConfig;
  244. item.components.forEach(function (component) {
  245. if (component.ServiceComponentInfo && component.ServiceComponentInfo.component_name == "HBASE_MASTER") {
  246. item.masterComponent = component;
  247. finalConfig = jQuery.extend(finalConfig, hbaseConfig);
  248. var regionsArray = jQuery.parseJSON(component.ServiceComponentInfo.RegionsInTransition);
  249. item.regions_in_transition = regionsArray == null ? 0 : regionsArray.length;
  250. }
  251. if (component.ServiceComponentInfo && component.ServiceComponentInfo.component_name == "HBASE_REGIONSERVER") {
  252. if (!item.region_servers) {
  253. item.region_servers = [];
  254. }
  255. if (component.host_components) {
  256. component.host_components.forEach(function (hc) {
  257. item.region_servers.push(hc.HostRoles.host_name);
  258. });
  259. }
  260. }
  261. });
  262. // Map
  263. finalJson = this.parseIt(item, finalConfig);
  264. finalJson.quick_links = [13, 14, 15, 16, 17, 18];
  265. result.push(finalJson);
  266. App.store.load(App.HBaseService, finalJson);
  267. } else {
  268. result.push(this.parseIt(item, this.config));
  269. }
  270. }, this);
  271. result = this.sortByOrder(this.get('servicesSortOrder'), result);
  272. App.store.loadMany(this.get('model'), result);
  273. result = [];
  274. json.items.forEach(function (item) {
  275. item.components.forEach(function (component) {
  276. result.push(this.parseIt(component, this.config2));
  277. }, this)
  278. }, this);
  279. App.store.loadMany(this.get('model2'), result);
  280. result = [];
  281. json.items.forEach(function (item) {
  282. item.components.forEach(function (component) {
  283. component.host_components.forEach(function (host_component) {
  284. result.push(this.parseIt(host_component, this.config3));
  285. }, this)
  286. }, this)
  287. }, this);
  288. App.store.loadMany(this.get('model3'), result);
  289. }
  290. }
  291. });