NAME
Linux::LXC - Manage your LXC containers.
VERSION
1.0000
SYNOPSYS
use Linux::LXC qw(ALLOW_UNDEF);
my $c = Linux::LXC->new(
utsname => 'web',
template => 'download -- -d debian -r wheezy -a amd64'
);
my ($uid_start, $uid_map) =
$c->get_config('lxc.id_map', qr/^u 0 (\d+) (\d+)$/, ALLOW_UNDEF);
$c->stop if $c->is_running;
$c->destroy if $c->is_existing;
$c->deploy;
$c->set_config('lxc.network.ipv4', '10.0.3.2');
$c->start;
my @cmd = (
'route add default gw 10.0.0.3 eth0',
'echo "nameserver 8.8.8.8" > /etc/resolv.conf',
'apt-get update -y',
'apt-get install -y lighttpd'
);
map {
my ($res, $stdout, $stderr) = $c->exec($_);
die $stderr if $stderr ne '';
} @cmd;
$c->put('lighttpd.conf', '/etc/lighttpd/lighttpd.conf');
$c->put('www', '/var/www');
DESCRIPTION
This module helps you to manage LXC container. Each container will be
represented by an object of this module. Some module subroutine are
also usable without any object instance.
Module subroutines
get_existing_containers()
Will return an array with the name of all LXC containers existing on
the system.
get_running_containers()
Will return an array with the name of all LXC containers currently
running on the system.
get_stopped_containers()
Will return an array with the name of all LXC containers currently
stopped on the system.
Object methods
new(%params)
Instanciate a new Linux::LXC object. Params that can be initialized:
utsname
Mandatory parameter. Set the utsname of the container.
template
Mandatory only if you planned to deploy the container. Set the LXC
template to use for deploying the container.
return
A Linux::LXC object.
deploy()
Will deploy the container. Concretly, this method will check that the
container is not existing, and after execute `lxc-deploy -n <utsname>
-t <template>` shell command.
return
The previous Linux::LXC object.
del_config($attribute, $filter)
Will delete all LXC configuration container attributes that respect the
$filter pattern.
$attribute
The attribute to delete.
$filter
A regex or undef. It will be compared with all $attribute values. The
ones that match will be removed. If undef, all values will be
removed.
return
The number of elements deleted.
destroy()
Will stop the container if it's existing and destroy it with the shell
`lxc-destroy -n <utsname>` shell command.
return
The previous Linux::LXC object.
exec($cmd)
Will execute the $cmd command in the container. This method use the
IPC::Run method, that allow us to don't think at all about priorities
between shell operators. Eg: exec('echo "Hello" >> ~/file.txt') will
write the file on the container, and not on the instance that actually
runs the commnand.
return (if want array)
($result, $stdout, $stderr); $result true if shell command return 0
(it usually means that the command was a success), false otherwise.
$stdout and $stderr are self-explaining.
return (if want scalar)
True if shell command return 0 (it usually means that the command was
a success), false otherwise.
get_config($paramater, $filter, $flag)
Get an array of values corresponding to all data that match the LXC
container configuration.
$parameter
The parameter to match.
$filter
An regex, or undef. Values corresponding of the parameter to keep. If
undef, we will keep all of them.
$flags
ALLOW_EMPTY: don't croak if the parameter asked was not found.
return
An array with all matched results.
get_lxc_path()
Return the path to the LXC instance of the container. By default it's
/var/lib/lxc/<utsname>/. The path is the folder that contains rootfs
and config file.
get_template()
Get the template of the LXC instance.
get_utsname()
Will return the utsname of the container.
is_existing()
Retrun true if the container with the given utsname exists. False
otherwise.
is_running()
Retrun true if the container with the given utsname is running. False
otherwise.
is_stopped()
Return true if the container with the given utsname is stopped. False
otherwise.
put($input, $destination)
Will copy the $input file or folder on the $destination path in the
container instance. This method also takes care of ownership and will
chown $destination to the container root uid.
$input
String corresponding to a relative or absolute path of a folder or a
file we want to copy on the container root fs. This path should be
readable by the user executing this script.
$output
Location on the container to put the file or folder. This path has to
be absolute.
set_config($attribute, $value, $flag)
Will set a LXC attribute in container configuration. The update can
occurs in two modes: addition or erasing. In the first one, a new
attribute with the given value will always be created. In the second
case, the first previous value already existing of $attribute will be
updated with the new $value. If none is found, the atribute will also
be created.
$attribute
Attribute to set.
$value
Value to give to the attribute.
$flag
Can be ADDITION_MODE, ERASING_MODE or undef. If undef, ERASING_MODE
will occur.
set_template($template)
Will set the $template name to the given container. Note that this
action should be done before the deployment.
start()
Start the container.
stop()
Stop the container.
AUTHOR
Spydemon <
[email protected]>
COPYRIGHT AND LICENSE
This software is copyright (c) 2017 by Spydemon.
This program is free software: you can redistribute it and/or modify it
under the terms of the GNU General Public License as published by the
Free Software Foundation, either version 3 of the License, or (at your
option) any later version.
This program is distributed in the hope that it will be useful, but
WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
General Public License for more details.
You should have received a copy of the GNU General Public License along
with this program. If not, see <
http://www.gnu.org/licenses/>.