- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有一个测试服务器连接到我的家庭网络,静态 IP 地址,使用 KVM/Libvirt 虚拟化。为了测试我网络中的某些服务(例如使用手机),我想从我的 SOHO 路由器网络中为这些虚拟机分配 IP - 静态地或使用路由器 DHCP。
所以我的目标是:
在这两种情况下,虚拟机都没有 IP 地址:
由于这些虚拟机是由 Terraform 自动配置的,我认为 SO 是解决这个问题的好地方。
我的 Terraform POC 文件:
terraform {
required_version = ">= 0.13"
required_providers {
libvirt = {
source = "dmacvicar/libvirt"
version = "0.6.2"
}
}
}
resource "libvirt_volume" "centos7-img" {
name = "cnx_centos7.qcow2"
pool = libvirt_pool.default.name
source = "/var/lib/libvirt/images/CentOS-7-x86_64-GenericCloud.qcow2"
format = "qcow2"
}
provider "libvirt" {
uri = "qemu:///system"
}
resource "libvirt_pool" "default" {
name = "default"
type = "dir"
path = "/tmp/kvm"
}
data "template_file" "cloudinit_network" {
template = file("network.cfg")
}
data "template_file" "cloudinit_data" {
template = file("cloudinit.cfg")
vars = {}
}
resource "libvirt_cloudinit_disk" "cloudinit" {
name = "cloudinit.iso"
user_data = data.template_file.cloudinit_data.rendered
network_config = data.template_file.cloudinit_network.rendered
pool = libvirt_pool.default.name
}
resource "libvirt_network" "cnx_network" {
name = "cnx_network"
#addresses = ["192.168.0.17/24"]
mode = "bridge"
bridge = "br0"
dhcp {
enabled = true
}
# Enables usage of the host dns if no local records match
dns {
enabled = true
local_only = false
}
}
resource "libvirt_domain" "cnx" {
name = "cnx-poc"
memory = 2048
vcpu = 4
cloudinit = libvirt_cloudinit_disk.cloudinit.id
network_interface {
network_id = libvirt_network.cnx_network.id
hostname = "cnx.fritz.box"
#addresses = ["192.168.0.10"]
# Required to get ip address in the output when using dhcp
wait_for_lease = true
}
disk {
volume_id = libvirt_volume.centos7-img.id
}
console {
type = "pty"
target_type = "serial"
target_port = "0"
}
console {
type = "pty"
target_type = "virtio"
target_port = "1"
}
graphics {
type = "spice"
listen_type = "address"
autoport = true
}
}
output "ips" {
value = libvirt_domain.cnx.*.network_interface.0.addresses
}
Cloudinit network.cfg
version: 2
ethernets:
eth0:
dhcp4: true
dhcp6: false
# addresses:
# - 192.168.0.10
gateway4: 192.168.0.1
Cloudinit cloudinit.cfg
这并不是真正需要的。我只是设置了一个密码,这样我就可以使用 libvirt 控制台访问 VM 并查看 ip 配置,即使在网络无法正常工作时也是如此。
#cloud-config
password: password
chpasswd:
list: |
root:password
centos:password
expire: false
网桥/etc/netplan/50-cloud-init.yaml
(主机)
# This file is generated from information provided by
# the datasource. Changes to it will not persist across an instance.
# To disable cloud-init's network configuration capabilities, write a file
# /etc/cloud/cloud.cfg.d/99-disable-network-config.cfg with the following:
# network: {config: disabled}
network:
ethernets:
enp6s0:
#addresses: []
dhcp4: no
dhcp6: no
bridges:
br0:
interfaces: [enp6s0]
addresses: [192.168.0.17/24]
gateway4: 192.168.0.1
#mtu: 1500
nameservers:
addresses: [192.168.0.1]
search: ["fritz.box"]
parameters:
stp: true
#forward-delay: 4
dhcp4: no
dhcp6: no
version: 2
测试和应用:
$ sudo netplan generate
$ sudo netplan --debug apply
除了配置文件中注释掉的行之外,我还尝试了以下操作:
我尝试直接在 VM 中引用网桥,而不像这样定义 libvirt 网络:
resource "libvirt_domain" "cnx" {
name = "cnx-poc"
memory = 2048
vcpu = 4
cloudinit = libvirt_cloudinit_disk.cloudinit.id
network_interface {
bridge = "br0"
addresses = ["192.168.0.10"]
}
# ...
这不起作用,我认为这与 this problem of the missing qemu-guest-agent
package 有关.我不能简单地解决这个问题,因为我需要网络访问才能安装它,但这是行不通的。我将尝试研究是否可以添加两个 NIC(1x NAT 1x 网桥)来连接互联网。
但这似乎不是一个好的解决方法。并且在票证中建议创建一个单独的网络。如果该解决方法可行,我不会有任何问题,但到目前为止我还没有运气。
因为我 run into this problem some time ago ,我尝试不指定网络配置:
network_config = data.template_file.cloudinit_network.rendered
我认为这可能会导致虚拟机使用 DHCP,或者至少我从 Terraform 静态分配的 IP 在这种情况下似乎不起作用。
生成的网络如下所示:
$ virsh net-dumpxml cnx_network
<network connections='1'>
<name>cnx_network</name>
<uuid>${removed}</uuid>
<forward mode='bridge'/>
<bridge name='br0'/>
</network>
这在查看 articles like this 时似乎完全有效,谁在解释如何在 Ubuntu 上使用 KVM 和 netplan 手动设置。
此外,使用 virsh dumpxml cnx-poc
检查的 VM 的 xml 中的 interface type='network'
元素看起来不错:
<interface type='network'>
<mac address='${mac}'/>
<source network='cnx_network'/>
<model type='virtio'/>
<address type='pci' domain='0x0000' bus='0x00' slot='0x03' function='0x0'/>
</interface>
最佳答案
原来他的问题是由于libvirt provider plugin的变化引起的.最近我从 0.5.2 更新到 0.6.2。对于所有高于 0.4.2 的版本,default behavior was changed :
Until terraform-provider-libvirt 0.4.2, qemu-agent was used by defaultto get network configuration. However, if qemu-agent is not running,this creates a delay until connecting to it times-out.
In current versions, we default to not to attempt connecting to it,and attempting to retrieve network interface information from theagent needs to be enabled explicitly with qemu_agent = true, furtherdetails here. Note that you still need to make sure the agent isrunning in the OS, and that is unrelated to this option.
Note: when using bridge network configurations you need to enable theqemu_agent = true. otherwise you will not retrieve the ip adresses ofdomains.
Be aware that this variables may be subject to change again in futureversions.
qemu-guest-agent CentOS云镜像中已经安装,无需下载。但是由于更改了 libvirt 提供程序行为,它没有被使用。我还没有注意到这一点,因为我的虚拟机是使用 NAT 构建的。它现在只与我对桥接网络的更改有关。
事实上,这意味着我只需像这样将属性添加到我的 vm 域中:
resource "libvirt_domain" "cnx" {
name = "cnx-poc"
memory = 2048
vcpu = 4
cloudinit = libvirt_cloudinit_disk.cloudinit.id
# Required for bridged networks for libvirt provider plugin > 0.4.2
qemu_agent = true
# ...
}
现在我的虚拟机已经构建完成,它们获得了我的 DHCP 服务器的 IP 地址:
Apply complete! Resources: 8 added, 0 changed, 0 destroyed.
Outputs:
ips = [
[
"192.168.0.163",
"fe80::5054:ff:fe62:2adf",
],
]
ips_db2 = [
[
"192.168.0.162",
"fe80::5054:ff:fe8a:ac6a",
],
]
关于ubuntu - 将来自主机网络的静态/DHCP IP 分配给由 Terraform 提供的 KVM VM,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/65945531/
这与 Payubiz payment gateway sdk 关系不大一体化。但是,主要问题与构建项目有关。 每当我们尝试在模拟器上运行应用程序时。我们得到以下失败: What went wrong:
我有一个现有的应用程序,其中包含在同一主机上运行的 4 个 docker 容器。它们已使用 link 命令链接在一起。 然而,在 docker 升级后,link 行为已被弃用,并且似乎有所改变。我们现
在 Internet 模型中有四层:链路 -> 网络 -> 传输 -> 应用程序。 我真的不知道网络层和传输层之间的区别。当我读到: Transport layer: include congesti
很难说出这里要问什么。这个问题模棱两可、含糊不清、不完整、过于宽泛或夸夸其谈,无法以目前的形式得到合理的回答。如需帮助澄清此问题以便重新打开,visit the help center . 关闭 1
前言: 生活中,我们在上网时,打开一个网页,就可以看到网址,如下: https😕/xhuahua.blog.csdn.net/ 访问网站使用的协议类型:https(基于 http 实现的,只不过在
网络 避免网络问题降低Hadoop和HBase性能的最重要因素可能是所使用的交换硬件,在项目范围的早期做出的决策可能会导致群集大小增加一倍或三倍(或更多)时出现重大问题。 需要考虑的重要事项:
网络 网络峰值 如果您看到定期的网络峰值,您可能需要检查compactionQueues以查看主要压缩是否正在发生。 有关管理压缩的更多信息,请参阅管理压缩部分的内容。 Loopback IP
Pure Data 有一个 loadbang 组件,它按照它说的做:当图形开始运行时发送一个 bang。 NoFlo 的 core/Kick 在其 IN 输入被击中之前不会发送其数据,并且您无法在 n
我有一台 Linux 构建机器,我也安装了 minikube。在 minikube 实例中,我安装了 artifactory,我将使用它来存储各种构建工件 我现在希望能够在我的开发机器上做一些工作(这
我想知道每个视频需要多少种不同的格式才能支持所有主要设备? 在我考虑的主要设备中:安卓手机 + iPhone + iPad . 对具有不同比特率的视频进行编码也是一种好习惯吗? 那里有太多相互矛盾的信
我有一个使用 firebase 的 Flutter Web 应用程序,我有两个 firebase 项目(dev 和 prod)。 我想为这个项目设置 Flavors(只是网络没有移动)。 在移动端,我
我正在读这篇文章Ars article关于密码安全,它提到有一些网站“在传输之前对密码进行哈希处理”? 现在,假设这不使用 SSL 连接 (HTTPS),a.这真的安全吗? b.如果是的话,你会如何在
我试图了解以下之间的关系: eth0在主机上;和 docker0桥;和 eth0每个容器上的接口(interface) 据我了解,Docker: 创建一个 docker0桥接,然后为其分配一个与主机上
我需要编写一个java程序,通过网络将对象发送到客户端程序。问题是一些需要发送的对象是不可序列化的。如何最好地解决这个问题? 最佳答案 发送在客户端重建对象所需的数据。 关于java - 不可序列化对
所以我最近关注了this有关用 Java 制作基本聊天室的教程。它使用多线程,是一个“面向连接”的服务器。我想知道如何使用相同的 Sockets 和 ServerSockets 来发送对象的 3d 位
我想制作一个系统,其中java客户端程序将图像发送到中央服务器。中央服务器保存它们并运行使用这些图像的网站。 我应该如何发送图像以及如何接收它们?我可以使用同一个网络服务器来接收和显示网站吗? 最佳答
我正在尝试设置我的 rails 4 应用程序,以便它发送电子邮件。有谁知道我为什么会得到: Net::SMTPAuthenticationError 534-5.7.9 Application-spe
我正在尝试编写一个简单的客户端-服务器程序,它将客户端计算机连接到服务器计算机。 到目前为止,我的代码在本地主机上运行良好,但是当我将客户端代码中的 IP 地址替换为服务器计算机的本地 IP 地址时,
我需要在服务器上并行启动多个端口,并且所有服务器套接字都应在 socket.accept() 上阻塞。 同一个线程需要启动客户端套接字(许多)来连接到特定的 ServerSocket。 这能实现吗?
我的工作执行了大约 10000 次以下任务: 1) HTTP 请求(1 秒) 2)数据转换(0.3秒) 3)数据库插入(0.7秒) 每次迭代的总时间约为 2 秒,分布如上所述。 我想做多任务处理,但我
我是一名优秀的程序员,十分优秀!