在Ubuntu16.04上部署LXC容器管理系统的相关步骤
打算安装一个LXC linux容器管理的软件来分配使用资源并配置不同的编程环境,这样就方便大家的使用,步骤如下(宿主机的环境都搭建好了,对应显卡的驱动等):
参考网站:
简单入门和相关指令总结:https://www.ibm.com/developerworks/cn/linux/1312_caojh_linuxlxc/index.html
Linux 容器的资源管理方法:https://www.ibm.com/developerworks/cn/linux/1404_caojh_lxc/
其他部署的方法可以参看这个:https://zhuanlan.zhihu.com/p/25710517
一、简单的使用流程:
1、安装LXC软件:
sudo apt-get install lxc
我的已经安装好了,提示不用安装了。
2、检查一下当前的linux内核版本是否支持lxc:
sudo lxc-checkconfig
如果每个状态都是enable,则表示当前环境支持LXC
3、开始创建一个容器,容器的类型选择如下所示:
# tree /usr/lib/lxc/templates/
/usr/lib/lxc/templates/
├── lxc-busybox
├── lxc-debian
├── lxc-fedora
├── lxc-opensuse
├── lxc-sshd
├── lxc-ubuntu
└── lxc-ubuntu-cloud
这些模板我们都可以使用,举例使用lxc-ubuntu类型的系统来构建一个新的container:
sudo lxc-create -n Centos -t ubuntu
运行过程如下:需要注意的是最后会告诉你对应系统的初始用户名和密码:

注意密码在这里哦!!!!

接下来我们用指令来查看创建好的container:
sudo lxc-ls -f

Centos那个主机是我们刚刚创建好的,Debian和Ubuntu是我之前创建的。我们也能通过lxc-ls -f这条指令来查看所有container当前的状态。
我们能在/var/lib/lxc的目录中查看到创建好的容器的相关配置文件,我们就是通过修改相关的配置文件(config文件)来控制对应容器container的参数的。

4、开启容器中的机器:
sudo lxc-start -n Ubuntu

5、打开对应机器的控制台:
sudo lxc-console -n Ubuntu

输入对应的用户名和密码就可以啦~用户名:ubuntu 密码:ubuntu
6、使用ssh连接对应的主机:

找到对应的内网IP地址之后,我们就可以通过ssh来连接对应的container主机了:
sudo ssh ubuntu@10.0.3.155
这样就可以连接到我梦需要使用的container上面了,如下图所示:(注意@符号前面的名称ubuntu不是container的名称而是主机的用户名)

7、关闭对应的容器:
sudo lxc-stop -n Ubuntu
你可以直接使用exit来直接推出当前的容器,但是容器并没有被关闭掉,此时容器的机器还是会占有一定的硬件资源:
此时只是退出了当前的容器。
所以需要用到指令:lxc-stop -n Ubuntu 来关闭叫做Ubuntu的容器:
如图所示,Ubuntu容器的状态是STOPPED,同时内网IP也丢失了。
二、详细具体的相关指令:
lxc-version 用于显示系统LXC的版本号(可以通过此命令判断系统是否安装了lxc)
lxc-checkconfig 用于判断linux内核是否支持LXC
lxc-create用于创建一个容器
用法:lxc-create -n name [-f config_file]
-n 后面跟要创建的容器名字 例如:-n foo
-f 后面跟容器配置文件的路径
lxc-execute 用于在一个容器执行应用程序
lxc-start 用于在容器中执行给定命令
用法:lxc-start -n name [-f config_file] [-c console_file] [-d] [-s KEY=VAL]
[command]
-d 将容器当做守护进程执行
-f 后面跟配置文件
-c 指定一个文件作为容器console的输出,如果不指定,将输出到终端
-s 指定配置
例如:lxc-start -n foo -f foo.conf -d /bin/bash
lxc-kill 发送信号给容器中的第一个用户进程(容器内部进程号为2的进程)
用法:lxc-kil -n name SIGNUM
-n 后面跟容器名
SIGNUM 信号 (此参数可选,默认SIGKILL)
例如:lxc-kill -n foo
lxc-stop 用于停止容器中所有的进程
用法:lxc-stop -n name
-n后面跟要停止的容器名
lxc-destroy 用于销毁容器
用法:lxc-destroy -n name
-n后面跟要停止的容器名
lxc-cgroup 用于获取或调整与cgroup相关的参数
用法:lxc-cgroup -n name subsystem value
-n 后面跟要调整的容器名
例如: lxc-cgroup -n foo devices.list
lxc-cgroup -n foo cpuset.cpus "0,3"
lxc-info 用户获取一个容器的状态
用法:lxc-info -n name
-n后面跟操作的容器名
例如: lxc-info --n foo
lxc-ls 列出当前系统所有的容器
用法:lxc-ls
例如:lxc-ls
三、ssh登录时的用户界面脚本编写:
为了方便的使用进入到对应的container当中,编写了ssh登录到宿主机时的登录界面(ssh登录时都会自动运行脚本~/.bashrc,因此我们只需要将需要登录之后运行的脚本写入到~/.bashrc文件当中就可以了)如下所示:
将这些代码添加到~/.bashrc文件的最后面,每次ssh登录时就会运行此脚本。
代码如下:
echo "The Status Of the Machine:"
INFO=$(sudo lxc-ls -f)
echo "$INFO"
echo "The Table For Choosing Sys-Container:"
echo "1 --------- Ubuntu16.04+TensorFlow1.0"
echo "2 --------- Debian10.42+Caffe1.2"
echo "3 --------- Centos17.22+TensorFlow1.2"
echo "Please Choose The Lable Of The System:"
read input
if [ "$input" -eq ]; then
echo "Ubuntu is Starting,Please waitting..."
sudo lxc-start -n Ubuntu
echo "Have a Good Day!"
sudo ssh ubuntu@10.0.3.155
elif [ "$input" -eq ]; then
echo "Debian is Starting,Please waitting..."
sudo lxc-start -n Debian
echo "Have a Good Day!"
sudo ssh Debian@10.0.3.239
elif [ "$input" -eq ]; then
echo "Centos is Starting,Please waitting..."
sudo lxc-start -n Centos
echo "Have a Good Day!"
sudo ssh Centos@10.2.0.134
else
echo "Thanks For Choosing the Host Machine,Enjoying~"
fi
实际的效果如下所示:

输入容器Ubuntu机器的密码就可以进入这个版本的容器当中,这样操作也是非常方便的,其他的相关操作和需要后面在不断的优化吧。

2017.9.8 更新方法:
四、使用端口映射的转发的方法
借鉴一下知乎大神的方法,实现端口的映射和转发功能也能很好很方便的解决容器使用的问题:
直接使用端口映射的功能(确保启动了需要使用的容器lxc-start -n Ubuntu):
sudo iptables -t nat -A PREROUTING -d 192.168.1.117 -p tcp --dport -j DNAT --to-destination 10.0.3.155:
将主机的10001端口映射到主机内网容器的22端口上面,实现端口数据的转发功能,实验结果如下:

由上可以看出,端口映射的转发功能没有问题。(相关参考:http://blog.csdn.net/xin_yu_xin/article/details/46416101)
完~
在Ubuntu16.04上部署LXC容器管理系统的相关步骤的更多相关文章
- primecoin在ubuntu16.04上部署服务:
primecoin在ubuntu16.04上部署服务: 一.下载Tomcat,Jdk,primecoin(公司内部文件) 注意Tomcat版本需要高于Jdk的,不然会报错. 二.把它们都解压到你要的安 ...
- 0、ubuntu16.04安装部署kvm
ubuntu16.04安装部署kvm1.查看CPU是否支持KVM egrep "(svm|vmx)" /proc/cpuinfo 2.安装相关kvm包 sudo apt-get i ...
- 【MindSpore】Ubuntu16.04上成功安装GPU版MindSpore1.0.1
本文是在宿主机Ubuntu16.04上拉取cuda10.1-cudnn7-ubuntu18.04的镜像,在容器中通过Miniconda3创建python3.7.5的环境并成功安装mindspore_g ...
- deepsooncms在Ubuntu 14.04上部署教程
deepsooncms在Ubuntu 14.04上部署教程 一.安装mono1.在命令行运行sudo apt-key adv --keyserver keyserver.ubuntu.com --re ...
- Ubuntu16.04上用源代码安装ICE
ubuntu16.04上用源代码安装ICE
- Ubuntu16.04上安装neo4j数据库
什么是neo4j数据库? neo4j数据库是图数据库的一种,属于nosql的一种,常见的nosql数据库还有redis.memcached.mongDB等,不同于传统的关系型数据库,nosql数据也有 ...
- 在ubuntu16.04上安装eclipse
在ubuntu16.04上安装eclipse 一.下载 首先我们需要安装jdk1.8及其以上,然后从官网:https://www.eclipse.org/downloads/上下载,需要注意 ...
- 在ubuntu16.04上编译android源码【转】
本文转载自:http://blog.csdn.net/fuchaosz/article/details/51487585 1 前言 经过3天奋战,终于在Ubuntu 16.04上把Android 6. ...
- ubuntu16.04上在使用搜狗输入法时,按shift不能正常切换中英文
问题描述: ubuntu16.04上在使用搜狗输入法时,不知道把什么组合键给错按了,导致了按shift不能正常切换中英文,这是一件很烦恼的事儿! 解决步骤: 1,终端输入打开: fcitx-confi ...
随机推荐
- 微信小程序(一)基本知识初识别
最近微信圈里小程序很火的样子,以前小程序刚开始的时候研究了一下,多日没关注发现一些东西都淡忘了,最后决定还是记录下来的好. 毕竟好记星比不上烂笔头嘛~ 另外有想学习小程序的同学,也可以参考下,当然如果 ...
- JAVA字符串操作 (转)
JAVA字符串操作 原帖地址:http://blog.163.com/hn_myj@126/blog/static/50555635200861133942947/ 参考:http://blog.cs ...
- 单双引号的区别,defined容易疏忽的小地方
单双引号的区别(面试题) 1.双引号可以解析变量,单引号不行 2.双引号解析转义字符,单引号不解析转义字符.但是单引号能解析 ...
- java利用接口和适配器进行完全解耦--参考《thinking in java》
一.当使用父子类来实现以下东西时,其实是用了向上转型,这段代码的确简单了很多,复用性也很好,但是我们会发现Apply.process()和Processor类耦合过紧,其实apply.process( ...
- MySQL之删_delete-truncate
MySQL增删改查之删_delete-truncate 一.DELETE语句 删除数据记录 1.在单表中删除行 语法: DELETE [IGNORE] FROM tbl_name [WHERE whe ...
- HTML中表格
HTML表格 [表格table] 表格用table表示,表格中的每一行tr表示,一行中的每一列用td表示 th表示的是:表头.表头中的文字,默认为加粗居中.th要放在tr中,用于替换掉td. [tab ...
- IPython使用学习笔记
学习<利用python进行数据分析>第三章 IPython:一种交互式计算和开发环境的笔记,共享给大家,同时为自己作为备忘用. 安装ipython用pip即可.ps.博主用的是win7系统 ...
- ubuntu创建wifi热点(android可识别)亲测可用
转自http://jingyan.baidu.com/article/ea24bc39b03fc6da62b331f0.html 如何在ubuntu系统下创建android可识别热点?一般环境下创建的 ...
- Linux系统中cgroup功能介绍
1 Cgroups简介 1.1 What are cgroups ? Cgroups(控制组)是Linux内核的一个功能,用来限制.统计和分离一个进程组的资源(CPU.内存.磁盘输入输出等).换句话 ...
- python---scrapy之MySQL同步存储
假设我们已经能获取到item里定义的字段的数据,接下来就需要保存item的数据到mysql数据库. pipeline用来存储item中的数据,将爬取到的数据进行二次处理 首先,要做的准备的工作,安装M ...