批量部署lxc虚拟机

前言:lxc是一种操作系统层虚拟化(Operating system–level virtualization)技术,为Linux内核容器功能的一个用户空间接口。它将应用软件系统打包成一个软件容器(Container),内含应用软件本身的代码,以及所需要的操作系统核心和库。通过统一的命名空间和共用API来分配不同软件容器的可用硬件资源,创造出应用程序的独立沙箱运行环境,使得Linux用户可以容易的创建和管理系统或应用容器。

由于有些朋友对lxc虚拟机了解不多,所以我觉得,这个课题也算很新颖了。

马哥简单讲了lxc虚拟机的部署。我把他写成了脚本,全当练习啦!(别小瞧它,lxc虚拟机也有用武之地的!)

用后体会:用了几天,占用内存很小,安装速度较快,如果你的电脑硬件配置较低,完全可是试试它!

小伙伴们,有几点需要注意,lxc的虚拟机是非常简化版的虚拟机,共用的内核,也不支持fdisk,selinux跟宿主机是一样的也不支持修改等等(其他方面不足待考证)。

所以,我要说明,条件高的同学们不要使用啦。如果你做集群,或者需要使用大量虚拟机,对虚拟机要求的并不高,可以在一台虚拟机里安装多台的lxc虚拟机(vmware虚拟机的内存给大一些)。

实验环境:

1.将马哥发的lxc软件放到/root/lxc

2.配制好本地yum源

3.一个网卡就行

为了方便大家,我写了一些注释,脚本测试过几次,应该没有没问题。当然,由于每个人的环境不同,如果遇到问题大家可以联系我,自己改改也行,我不胜感激。

#!/bin/bash

########Note: please put the Lxc software file in /root/lxc################# 

########Note: Please configure the local yum################################ 

setenforce 0 &>/dev/null

service iptables  stop

read -p "please enter your ip,Netmask and Network card Name(ex:1.1.1.1 255.0.0.0 eth0) :" UserIp Mask Device 

#####请输入你的网卡的ip(随便给一个,不能重复)掩码和网卡名

if ! ping -w 1 -c1 $UserIp &>/dev/null;then

echo 'ok'

else

        echo "$UserIp has already been used."

        exit 1

fi

cd /etc/sysconfig/network-scripts/

cat > ifcfg-eth0 << EOF

DEVICE="$Device"

ONBOOT=yes

BOOTPROTO=none

IPADDR="$UserIp"

NETMASK="$Mask"

EOF

read -p "please enter mirror path,Must be absoulte path(ex:/dev/cdrom):" mirror 你们本地镜像在哪(要写绝对路径)

mount -o loop $mirror /mnt

echo 'mirror mount /mnt!'

cd /etc/sysconfig/network-scripts/

cp ifcfg-eth0 ifcfg-br0

sed -i '$a TYPE=Bridge' ifcfg-br0

sed -i '/DEVICE/c DEVICE=br0' ifcfg-br0

sed -i '/BOOTPROTO/c BOOTPROTO=none' ifcfg-br0

sed -i '/IPADDR/d' ifcfg-eth0

sed -i '/NETMASK/d' ifcfg-eth0

sed -i '/BOOTPROTO/c BOOTPROTO=none' ifcfg-eth0

sed -i '$a BRIDGE=br0' ifcfg-eth0


service NetworkManager stop

service network restart 

yum install vsftpd -y

cp -a /mnt/* /var/ftp/pub

service vsftpd restart && echo 'vsftpd is ok!'

ip=`ifconfig br0 | awk -F ' +|:' '/inet addr/{print $4}'` #####ftp server ip #################

cd /root/lxc

yum install *.rpm -y

yum install libcgroup -y 

service cgconfig restart 

chkconfig cgconfig on

path='/usr/share/lxc/templates/lxc-centos'

sed -i '/lxc.network.link/c lxc.network.link = br0' /etc/lxc/default.conf

sed  -i '/\[updates\]/,/updates$/d' $path

sed -i "/=os$/c baseurl=ftp://$ip/pub" $path

declare -a abc

declare -i A=0

read  -p  "please enter Machine Name,can have more Name(ex:centos1 centos2 ):" -a abc  

#####输入虚拟机的名字空格隔开(输入几个名字就有几个虚拟机出来,这些名字你要记住)

Num=`echo "${abc[*]}" | wc -w `

for i in `seq 0 "$[$Num-1]"`;do

lxc-create -n ${abc["$i"]} -t $path

done

echo '#######run  "chroot /var/lib/lxc/MACHINE NAME/rootfs passwd"###################' 

你必须要设置密码才能登陆,将里面的‘MACHINE NAME’改成你的虚拟机名就可以设定了

echo '#######please modify the password of the virtual machine, and then run lxc-start -n MACHINE NAME####' 

lxc-start -n 虚拟机名字 (这个是登陆用的)

关于lxc虚拟机的几个小命令,帮助你玩转它!

lxc-start -n 虚拟机名 作用:开启虚拟机

lxc-stop -n 虚拟机名  作用:停止虚拟机

lxc-ls   作用:查看虚拟机

lxc-destroy -n 虚拟机名 作用:删除指定的虚拟机


本人新手一枚,也是第一次分享博客,脚本也比较乱,希望大家批评指正,不喜勿喷。真心的希望和大家共同进步,也希望马哥的兄弟们能见证我的成长!


原创文章,作者:Net-Jia,如若转载,请注明出处:http://www.178linux.com/12965

(0)
Net-JiaNet-Jia
上一篇 2016-03-19 22:25
下一篇 2016-03-20 11:48

相关推荐

  • 用户权限以及组权限作业

    1、在/data/testdir里创建的新文件自动属于g1组,组g2的成员如:alice能对这些新文件有读写权限,组g3的成员如:tom只能对新文件有读权限,其它用户(不属于g1,g2,g3)不能访问这个文件夹。 [root@localhost testdir]# mkdir -p /data/testdir [roo…

    Linux干货 2016-08-08
  • 面向对象

    语言分类 面向机器:抽象成机器指令,机器容易理解。代表:汇编语言 面向过程:一件事情分步骤来完成,出现各种情况有解决办法一一对应,问题规模小可以步骤化、按部就班的处理。代表:C语言 面向对象oop(object Oriented Programming):随着计算机解决问题的规模扩大、情况更复杂,需要很多部分协作,面向过程编程就不合适了,演变出了面向对象编程…

    Linux干货 2017-11-13
  • vim编辑器

    vim编辑器三种模式转换 G跳到尾行 gg:跳到首行 H:跳到当前页的首行 L: 跳到当前页的尾行 M: 跳到当前而的中间行 dd: 删除光标所在的行 #dd:多行删除 yy:复制行 #yy: 复制多行  Y: 复制整行 cc:删除当前行并输入新内容 #cc:删除多行 C:删除当前光标到行尾,并切换成插入模式 修改配置文件 全局: /etc/vimrc 用…

    2017-08-05
  • 浅谈DNS基本原理以及实现方法(一)

     DNS(Domain Name System,域名系统),是目前互联网上最不可或缺的服务器之一,我们在互联网从访问一个网站,到发送一封电子邮件,再到定位域中的域控制器,无时无刻不再使用着DNS为我们提供的服务,那为什么我们会需要这样一个服务那?带着这样一个疑问让我们先来认识一下什么是DNS吧  DNS最核心的工作就是域名解析,也就是把计…

    Linux干货 2015-12-15
  • 马哥linux0805作业内容

    在/date/testdir/里穿件的新文件自动属于g1组,组g2的成员如:alice能对这些新文件有读写权限,组g3的成员如:tom只能对新文件有读权限,其他用户(不属于g1,g2,g3)不能访问这个文件夹 设置user1,使之新建文件权限为rw——- 3.设置/testdir/f1的权限,使user1用户不可以读写执行,g1组可以…

    Linux干货 2016-08-11
  • bash编程初体验(三)

    bash编程初体验之for for while until 概述 本文将介绍以for为代表的循环语句在shell 脚本中的应用,常见的循环语句有for, while,until,作为循环语句,顾名思义,它就是重复地做一件事,直到满足某一条件而退出;另外,还有两个循环控制语句continue与break来配合循环语句,以实现临时中断或跳出循环的功能;以下为fo…

    Linux干货 2016-08-24

评论列表(1条)

  • stanley
    stanley 2016-03-20 11:48

    blog的代码段格式化后会更精彩