Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Submit feedback
Contribute to GitLab
Sign in
Toggle navigation
P
pve-manager
Project
Project
Details
Activity
Releases
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
Administrator
pve-manager
Commits
ccc4eb52
Commit
ccc4eb52
authored
Nov 19, 2013
by
Dietmar Maurer
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
add OSD tree
parent
f87a42de
Changes
2
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
242 additions
and
4 deletions
+242
-4
Ceph.pm
PVE/API2/Ceph.pm
+76
-0
Ceph.js
www/manager/node/Ceph.js
+166
-4
No files found.
PVE/API2/Ceph.pm
View file @
ccc4eb52
...
@@ -860,6 +860,82 @@ __PACKAGE__->register_method ({
...
@@ -860,6 +860,82 @@ __PACKAGE__->register_method ({
return
&
$run_ceph_cmd_json
(['
status
'],
quiet
=>
1
);
return
&
$run_ceph_cmd_json
(['
status
'],
quiet
=>
1
);
}});
}});
__PACKAGE__
->
register_method
({
name
=>
'
listosd
',
path
=>
'
osd
',
method
=>
'
GET
',
description
=>
"
Get Ceph osd list/tree.
",
proxyto
=>
'
node
',
protected
=>
1
,
parameters
=>
{
additionalProperties
=>
0
,
properties
=>
{
node
=>
get_standard_option
('
pve-node
'),
},
},
returns
=>
{
type
=>
"
object
",
},
code
=>
sub
{
my
(
$param
)
=
@_
;
&
$check_ceph_inited
();
my
$res
=
&
$run_ceph_cmd_json
(['
osd
',
'
tree
'],
quiet
=>
1
);
die
"
no tree nodes found
\n
"
if
!
(
$res
&&
$res
->
{
nodes
});
my
$nodes
=
{};
my
$newnodes
=
{};
foreach
my
$e
(
@
{
$res
->
{
nodes
}})
{
$nodes
->
{
$e
->
{
id
}}
=
$e
;
my
$new
=
{
id
=>
$e
->
{
id
},
name
=>
$e
->
{
name
},
type
=>
$e
->
{
type
}
};
foreach
my
$opt
(
qw(status crush_weight reweight)
)
{
$new
->
{
$opt
}
=
$e
->
{
$opt
}
if
defined
(
$e
->
{
$opt
});
}
$newnodes
->
{
$e
->
{
id
}}
=
$new
;
}
foreach
my
$e
(
@
{
$res
->
{
nodes
}})
{
my
$new
=
$newnodes
->
{
$e
->
{
id
}};
if
(
$e
->
{
children
}
&&
scalar
(
@
{
$e
->
{
children
}}))
{
$new
->
{
children
}
=
[]
;
$new
->
{
leaf
}
=
0
;
foreach
my
$cid
(
@
{
$e
->
{
children
}})
{
$nodes
->
{
$cid
}
->
{
parent
}
=
$e
->
{
id
};
if
(
$nodes
->
{
$cid
}
->
{
type
}
eq
'
osd
'
&&
$e
->
{
type
}
eq
'
host
')
{
$newnodes
->
{
$cid
}
->
{
host
}
=
$e
->
{
name
};
}
push
@
{
$new
->
{
children
}},
$newnodes
->
{
$cid
};
}
}
else
{
$new
->
{
leaf
}
=
(
$e
->
{
id
}
>=
0
)
?
1
:
0
;
}
}
my
$rootnode
;
foreach
my
$e
(
@
{
$res
->
{
nodes
}})
{
if
(
!
$nodes
->
{
$e
->
{
id
}}
->
{
parent
})
{
$rootnode
=
$newnodes
->
{
$e
->
{
id
}};
last
;
}
}
die
"
no root node
\n
"
if
!
$rootnode
;
my
$data
=
{
root
=>
$rootnode
};
return
$data
;
}});
__PACKAGE__
->
register_method
({
__PACKAGE__
->
register_method
({
name
=>
'
createosd
',
name
=>
'
createosd
',
path
=>
'
osd
',
path
=>
'
osd
',
...
...
www/manager/node/Ceph.js
View file @
ccc4eb52
Ext
.
define
(
'
PVE.node.CephOsdTree
'
,
{
extend
:
'
Ext.tree.Panel
'
,
alias
:
'
widget.pveNodeCephOsdTree
'
,
initComponent
:
function
()
{
var
me
=
this
;
var
nodename
=
me
.
pveSelNode
.
data
.
node
;
if
(
!
nodename
)
{
throw
"
no node name specified
"
;
}
var
sm
=
Ext
.
create
(
'
Ext.selection.TreeModel
'
,
{});
var
service_cmd
=
function
(
cmd
)
{
var
rec
=
sm
.
getSelection
()[
0
];
if
(
!
(
rec
&&
rec
.
data
.
name
&&
rec
.
data
.
host
))
{
return
;
}
PVE
.
Utils
.
API2Request
({
url
:
"
/nodes/
"
+
rec
.
data
.
host
+
"
/ceph/
"
+
cmd
,
params
:
{
service
:
rec
.
data
.
name
},
waitMsgTarget
:
me
,
method
:
'
POST
'
,
failure
:
function
(
response
,
opts
)
{
Ext
.
Msg
.
alert
(
gettext
(
'
Error
'
),
response
.
htmlStatus
);
}
});
}
var
start_btn
=
new
Ext
.
Button
({
text
:
gettext
(
'
Start
'
),
disabled
:
true
,
handler
:
function
(){
service_cmd
(
'
start
'
);
}
});
var
stop_btn
=
new
Ext
.
Button
({
text
:
gettext
(
'
Stop
'
),
disabled
:
true
,
handler
:
function
(){
service_cmd
(
'
stop
'
);
}
});
var
remove_btn
=
new
Ext
.
Button
({
text
:
gettext
(
'
Remove
'
),
disabled
:
true
,
handler
:
function
(){
var
rec
=
sm
.
getSelection
()[
0
];
if
(
!
(
rec
&&
(
rec
.
data
.
id
>=
0
)
&&
rec
.
data
.
host
))
{
return
;
}
PVE
.
Utils
.
API2Request
({
url
:
"
/nodes/
"
+
rec
.
data
.
host
+
"
/ceph/osd/
"
+
rec
.
data
.
id
,
waitMsgTarget
:
me
,
method
:
'
DELETE
'
,
failure
:
function
(
response
,
opts
)
{
Ext
.
Msg
.
alert
(
gettext
(
'
Error
'
),
response
.
htmlStatus
);
}
});
}
});
var
set_button_status
=
function
()
{
var
rec
=
sm
.
getSelection
()[
0
];
if
(
!
rec
)
{
start_btn
.
setDisabled
(
true
);
stop_btn
.
setDisabled
(
true
);
remove_btn
.
setDisabled
(
true
);
return
;
}
var
isOsd
=
(
rec
.
data
.
host
&&
(
rec
.
data
.
type
===
'
osd
'
)
&&
(
rec
.
data
.
id
>=
0
));
start_btn
.
setDisabled
(
!
(
isOsd
&&
(
rec
.
data
.
status
!==
'
up
'
)));
stop_btn
.
setDisabled
(
!
(
isOsd
&&
(
rec
.
data
.
status
!==
'
down
'
)));
remove_btn
.
setDisabled
(
!
(
isOsd
&&
(
rec
.
data
.
status
===
'
down
'
)));
};
sm
.
on
(
'
selectionchange
'
,
set_button_status
);
var
reload
=
function
()
{
PVE
.
Utils
.
API2Request
({
url
:
"
/nodes/
"
+
nodename
+
"
/ceph/osd
"
,
waitMsgTarget
:
me
,
method
:
'
GET
'
,
failure
:
function
(
response
,
opts
)
{
PVE
.
Utils
.
setErrorMask
(
me
,
response
.
htmlStatus
);
},
success
:
function
(
response
,
opts
)
{
sm
.
deselectAll
();
me
.
setRootNode
(
response
.
result
.
data
.
root
);
me
.
expandAll
();
set_button_status
();
}
});
};
var
reload_btn
=
new
Ext
.
Button
({
text
:
gettext
(
'
Reload
'
),
handler
:
reload
});
Ext
.
apply
(
me
,
{
tbar
:
[
reload_btn
,
start_btn
,
stop_btn
,
remove_btn
],
rootVisible
:
false
,
fields
:
[
'
name
'
,
'
type
'
,
'
status
'
,
'
host
'
,
{
type
:
'
integre
'
,
name
:
'
id
'
},
{
type
:
'
number
'
,
name
:
'
reweight
'
},
{
type
:
'
number
'
,
name
:
'
crush_weight
'
}],
stateful
:
false
,
selModel
:
sm
,
columns
:
[
{
xtype
:
'
treecolumn
'
,
text
:
'
Name
'
,
dataIndex
:
'
name
'
,
width
:
200
},
{
text
:
'
ID
'
,
dataIndex
:
'
id
'
,
align
:
'
right
'
,
width
:
60
},
{
text
:
'
weight
'
,
dataIndex
:
'
crush_weight
'
,
align
:
'
right
'
,
width
:
60
},
{
text
:
'
Type
'
,
dataIndex
:
'
type
'
,
align
:
'
right
'
,
width
:
100
},
{
text
:
'
Status
'
,
dataIndex
:
'
status
'
,
align
:
'
right
'
,
width
:
100
},
{
text
:
'
reweight
'
,
dataIndex
:
'
reweight
'
,
align
:
'
right
'
,
width
:
60
}
],
listeners
:
{
show
:
function
()
{
console
.
log
(
"
RELOAD
"
);
reload
();
}
}
});
me
.
callParent
();
reload
();
}
});
Ext
.
define
(
'
PVE.node.CephDiskList
'
,
{
Ext
.
define
(
'
PVE.node.CephDiskList
'
,
{
extend
:
'
Ext.grid.GridPanel
'
,
extend
:
'
Ext.grid.GridPanel
'
,
alias
:
'
widget.pveNodeCephDiskList
'
,
alias
:
'
widget.pveNodeCephDiskList
'
,
...
@@ -34,8 +198,6 @@ Ext.define('PVE.node.CephDiskList', {
...
@@ -34,8 +198,6 @@ Ext.define('PVE.node.CephDiskList', {
handler
:
function
()
{
handler
:
function
()
{
var
rec
=
sm
.
getSelection
()[
0
];
var
rec
=
sm
.
getSelection
()[
0
];
console
.
log
(
"
CREATEOSD
"
+
rec
.
data
.
dev
);
PVE
.
Utils
.
API2Request
({
PVE
.
Utils
.
API2Request
({
url
:
"
/nodes/
"
+
nodename
+
"
/ceph/osd
"
,
url
:
"
/nodes/
"
+
nodename
+
"
/ceph/osd
"
,
method
:
'
POST
'
,
method
:
'
POST
'
,
...
@@ -574,9 +736,9 @@ Ext.define('PVE.node.Ceph', {
...
@@ -574,9 +736,9 @@ Ext.define('PVE.node.Ceph', {
itemId
:
'
disklist
'
itemId
:
'
disklist
'
},
},
{
{
xtype
:
'
pveNodeCephOsdTree
'
,
title
:
'
OSD
'
,
title
:
'
OSD
'
,
itemId
:
'
test3
'
,
itemId
:
'
osdtree
'
html
:
"
ABCD
"
},
},
{
{
title
:
'
Pool
'
,
title
:
'
Pool
'
,
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment