Eu gostaria de construir um trecho debian para rodar no vagrant com o provedor libvirt.
Eu tentei construir do zero e também com o empacotador e o melhor que eu consigo é um erro de sistema operacional não encontrado na reinicialização ou um congelamento na parte superior da caixa.
Quando não estiver usando o packer, eu posso inicializar a caixa dentro do virt-manager e ele funciona, mas ele não recebe acesso à rede se eu fizer um vagrant na mesma caixa. O Packer deve simplificar isso, mas recebo um erro sem mídia encontrada na inicialização.
Inicializando com o Vagrant, ele congela no ponto de == > padrão: Aguardando que o domínio obtenha um endereço IP.
Se eu, então, anexar à tela da máquina através do / virt-manager / eu vejo congelado após
acpid: aguardando eventos: o log de eventos está desativado
Onde estou indo errado?
Existe a necessidade de um passo manual extra após a saída deste script de empacotador.
Aqui está o modelo de empacotador que uso
{
"variables": {
"user": "vagrant",
"password": "vagrant",
"disk_size": "100000",
"domain": ""
},
"builders": [
{
"name": "debian93-vagrant",
"type": "qemu",
"format": "qcow2",
"accelerator": "kvm",
"disk_size": "{{ user 'disk_size' }}",
"iso_url": "https://cdimage.debian.org/debian-cd/9.3.0/amd64/iso-cd/debian-9.3.0-amd64-netinst.iso",
"iso_checksum": "83480be837710a76fd4e75a6573ca110e06f5a7589d2d3852bdb0f45749800b3",
"iso_checksum_type": "sha256",
"http_directory": "http",
"ssh_username": "{{ user 'user' }}",
"ssh_password": "{{ user 'password' }}",
"shutdown_command": "echo '{{ user 'password' }}' | sudo -S shutdown -h now",
"ssh_wait_timeout": "60m",
"boot_wait": "2s",
"boot_command": [
"<esc><wait><wait>",
"install ",
"auto=true ",
"priority=critical ",
"interface=auto ",
"url=http://{{ .HTTPIP }}:{{ .HTTPPort }}/preseed.cfg ",
"passwd/user-fullname={{ user 'user' }} ",
"passwd/user-password={{ user 'password' }} ",
"passwd/user-password-again={{ user 'password' }} ",
"passwd/username={{ user 'user' }} ",
"<enter>"
]
}
],
"provisioners": [
{
"type": "shell",
"execute_command": "echo '{{ user 'password' }}' | {{ .Vars }} sudo -E -S bash '{{ .Path }}'",
"scripts": [
"scripts/vagrant.sh",
"scripts/update.sh",
"scripts/packages.sh",
"scripts/cleanup.sh"
]
}
],
"post-processors": [
{
"keep_input_artifact": false,
"output": "box/debian93-vagrant.box",
"type": "vagrant"
}
]
}
E o arquivo do Vagrant para inicializá-lo
ENV['VAGRANT_DEFAULT_PROVIDER'] = 'libvirt'
# 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|
# TODO build our own and deploy it to vagrantboxes
# config.vm.box = "debian/jessie64"
config.vm.box = "debian93Vagrant"
# config.vm.box = ""
#config.vm.box_version = "0.0.1"
# Remove or adapt host_ip if remote access is required
config.vm.network "forwarded_port", guest: 5601, host: 5601, host_ip: "127.0.0.1"
config.vm.network "forwarded_port", guest: 9200, host: 9200, host_ip: "127.0.0.1"
config.vm.network "forwarded_port", guest: 5044, host: 5044, host_ip: "127.0.0.1"
# Create a private network, which allows host-only access to the machine
# using a specific IP.
config.vm.network "private_network", ip: "192.168.121.10"
# Create a public network, which generally matched to bridged network.
# Bridged networks make the machine appear as another physical device on
# your network.
# config.vm.network "public_network"
# If more folders are needed map them here
# config.vm.synced_folder ".", "/vagrant"
config.vm.synced_folder "./config", "/config"
# Libvirt provider with added oomph
config.vm.provider :libvirt do |prov|
prov.memory = 4096
prov.cpus = 4
end
# Basic setup through a shell provisioner
config.vm.provision "shell", inline: <<-SHELL
apt-get update
apt-get upgrade -y
apt-get install net-tools htop
sleep 5
SHELL
# Deploy the stack
config.vm.provision "ansible" do |an|
an.playbook = "./ansible/single_machine.yml"
end
# Leave things running permanently post installation
config.vm.provision "shell", inline: <<-SHELL
systemctl enable logstash
systemctl enable elasticsearch
systemctl enable kibana
service kibana start
service elasticsearch start
service logstash start
SHELL
end
Outras investigações revelam a seguinte discordância nos endereços MAC Dentro da imagem inicializada (acessada através do virt-manager): 52: 54: 00: a0: 46: 68 No Vagrant (da saída de depuração): mac="52: 54: 00: 9e: ad: 85" E a partir da mensagem de erro: DEBUG wait_till_up: Pesquisando por IP para endereço MAC: 52: 54: 00: b8: 88: 7d
Além disso, os UUIDs dos domínios não são os mesmos: Vagrant dá: id="24e1487f-c36f-4cc3-a45e-4d8c6d867a4d" Relatórios virt-manager: c4d152fd-6da4-4b09-bb98-96767b367a6c
O que poderia causar a incompatibilidade?