Linux容器虚拟化LXC的使用


Oops:

万一不能访问,请自带梯子和火星文翻译器

官方网站:

https://linuxcontainers.org/

Github:

https://github.com/lxc/lxc

 

火星文简介:

What's LXC?

LXC is a userspace interface for the Linux kernel containment features.
Through a powerful API and simple tools, it lets Linux users easily create and manage system or application containers.
Features

Current LXC uses the following kernel features to contain processes:

Kernel namespaces (ipc, uts, mount, pid, network and user)
Apparmor and SELinux profiles
Seccomp policies
Chroots (using pivot_root)
Kernel capabilities
Control groups (cgroups) # 需要用到cgroups子系统

As such, LXC is often considered as something in the middle between a chroot on steroids and a full fledged virtual machine. The goal of LXC is to create an environment as close as possible as a standard Linux installation but without the need for a separate kernel.
Components

LXC is currently made of a few separate components:

The liblxc library
Several language bindings for the API:
python3 (in-tree, long term support in 1.0.x)
lua (in tree, long term support in 1.0.x)
Go
ruby
python2
Haskell
A set of standard tools to control the containers
Container templates

Licensing

LXC is free software, most of the code is released under the terms of the GNU LGPLv2.1+ license, some Android compatibility bits are released under a standard 2-clause BSD license and some binaries and templates are shipped under the GNU GPLv2 license.
Where do I get it?
From upstream

You can fetch the latest upstream tarballs here or grab it directly from git here or with:

git clone git://github.com/lxc/lxc
 

------------------------------------------------------------------------------------------

实战部分:

准备工作:

系统环境和yum源

 

wKioL1R6jGuh4ipWAAFM4cYtj7o799.jpg

 

安装所需软件包:

1) debootstrap

debootstrap is used to create a Debian base system from scratch, without
requiring the availability of dpkg or apt.

2) libvirt

省去麻烦的配置,直接用这个 ^_^

3) libcgroup

Control groups infrastructure. The tools and library help manipulate, control administrate and monitor control groups and the associated controllers.

4) lxc lxc-templates

主要包以及模板(等下我们稍微改下模板文件的yum源)

5) 当然还需要 gcc rsync

 

wKioL1R6jvHxRlOgAANxmP4mt18724.jpg

 

启动相关服务:

 

wKioL1R6kLXz_gWdAAPgSsKfyaE607.jpg

 

修改模板文件:

 

wKiom1R6kR_DxzOJAAIylTLfrQs326.jpg

 

系统给提供了这么多模板,下面来修改下centos模板的默认源(修改之前自觉备份一个)

 

wKiom1R6khvgHOPpAADXoI35pVQ427.jpg

 

开始正式安装:

 

wKiom1R6k6fgzYVuAAGlLHPyeUU985.jpg

 

lxc-create creates a container

Options :
-n, --name=NAME NAME for name of the container
-f, --config=file Initial configuration file
-t, --template=t Template to use to setup container

 

wKiom1R6lHai81NFAAKCrg9llPk992.jpg

 

修改密码:

# chroot /var/lib/lxc/centos_1/rootfs passwd

 

启动虚拟机:

# lxc-start -d -n centos_1


Options :
-n, --name=NAME NAME for name of the container
-d, --daemon daemonize the container

 

查看虚拟机状态:

# lxc-info -n centos_1

 

wKioL1R6ldCQv9exAADVkU_yRrg504.jpg

 

连过去看看:

 

wKiom1R6ldfQ-d70AAKg2tzzM3U169.jpg

 

这样一台就弄好了,如果要做LBC,HAC这类实验,可以克隆多个来实现。

 

LXC给我们提供了很多管理工具:

lxc-attach
lxc-clone # 克隆相关
lxc-destroy # 销毁
lxc-ls # List containers existing on the system。

lxc-stop # XD
lxc-usernsexec
lxc-autostart
lxc-config
lxc-execute
lxc-monitor
lxc-top # top你懂的
lxc-wait
lxc-cgroup
lxc-console
lxc-freeze
lxc-snapshot # 给一个容器镜像
lxc-unfreeze
lxc-checkconfig
lxc-create # 创建
lxc-info # 显示容器状态信息
lxc-start # 启动
lxc-unshare

 

Python API:

Python 3K

    import lxc    
    container = lxc.Container("p1")
    container.create("ubuntu")
    container.start()
    container.get_ips()
    container.stop()

 

Python 2.X:

相关内容