批量部署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

相关推荐

  • Linux任务计划

        任务计划分类:    一次性任务计划:只执行一次就结束                at batch    周期性任务计划:每隔一定的周期去…

    Linux干货 2017-05-08
  • Linux创建CA和申请认证

    Linux创建CA和申请认证 背景: 在学习Linux运维中,学习到了CA的创建和申请认证,为了加深对CA的理解,这里做一个创建CA和申请认证的实验并记录下来供以后回顾。 介绍: 什么是CA认证? 电子商务认证授权机构(CA, Certificate Authority),也称为电子商务认证中心,是负责发放和管理数字证书的权威机构,并作为电子商务交易中受信任…

    2017-09-09
  • 逻辑卷LVM

    逻辑卷LVM 简介     在实际生产应用中,磁盘的分区的容量是固定不变的,当出现分区容量不足的情况,除了新加磁盘,还有没有其他方法呢?    逻辑卷(LVM)的概念就出现了,全称叫Logical Volume Manager。它的作用是允许对卷进行方便操作的抽象层,包括重新设定…

    Linux干货 2017-08-12
  • RAID有点意思

        独立硬盘冗余阵列(RAID, Redundant Array of Independent Disks),旧称廉价磁盘冗余阵列(Redundant Array of Inexpensive Disks),简称磁盘阵列。其基本思想就是把多个相对…

    Linux干货 2017-06-19
  • CentOS 5,6 系统启动流程详解

        一、linux 组成介绍          1.linux 组成:              Lin…

    Linux干货 2016-09-11
  • 马哥教育网络班21期第9周课程练习

    1、写一个脚本,判断当前系统上所有用户的shell是否为可登录shell(即用户的shell不是/sbin/nologin);分别这两类用户的个数;通过字符串比较来实现; #!/bin/bash # declare -i nologin_user;other_user all_users=`awk -F':'…

    Linux干货 2016-09-19

评论列表(1条)

  • stanley
    stanley 2016-03-20 11:48

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