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
c6a69e0b
Commit
c6a69e0b
authored
Sep 28, 2011
by
Dietmar Maurer
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
implemented vm_config for openvz
parent
3e86d7f6
Changes
3
Hide whitespace changes
Inline
Side-by-side
Showing
3 changed files
with
94 additions
and
21 deletions
+94
-21
OpenVZ.pm
PVE/API2/OpenVZ.pm
+55
-13
OpenVZ.pm
PVE/OpenVZ.pm
+26
-7
pvectl
bin/pvectl
+13
-1
No files found.
PVE/API2/OpenVZ.pm
View file @
c6a69e0b
...
@@ -3,6 +3,7 @@ package PVE::API2::OpenVZ;
...
@@ -3,6 +3,7 @@ package PVE::API2::OpenVZ;
use
strict
;
use
strict
;
use
warnings
;
use
warnings
;
use
File::
Basename
;
use
File::
Basename
;
use
POSIX
qw (LONG_MAX);
use
PVE::
SafeSyslog
;
use
PVE::
SafeSyslog
;
use
PVE::
Tools
qw(extract_param)
;
use
PVE::
Tools
qw(extract_param)
;
...
@@ -53,12 +54,6 @@ CPUUNITS="1000"
...
@@ -53,12 +54,6 @@ CPUUNITS="1000"
CPUS="1"
CPUS="1"
__EOD
__EOD
my
$get_config_path
=
sub
{
my
$vmid
=
shift
;
return
"
/etc/pve/openvz/
${vmid}
.conf
";
};
__PACKAGE__
->
register_method
({
__PACKAGE__
->
register_method
({
name
=>
'
vmlist
',
name
=>
'
vmlist
',
path
=>
'',
path
=>
'',
...
@@ -131,7 +126,7 @@ __PACKAGE__->register_method({
...
@@ -131,7 +126,7 @@ __PACKAGE__->register_method({
my
$code
=
sub
{
my
$code
=
sub
{
my
$basecfg_fn
=
&
$
get_config_path
(
$vmid
);
my
$basecfg_fn
=
PVE::OpenVZ::
get_config_path
(
$vmid
);
die
"
container
$vmid
already exists
\n
"
if
-
f
$basecfg_fn
;
die
"
container
$vmid
already exists
\n
"
if
-
f
$basecfg_fn
;
...
@@ -209,12 +204,7 @@ __PACKAGE__->register_method({
...
@@ -209,12 +204,7 @@ __PACKAGE__->register_method({
my
$code
=
sub
{
my
$code
=
sub
{
my
$basecfg_fn
=
&
$get_config_path
(
$vmid
);
my
$conf
=
PVE::OpenVZ::
load_config
(
$vmid
);
my
$basecfg
=
PVE::Tools::
file_get_contents
(
$basecfg_fn
);
die
"
container
$vmid
does not exists
\n
"
if
!
$basecfg
;
my
$conf
=
PVE::OpenVZ::
parse_ovz_config
(
$basecfg_fn
,
$basecfg
);
die
"
checksum missmatch (file change by other user?)
\n
"
die
"
checksum missmatch (file change by other user?)
\n
"
if
$digest
&&
$digest
ne
$conf
->
{
digest
};
if
$digest
&&
$digest
ne
$conf
->
{
digest
};
...
@@ -232,6 +222,58 @@ __PACKAGE__->register_method({
...
@@ -232,6 +222,58 @@ __PACKAGE__->register_method({
return
undef
;
return
undef
;
}});
}});
__PACKAGE__
->
register_method
({
name
=>
'
vm_config
',
path
=>
'
{vmid}/config
',
method
=>
'
GET
',
proxyto
=>
'
node
',
description
=>
"
Get virtual machine configuration.
",
parameters
=>
{
additionalProperties
=>
0
,
properties
=>
{
node
=>
get_standard_option
('
pve-node
'),
vmid
=>
get_standard_option
('
pve-vmid
'),
},
},
returns
=>
{
type
=>
"
object
",
properties
=>
{
digest
=>
{
type
=>
'
string
',
description
=>
'
SHA1 digest of configuration file. This can be used to prevent concurrent modifications.
',
}
},
},
code
=>
sub
{
my
(
$param
)
=
@_
;
my
$veconf
=
PVE::OpenVZ::
load_config
(
$param
->
{
vmid
});
# we only return selected/converted values
my
$conf
=
{
digest
=>
$veconf
->
{
digest
}
};
my
$properties
=
PVE::OpenVZ::
json_config_properties
();
foreach
my
$k
(
keys
%
$properties
)
{
next
if
$k
eq
'
memory
';
next
if
$k
eq
'
swap
';
next
if
$k
eq
'
disk
';
$conf
->
{
$k
}
=
$veconf
->
{
$k
}
->
{
value
}
if
$veconf
->
{
$k
}
&&
defined
(
$veconf
->
{
$k
}
->
{
value
});
}
$conf
->
{
memory
}
=
$veconf
->
{
physpages
}
->
{
lim
}
?
int
(
$veconf
->
{
physpages
}
->
{
lim
}
*
4096
)
:
512
*
1024
*
1024
;
$conf
->
{
swap
}
=
$veconf
->
{
swappages
}
->
{
lim
}
?
int
(
$veconf
->
{
swappages
}
->
{
lim
}
*
4096
)
:
0
;
my
$diskspace
=
$veconf
->
{
diskspace
}
->
{
bar
}
||
LONG_MAX
;
if
(
$diskspace
==
LONG_MAX
)
{
$conf
->
{
disk
}
=
0
;
}
else
{
$conf
->
{
disk
}
=
int
(
$diskspace
*
1024
);
}
return
$conf
;
}});
__PACKAGE__
->
register_method
({
__PACKAGE__
->
register_method
({
name
=>
'
destroy_vm
',
name
=>
'
destroy_vm
',
path
=>
'
{vmid}
',
path
=>
'
{vmid}
',
...
...
PVE/OpenVZ.pm
View file @
c6a69e0b
...
@@ -39,6 +39,24 @@ sub cfs_config_path {
...
@@ -39,6 +39,24 @@ sub cfs_config_path {
return
"
nodes/
$node
/openvz/
$vmid
.conf
";
return
"
nodes/
$node
/openvz/
$vmid
.conf
";
}
}
sub
get_config_path
{
my
$vmid
=
shift
;
return
"
/etc/pve/openvz/
${vmid}
.conf
";
};
sub
load_config
{
my
(
$vmid
)
=
@_
;
my
$basecfg_fn
=
get_config_path
(
$vmid
);
my
$basecfg
=
PVE::Tools::
file_get_contents
(
$basecfg_fn
);
die
"
container
$vmid
does not exists
\n
"
if
!
$basecfg
;
my
$conf
=
PVE::OpenVZ::
parse_ovz_config
(
$basecfg_fn
,
$basecfg
);
return
wantarray
?
(
$conf
,
$basecfg
)
:
$conf
;
}
my
$last_proc_vestat
=
{};
my
$last_proc_vestat
=
{};
sub
vmstatus
{
sub
vmstatus
{
...
@@ -214,8 +232,8 @@ my $confdesc = {
...
@@ -214,8 +232,8 @@ my $confdesc = {
disk
=>
{
disk
=>
{
optional
=>
1
,
optional
=>
1
,
type
=>
'
number
',
type
=>
'
number
',
description
=>
"
Amount of disk space for the VM in GB.
",
description
=>
"
Amount of disk space for the VM in GB.
A zero indicates no limits.
",
minimum
=>
0
.5
,
minimum
=>
0
,
default
=>
2
,
default
=>
2
,
},
},
quotatime
=>
{
quotatime
=>
{
...
@@ -696,11 +714,12 @@ sub update_ovz_config {
...
@@ -696,11 +714,12 @@ sub update_ovz_config {
}
}
};
};
my
$mem
=
int
((
$veconf
->
{
physpages
}
->
{
lim
}
*
4
)
/
1024
)
||
512
;
my
$mem
=
$veconf
->
{
physpages
}
->
{
lim
}
?
my
$swap
=
int
((
$veconf
->
{
swappages
}
->
{
lim
}
*
4
)
/
1024
)
||
0
;
int
((
$veconf
->
{
physpages
}
->
{
lim
}
*
4
)
/
1024
)
:
512
;
my
$swap
=
$veconf
->
{
swappages
}
->
{
lim
}
?
int
((
$veconf
->
{
swappages
}
->
{
lim
}
*
4
)
/
1024
)
:
0
;
my
$disk
=
(
$veconf
->
{
diskspace
}
->
{
bar
}
||
$res_unlimited
)
/
(
1024
*
1024
);
my
$disk
=
(
$veconf
->
{
diskspace
}
->
{
bar
}
/
(
1024
*
1024
))
||
$res_unlimited
;
my
$cpuunits
=
$veconf
->
{
cpuunits
}
->
{
value
}
||
1000
;
my
$cpuunits
=
$veconf
->
{
cpuunits
}
->
{
value
}
||
1000
;
my
$quotatime
=
$veconf
->
{
quotatime
}
->
{
value
}
||
0
;
my
$quotatime
=
$veconf
->
{
quotatime
}
->
{
value
}
||
0
;
my
$quotaugidlimit
=
$veconf
->
{
quotaugidlimit
}
->
{
value
}
||
0
;
my
$quotaugidlimit
=
$veconf
->
{
quotaugidlimit
}
->
{
value
}
||
0
;
...
@@ -758,7 +777,7 @@ sub update_ovz_config {
...
@@ -758,7 +777,7 @@ sub update_ovz_config {
# disk quota parameters
# disk quota parameters
if
((
$disk
*
1.1
)
>=
(
$res_unlimited
/
(
1024
*
1024
)))
{
if
(
!
$disk
||
(
$disk
*
1.1
)
>=
(
$res_unlimited
/
(
1024
*
1024
)))
{
&
$push_bl_changes
('
diskspace
',
$res_unlimited
,
$res_unlimited
);
&
$push_bl_changes
('
diskspace
',
$res_unlimited
,
$res_unlimited
);
&
$push_bl_changes
('
diskinodes
',
$res_unlimited
,
$res_unlimited
);
&
$push_bl_changes
('
diskinodes
',
$res_unlimited
,
$res_unlimited
);
}
else
{
}
else
{
...
...
bin/pvectl
View file @
c6a69e0b
...
@@ -37,7 +37,7 @@ my $cmddef = {
...
@@ -37,7 +37,7 @@ my $cmddef = {
exit
0
if
(
!
scalar
(
@$vmlist
));
exit
0
if
(
!
scalar
(
@$vmlist
));
printf
"
%10s %-20s %-10s %-10s %12s %-10s
\n
",
printf
"
%10s %-20s %-10s %-10s %
-
12s %-10s
\n
",
qw(VMID NAME STATUS MEM(MB) DISK(GB))
;
qw(VMID NAME STATUS MEM(MB) DISK(GB))
;
foreach
my
$rec
(
sort
{
$a
->
{
vmid
}
<=>
$b
->
{
vmid
}
}
@$vmlist
)
{
foreach
my
$rec
(
sort
{
$a
->
{
vmid
}
<=>
$b
->
{
vmid
}
}
@$vmlist
)
{
...
@@ -53,6 +53,18 @@ my $cmddef = {
...
@@ -53,6 +53,18 @@ my $cmddef = {
set
=>
[
"
PVE::API2::OpenVZ
",
'
update_vm
',
['
vmid
'],
{
node
=>
$nodename
}
],
set
=>
[
"
PVE::API2::OpenVZ
",
'
update_vm
',
['
vmid
'],
{
node
=>
$nodename
}
],
config
=>
[
"
PVE::API2::OpenVZ
",
'
vm_config
',
['
vmid
'],
{
node
=>
$nodename
},
sub
{
my
$config
=
shift
;
foreach
my
$k
(
sort
(
keys
%
$config
))
{
next
if
$k
eq
'
digest
';
my
$v
=
$config
->
{
$k
};
if
(
$k
eq
'
description
')
{
$v
=
PVE::Tools::
encode_text
(
$v
);
}
print
"
$k
:
$v
\n
";
}
}],
};
};
...
...
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