AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • Início
  • system&network
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • Início
  • system&network
    • Recentes
    • Highest score
    • tags
  • Ubuntu
    • Recentes
    • Highest score
    • tags
  • Unix
    • Recentes
    • tags
  • DBA
    • Recentes
    • tags
  • Computer
    • Recentes
    • tags
  • Coding
    • Recentes
    • tags
Início / server / Perguntas / 1135321
Accepted
e-info128
e-info128
Asked: 2023-07-01 05:20:43 +0800 CST2023-07-01 05:20:43 +0800 CST 2023-07-01 05:20:43 +0800 CST

Como usar o endereço IP do host específico no kvm?

  • 772

Tenha um host Ubuntu Server dedicado com uma única interface de rede, mas com dois endereços IP:

root@server:~# cat /etc/netplan/50-cloud-init.yaml 
network:
    version: 2
    ethernets:
        eno3:
            dhcp4: true
            match:
                macaddress: 00:00:00:00:00:00
            set-name: eno3
            addresses: [IP-A/24, IP-B/32]

Quando IP-Aé o endereço IP nativo atribuído ao servidor e IP-Bé um endereço IP adicional que contratei. Ao configurar usando netplan applytudo funciona muito bem, o servidor WEB sai pelo endereço IP IP-Ae pelo curl consigo ver como é possível acessar a internet de IP-B:

wget -qO- http://checkip.dyndns.com/ --bind-address IP-A
... Current IP Address: IP-A
wget -qO- http://checkip.dyndns.com/ --bind-address IP-B
... Current IP Address: IP-B

O problema é que também tenho uma máquina virtual com kvm( virsh), como posso fazer a máquina virtual sair para a internet usando IP-Be não IP-Acomo faz por padrão?

Minhas interfaces de rede:

root@yhojann:~# ip addr
1: lo: <LOOPBACK,UP,LOWER_UP> mtu 65536 qdisc noqueue state UNKNOWN group default qlen 1000
    link/loopback 00:00:00:00:00:00 brd 00:00:00:00:00:00
    inet 127.0.0.1/8 scope host lo
       valid_lft forever preferred_lft forever
2: eno3: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc mq state UP group default qlen 1000
    link/ether 11:11:11:11:11:11 brd ff:ff:ff:ff:ff:ff
    inet IP-A/24 brd x.x.x.255 scope global dynamic eno3
       valid_lft 63801sec preferred_lft 63801sec
    inet IP-B/32 scope global eno3
       valid_lft forever preferred_lft forever
    inet6 ffff::fff:ffff:ffff:ffff/64 scope link 
       valid_lft forever preferred_lft forever
3: eno4: <BROADCAST,MULTICAST> mtu 1500 qdisc noop state DOWN group default qlen 1000
    link/ether 22:22:22:22:22:22 brd ff:ff:ff:ff:ff:ff
17: virbr0: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc noqueue state UP group default qlen 1000
    link/ether 33:33:33:33:33:33 brd ff:ff:ff:ff:ff:ff
    inet 192.168.122.1/24 brd 192.168.122.255 scope global virbr0
       valid_lft forever preferred_lft forever
18: virbr0-nic: <BROADCAST,MULTICAST> mtu 1500 qdisc fq_codel master virbr0 state DOWN group default qlen 1000
    link/ether 44:44:44:44:44:44 brd ff:ff:ff:ff:ff:ff
20: vnet0: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc fq_codel master virbr0 state UNKNOWN group default qlen 1000
    link/ether 44:44:44:44:44:44 brd ff:ff:ff:ff:ff:ff

Eu tentei descobrir se é possível configurar a rede kvm usandovirsh net-edit default

mas não encontrei nenhuma referência que permita fazer uso de um endereço ip de saída específico do host principal sem ter que usar uma nova interface virtual e redirecionar pacotes com iptables, pois isso causa uma grande latência na conectividade.

Existe uma maneira mais "nativa" de dizer ao kvm para usar o IP específico?

Os endereços IP e endereços mac mostrados são apenas para referência. Eu utilizo o ufw para gerenciar as conexões.

kvm-virtualization
  • 1 1 respostas
  • 27 Views

1 respostas

  • Voted
  1. Best Answer
    larsks
    2023-07-01T06:10:10+08:002023-07-01T06:10:10+08:00

    Para atribuir IP-B à máquina virtual:

    • Crie uma interface de ponte.

    • Mova-se eno3para a ponte.

      Observe que isso provavelmente resultará em perda de conectividade de rede, portanto, certifique-se de estar executando essas alterações em algum tipo de conexão fora de banda (como um console serial ou console gráfico).

      Exatamente como executar essas etapas de maneira persistente varia de distribuição para distribuição; o que quer que você esteja usando, tenho certeza de que encontrará a documentação apropriada.

    • Atribua IP-A ao dispositivo de ponte.

    • Anexe sua máquina virtual à ponte.

      Se você estiver criando sua vm usando virt-install, isso pode se parecer com:

      virt-install --network bridge=br0 ...
      

      Se você estiver criando o domínio XML manualmente, isso significa uma <interface>estrofe como esta:

      <interface type="bridge">
        <source bridge="br0"/>
        <model type="virtio"/>
      </interface>
      
    • Atribua eth0(ou qualquer que seja a interface chamada) dentro da máquina virtual IP-B

    Isso lhe dá:

    insira a descrição da imagem aqui

    Tanto seu host quanto sua máquina virtual estão conectados à mesma rede.

    • 1

relate perguntas

Sidebar

Stats

  • Perguntas 205573
  • respostas 270741
  • best respostas 135370
  • utilizador 68524
  • Highest score
  • respostas
  • Marko Smith

    Você pode passar usuário/passar para autenticação básica HTTP em parâmetros de URL?

    • 5 respostas
  • Marko Smith

    Ping uma porta específica

    • 18 respostas
  • Marko Smith

    Verifique se a porta está aberta ou fechada em um servidor Linux?

    • 7 respostas
  • Marko Smith

    Como automatizar o login SSH com senha?

    • 10 respostas
  • Marko Smith

    Como posso dizer ao Git para Windows onde encontrar minha chave RSA privada?

    • 30 respostas
  • Marko Smith

    Qual é o nome de usuário/senha de superusuário padrão para postgres após uma nova instalação?

    • 5 respostas
  • Marko Smith

    Qual porta o SFTP usa?

    • 6 respostas
  • Marko Smith

    Linha de comando para listar usuários em um grupo do Windows Active Directory?

    • 9 respostas
  • Marko Smith

    O que é um arquivo Pem e como ele difere de outros formatos de arquivo de chave gerada pelo OpenSSL?

    • 3 respostas
  • Marko Smith

    Como determinar se uma variável bash está vazia?

    • 15 respostas
  • Martin Hope
    Davie Ping uma porta específica 2009-10-09 01:57:50 +0800 CST
  • Martin Hope
    kernel O scp pode copiar diretórios recursivamente? 2011-04-29 20:24:45 +0800 CST
  • Martin Hope
    Robert ssh retorna "Proprietário incorreto ou permissões em ~/.ssh/config" 2011-03-30 10:15:48 +0800 CST
  • Martin Hope
    Eonil Como automatizar o login SSH com senha? 2011-03-02 03:07:12 +0800 CST
  • Martin Hope
    gunwin Como lidar com um servidor comprometido? 2011-01-03 13:31:27 +0800 CST
  • Martin Hope
    Tom Feiner Como posso classificar a saída du -h por tamanho 2009-02-26 05:42:42 +0800 CST
  • Martin Hope
    Noah Goodrich O que é um arquivo Pem e como ele difere de outros formatos de arquivo de chave gerada pelo OpenSSL? 2009-05-19 18:24:42 +0800 CST
  • Martin Hope
    Brent Como determinar se uma variável bash está vazia? 2009-05-13 09:54:48 +0800 CST

Hot tag

linux nginx windows networking ubuntu domain-name-system amazon-web-services active-directory apache-2.4 ssh

Explore

  • Início
  • Perguntas
    • Recentes
    • Highest score
  • tag
  • help

Footer

AskOverflow.Dev

About Us

  • About Us
  • Contact Us

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve