美文网首页vagrant
使用libvirt配置多节点的Vagrant集群

使用libvirt配置多节点的Vagrant集群

作者: 大山鼠 | 来源:发表于2017-02-27 22:16 被阅读817次

如今很多实验室都装备有大内存,高主频,多核心的高性能服务器,所以很多虚拟机的实验其实是可以在实验室完成的,而且相对于在公有云,其测试结果更准确。目前,我认为最好的方式就是在实验室搭建Vagrant+libvirt+KVM的虚拟机集群。本文讲介绍如何在CentOS/Fedora/Redhat上搭建Vagrant+libvirt的虚拟机集群。

特点

  • 支持多个物理机上的虚拟机之间互相通信
  • 通过Vagrantfile直接指定虚拟机启动的具体物理节点,可以有效的减少在公有云中虚拟机分配的物理节点拓扑不明确造成的实验误差。
  • 通过编写Vagrantfile完成测试环境的快速搭建和部署
  • 相对于Virtualbox,KVM虚拟机的性能较高

步骤

使用传统网络名称

  • /etc/default/grub 中的GRUB_CMDLINE_LINUX行中加入下面的两个选项net.ifnames=0 biosdevname=0
  • 运行grub2-mkconfig
  • 修改/etc/sysconfig/networt-script/ifcfg-x里的内容并重命名为ifcfg-eth0,ifcfg-eth1
  • 重启机器

节点之间SSH互联

  • 使用ssh-keygen生成本机密钥,使用ssh-copy-id username@hostname拷贝密钥

安装和配置libvirt

  • 配置/etc/hosts

注意,hostname的名字必须准确

安装和配置Vagrant

  • 从官网安装Vagrant
rpm -ivh https://releases.hashicorp.com/vagrant/1.9.1/vagrant_1.9.1_x86_64.rpm
  • 安装vagrant-libvirt插件
dnf -y install qemu libvirt libvirt-devel ruby-devel gcc
vagrant plugin install vagrant-libvirt

编写Vagrantfile

其中,master为远程主机,slave为本地主机,远程主机在libvirt.host中设置主机名称

# -*- mode: ruby -*-
# vi: set ft=ruby :

# All Vagrant configuration is done below. The "2" in Vagrant.configure
# configures the configuration version (we support older styles for
# backwards compatibility). Please don't change it unless you know what
# you're doing.
Vagrant.configure("2") do |config|
  config.vm.define "master" do |master|
    master.vm.box = "centos/7"
    master.vm.provider :libvirt do |libvirt|
        libvirt.host = "e2104"
        libvirt.driver = "kvm"
        libvirt.username = "root"
        libvirt.password = "111111"
        libvirt.connect_via_ssh = true
    end
    master.vm.network :public_network, :dev => "eth0", :mode => 'bridge', :ip => "10.0.2.111"
  end

  config.vm.define "slave" do |master|
    master.vm.box = "centos/7"
    master.vm.network :public_network, :dev => "eth0", :mode => 'bridge', :ip => "10.0.2.110"
  end
end

启动虚拟机

vagrant up master
vagrant up slave

注意事项

  • 在安装前如果已经安装了libvirt,则将libvirt完全卸载,并重启服务器
yum remove libvirt libvirt-client
reboot
yum install libvirt libvirt-devel
  • TLS访问是密钥的cn必须是主机名,否则会出错
country = AU
state = Queensland
locality = Brisbane
organization = libvirt.org
cn = e2105  #(必须为主机名)
tls_www_client
encryption_key
signing_key

相关文章

  • 使用libvirt配置多节点的Vagrant集群

    如今很多实验室都装备有大内存,高主频,多核心的高性能服务器,所以很多虚拟机的实验其实是可以在实验室完成的,而且相对...

  • Elasticsearch-config

    集群名称配置:集群不同节点配置相同的集群名称 集群节点配置:集群不同节点配置不同的节点名称 路径配置:数据路劲、日...

  • 13-mongoDB

    重点:使用场景 集群搭建(路由节点,配置节点,分片集群) 安全认证 索引类型(ttl-过期索引 ...

  • NIFI 系统属性 System Properties之Clus

    集群通用属性 设置NiFi集群时,应在所有节点上以相同的方式配置这些属性。 集群节点属性 为集群节点配置这些属性。

  • ubuntu使用kvmgt配置vGPU(qemu-kvm+lib

    ubuntu使用kvmgt配置vGPU(qemu-kvm+libvirt+virt-manager)

  • centos install vagrant with kvm

    先检查一下是否支持KVM 安装kvm等环境 安装vagrant 安装vagrant-libvirt插件 创建kvm...

  • elastic安装的linux设置

    注意es操作不能使用root用户 1.jdk 2.集群 hosts配置 集群名称 节点名称 threadpool,...

  • 多服务器 docker elasticsearch集群

    单服务器 elasticsearch集群手动配置 多服务器 elasticsearch集群 两台服务器, 主节点:...

  • linux docker redis 集群

    节点2和节点3的配置都一样 进入主节点容器,组建集群 注意: redis 必须使用 host 的网络模式,否则在本...

  • redis集群模式配置

    配置redis集群模式 首先配置redis集群模式最好使用3主3从(6个节点)的模式,测试环境中,只能在一台机器上...

网友评论

    本文标题:使用libvirt配置多节点的Vagrant集群

    本文链接:https://www.haomeiwen.com/subject/gxytgttx.html