|
|
|
<?php
|
|
|
|
/*
|
|
|
|
* CVM is more free software. It is licensed under the WTFPL, which
|
|
|
|
* allows you to do pretty much anything with it, without having to
|
|
|
|
* ask permission. Commercial use is allowed, and no attribution is
|
|
|
|
* required. We do politely request that you share your modifications
|
|
|
|
* to benefit other developers, but you are under no enforced
|
|
|
|
* obligation to do so :)
|
|
|
|
*
|
|
|
|
* Please read the accompanying LICENSE document for the full WTFPL
|
|
|
|
* licensing text.
|
|
|
|
*/
|
|
|
|
|
|
|
|
if(!isset($_CVM)) { die("Unauthorized."); }
|
|
|
|
|
|
|
|
class Container extends CPHPDatabaseRecordClass
|
|
|
|
{
|
|
|
|
public $table_name = "containers";
|
|
|
|
public $fill_query = "SELECT * FROM containers WHERE `Id` = '%d'";
|
|
|
|
public $verify_query = "SELECT * FROM containers WHERE `Id` = '%d'";
|
|
|
|
|
|
|
|
public $prototype = array(
|
|
|
|
'string' => array(
|
|
|
|
'Hostname' => "Hostname",
|
|
|
|
'InternalId' => "InternalId",
|
|
|
|
'RootPassword' => "RootPassword"
|
|
|
|
),
|
|
|
|
'numeric' => array(
|
|
|
|
'NodeId' => "NodeId",
|
|
|
|
'TemplateId' => "TemplateId",
|
|
|
|
'VirtualizationType' => "VirtualizationType",
|
|
|
|
'DiskSpace' => "DiskSpace",
|
|
|
|
'GuaranteedRam' => "GuaranteedRam",
|
|
|
|
'BurstableRam' => "BurstableRam",
|
|
|
|
'CpuCount' => "CpuCount"
|
|
|
|
),
|
|
|
|
'node' => array(
|
|
|
|
'Node' => "NodeId"
|
|
|
|
),
|
|
|
|
'template' => array(
|
|
|
|
'Template' => "TemplateId"
|
|
|
|
)
|
|
|
|
);
|
|
|
|
|
|
|
|
public function Deploy()
|
|
|
|
{
|
|
|
|
$sGuaranteedRamPages = $this->sGuaranteedRam * 256;
|
|
|
|
$sBurstableRamPages = $this->sBurstableRam * 256;
|
|
|
|
$sRootPassword = random_string(20);
|
|
|
|
|
|
|
|
$this->uRootPassword = $sRootPassword;
|
|
|
|
$this->InsertIntoDatabase();
|
|
|
|
|
|
|
|
$command = shrink_command("vzctl create {$this->sInternalId}
|
|
|
|
--ostemplate {$this->sTemplate->sTemplateName}
|
|
|
|
");
|
|
|
|
|
|
|
|
$result = $this->sNode->ssh->RunCommand($command, false);
|
|
|
|
|
|
|
|
if($result->returncode == 0)
|
|
|
|
{
|
|
|
|
// TODO: set sensible values depending on container resource configuration
|
|
|
|
// http://wiki.openvz.org/UBC_consistency_check
|
|
|
|
|
|
|
|
$command = shrink_command("vzctl set {$this->sInternalId}
|
|
|
|
--onboot yes
|
|
|
|
--setmode restart
|
|
|
|
--hostname {$this->sHostname}
|
|
|
|
--nameserver 8.8.8.8
|
|
|
|
--nameserver 8.8.4.4
|
|
|
|
--numproc {$this->sCpuCount}
|
|
|
|
--vmguarpages {$sGuaranteedRamPages}:unlimited
|
|
|
|
--privvmpages {$sBurstableRamPages}:{$sBurstableRamPages}
|
|
|
|
--quotatime 0
|
|
|
|
--diskspace {$this->sDiskSpace}M:{$this->sDiskSpace}M
|
|
|
|
--userpasswd root:{$sRootPassword}
|
|
|
|
--kmemsize 14372700:14790164
|
|
|
|
--lockedpages 256:256
|
|
|
|
--shmpages 21504:21504
|
|
|
|
--physpages 0:unlimited
|
|
|
|
--oomguarpages 26112:unlimited
|
|
|
|
--numtcpsock 360:360
|
|
|
|
--numflock 188:206
|
|
|
|
--numpty 16:16
|
|
|
|
--numsiginfo 256:256
|
|
|
|
--tcpsndbuf 1720320:2703360
|
|
|
|
--tcprcvbuf 1720320:2703360
|
|
|
|
--othersockbuf 1126080:2097152
|
|
|
|
--dgramrcvbuf 262144:262144
|
|
|
|
--numothersock 360:360
|
|
|
|
--numfile 9312:9312
|
|
|
|
--dcachesize 3409920:3624960
|
|
|
|
--numiptent 128:128
|
|
|
|
--diskinodes 200000:220000
|
|
|
|
--avnumproc 180:180
|
|
|
|
--save
|
|
|
|
");
|
|
|
|
|
|
|
|
$result = $this->sNode->ssh->RunCommand($command, false);
|
|
|
|
|
|
|
|
if($result->returncode == 0)
|
|
|
|
{
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
// TODO: Throw exception for failed container configuration
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
// TODO: throw exception for failed container creation
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
public function Start()
|
|
|
|
{
|
|
|
|
$command = "vzctl start {$this->sInternalId}";
|
|
|
|
$result = $this->sNode->ssh->RunCommand($command, false);
|
|
|
|
|
|
|
|
if($result->returncode == 0)
|
|
|
|
{
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
// TODO: throw exception for failed container start
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
?>
|