]>
git.proxmox.com Git - pve-manager.git/blob - www/manager6/ceph/Status.js
1 Ext
.define('PVE.node.CephStatus', {
2 extend
: 'Ext.panel.Panel',
3 alias
: 'widget.pveNodeCephStatus',
5 onlineHelp
: 'chapter_pveceph',
22 title
: gettext('Health'),
24 plugins
: 'responsive',
42 itemId
: 'overallhealth',
43 xtype
: 'pveHealthWidget',
44 title
: gettext('Status')
50 stateId
: 'ceph-status-warnings',
52 // since we load the store manually,
53 // to show the emptytext, we have to
54 // specify an empty store
56 emptyText
: gettext('No Warnings/Errors'),
59 dataIndex
: 'severity',
60 header
: gettext('Severity'),
63 renderer: function(value
) {
64 var health
= PVE
.Utils
.map_ceph_health
[value
];
65 var classes
= PVE
.Utils
.get_health_icon(health
);
67 return '<i class="fa fa-fw ' + classes
+ '"></i>';
70 sorterFn: function(a
,b
) {
71 var healthArr
= ['HEALTH_ERR', 'HEALTH_WARN', 'HEALTH_OK'];
72 return healthArr
.indexOf(b
.data
.severity
) - healthArr
.indexOf(a
.data
.severity
);
78 header
: gettext('Summary'),
82 xtype
: 'actioncolumn',
85 tooltip
: gettext('Detail'),
88 iconCls
: 'x-fa fa-info-circle',
89 handler: function(grid
, rowindex
, colindex
, item
, e
, record
) {
90 var win
= Ext
.create('Ext.window.Window', {
91 title
: gettext('Detail'),
104 '<span>' + Ext
.htmlEncode(record
.data
.summary
) + '</span>',
105 '<pre>' + Ext
.htmlEncode(record
.data
.detail
) + '</pre>'
119 xtype
: 'pveCephStatusDetail',
120 itemId
: 'statusdetail',
121 plugins
: 'responsive',
132 title
: gettext('Status')
135 title
: gettext('Services'),
136 xtype
: 'pveCephServices',
138 plugins
: 'responsive',
156 title
: gettext('Performance'),
166 xtype
: 'proxmoxGauge',
168 title
: gettext('Usage')
180 xtype
: 'pveRunningChart',
181 title
: gettext('Reads'),
182 renderer
: PVE
.Utils
.render_bandwidth
186 xtype
: 'pveRunningChart',
187 title
: gettext('Writes'),
188 renderer
: PVE
.Utils
.render_bandwidth
192 xtype
: 'pveRunningChart',
194 title
: 'IOPS', // do not localize
195 renderer
: Ext
.util
.Format
.numberRenderer('0,000')
199 xtype
: 'pveRunningChart',
201 title
: 'IOPS: ' + gettext('Reads'),
202 renderer
: Ext
.util
.Format
.numberRenderer('0,000')
206 xtype
: 'pveRunningChart',
208 title
: 'IOPS: ' + gettext('Writes'),
209 renderer
: Ext
.util
.Format
.numberRenderer('0,000')
217 generateCheckData: function(health
) {
219 var checks
= health
.checks
|| {};
220 var keys
= Ext
.Object
.getKeys(checks
).sort();
222 Ext
.Array
.forEach(keys
, function(key
) {
223 var details
= checks
[key
].detail
|| [];
226 summary
: checks
[key
].summary
.message
,
227 detail
: Ext
.Array
.reduce(
229 function(first
, second
) {
230 return first
+ '\n' + second
.message
;
234 severity
: checks
[key
].severity
241 updateAll: function(store
, records
, success
) {
242 if (!success
|| records
.length
=== 0) {
247 var rec
= records
[0];
248 me
.status
= rec
.data
;
251 me
.down('#overallhealth').updateHealth(PVE
.Utils
.render_ceph_health(rec
.data
.health
|| {}));
252 // add errors to gridstore
253 me
.down('#warnings').getStore().loadRawData(me
.generateCheckData(rec
.data
.health
|| {}), false);
256 me
.getComponent('services').updateAll(me
.metadata
|| {}, rec
.data
);
258 // update detailstatus panel
259 me
.getComponent('statusdetail').updateAll(me
.metadata
|| {}, rec
.data
);
261 // add performance data
262 var used
= rec
.data
.pgmap
.bytes_used
;
263 var total
= rec
.data
.pgmap
.bytes_total
;
265 var text
= Ext
.String
.format(gettext('{0} of {1}'),
266 PVE
.Utils
.render_size(used
),
267 PVE
.Utils
.render_size(total
)
270 // update the usage widget
271 me
.down('#space').updateValue(used
/total
, text
);
273 // TODO: logic for jewel (iops splitted in read/write)
275 var iops
= rec
.data
.pgmap
.op_per_sec
;
276 var readiops
= rec
.data
.pgmap
.read_op_per_sec
;
277 var writeiops
= rec
.data
.pgmap
.write_op_per_sec
;
278 var reads
= rec
.data
.pgmap
.read_bytes_sec
|| 0;
279 var writes
= rec
.data
.pgmap
.write_bytes_sec
|| 0;
281 if (iops
!== undefined && me
.version
!== 'hammer') {
282 me
.change_version('hammer');
283 } else if((readiops
!== undefined || writeiops
!== undefined) && me
.version
!== 'jewel') {
284 me
.change_version('jewel');
287 me
.reads
.addDataPoint(reads
);
288 me
.writes
.addDataPoint(writes
);
289 me
.iops
.addDataPoint(iops
);
290 me
.readiops
.addDataPoint(readiops
);
291 me
.writeiops
.addDataPoint(writeiops
);
294 change_version: function(version
) {
296 me
.version
= version
;
297 me
.sp
.set('ceph-version', version
);
298 me
.iops
.setVisible(version
=== 'hammer');
299 me
.readiops
.setVisible(version
=== 'jewel');
300 me
.writeiops
.setVisible(version
=== 'jewel');
303 initComponent: function() {
306 var nodename
= me
.pveSelNode
.data
.node
;
309 var baseurl
= '/api2/json' + (nodename
? '/nodes/' + nodename
: '/cluster') + '/ceph/';
310 me
.store
= Ext
.create('Proxmox.data.UpdateStore', {
311 storeid
: 'ceph-status-' + (nodename
|| 'cluster'),
315 url
: baseurl
+ '/status'
319 me
.metadatastore
= Ext
.create('Proxmox.data.UpdateStore', {
320 storeid
: 'ceph-metadata-' + (nodename
|| 'cluster'),
324 url
: baseurl
+ 'metadata'
328 // save references for the updatefunction
329 me
.iops
= me
.down('#iops');
330 me
.readiops
= me
.down('#readiops');
331 me
.writeiops
= me
.down('#writeiops');
332 me
.reads
= me
.down('#reads');
333 me
.writes
= me
.down('#writes');
336 me
.sp
= Ext
.state
.Manager
.getProvider();
337 me
.version
= me
.sp
.get('ceph-version');
338 me
.change_version(me
.version
);
340 var regex
= new RegExp("not (installed|initialized)", "i");
341 PVE
.Utils
.handleStoreErrorOrMask(me
, me
.store
, regex
, function(me
, error
){
342 me
.store
.stopUpdate();
343 PVE
.Utils
.showCephInstallOrMask(me
, error
.statusText
, (nodename
|| 'localhost'),
345 me
.mon(win
, 'cephInstallWindowClosed', function(){
346 me
.store
.startUpdate();
352 me
.mon(me
.store
, 'load', me
.updateAll
, me
);
353 me
.mon(me
.metadatastore
, 'load', function(store
, records
, success
) {
354 if (!success
|| records
.length
< 1) {
357 var rec
= records
[0];
358 me
.metadata
= rec
.data
;
361 me
.getComponent('services').updateAll(rec
.data
, me
.status
|| {});
363 // update detailstatus panel
364 me
.getComponent('statusdetail').updateAll(rec
.data
, me
.status
|| {});
368 me
.on('destroy', me
.store
.stopUpdate
);
369 me
.on('destroy', me
.metadatastore
.stopUpdate
);
370 me
.store
.startUpdate();
371 me
.metadatastore
.startUpdate();