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 / ubuntu / Perguntas / 1313547
Accepted
Mr. T
Mr. T
Asked: 2021-02-05 03:00:03 +0800 CST2021-02-05 03:00:03 +0800 CST 2021-02-05 03:00:03 +0800 CST

Linux KVM: Faça permissões de pasta mapeada/compartilhada RW para host e convidado

  • 772

Estou arrancando os cabelos tentando resolver esse problema de permissões em que os arquivos criados pelo convidado não podem ser acessados ​​no host.

Configurar:

Eu tenho um host Ubuntu 20.04 e um convidado Ubuntu 20.04 rodando através do KVM. Eu tenho uma configuração de montagem compartilhada no modo mapeado . O diretório do host pode ser /home/user/VMs/shared/syncthing/acessado por meio do guest vm em /hostmount. Estou montando de dentro do convidado com sudo mount -t 9p -o trans=virtio,version=9p2000.L /hostmount /hostmount. A VM convidada é iniciada usando virt-manager na conta normal user.

Status atual:

  • O host pode criar arquivos no compartilhamento que podem ser lidos e modificados pelo convidado.
  • O convidado pode criar arquivos no compartilhamento, mas eles não podem ser lidos ou modificados pelo usuário do host.

Se eu for touch /hostmount/test.filede dentro do convidado como usuário regular user, no lado do host, vejo as seguintes permissões para ls –l test.file:

-rw------- 1 libvirt-qemu kvm 0 Feb 4 02:51 /home/user/VMs/shared/syncthing/test.file

Situação Desejada:

Claro, eu poderia chowno arquivo após a criação, mas como faço:

  • Forçar a VM convidada a criar arquivos como userno host
  • Conceda userno host acesso a arquivos criados por guest vm ( libvirt-qemuno host)

Eu tentei as sugestões desta resposta . Eles funcionam em arquivos pré-existentes, mas não funcionam quando o convidado cria novos arquivos.

permissions
  • 1 1 respostas
  • 2470 Views

1 respostas

  • Voted
  1. Best Answer
    Mr. T
    2021-02-05T07:12:53+08:002021-02-05T07:12:53+08:00

    Encontrei uma maneira de resolver isso neste post relacionado, embora suponha que exista uma solução mais elegante. Se você estiver executando sua VM a partir da linha de comando, basta adicionar as opções fmodee dmodeao comando. Por exemplo: --filesystem "/path/to/share","sharename",mode=mapped,fmode='0777',dmode='0777'. Isso tornaria o diretório gravável por todo o mundo.

    Se você estiver usando libvirt xml ou virt-manager, poderá excluir sua pasta compartilhada existente e adicionar este xml logo antes do final do arquivo <domain>. Observe que você pode ter que ajustar alguns desses parâmetros, não sei o que todos eles fazem.

       <qemu:commandline>
            <qemu:arg value="-fsdev"/>
            <qemu:arg value="local,security_model=mapped,id=fsdev-fs0,path=/path/to/share,fmode=0777,dmode=0777"/>
            <qemu:arg value="-device"/>
            <qemu:arg value="virtio-9p-pci,id=fs0,fsdev=fsdev-fs0,mount_tag=sharename,bus=pci.1,addr=0x0"/>
          </qemu:commandline>
    

    Se você estiver no Ubuntu como eu, também precisará editar o seu /etc/apparmor.d/abstractions/libvirt-qemue adicionar a linha /path/to/share/{,**} rw,ao final dele. Isso concede a TODOS os convidados acesso a esse caminho.

    • 0

relate perguntas

Sidebar

Stats

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

    Existe um comando para listar todos os usuários? Também para adicionar, excluir, modificar usuários, no terminal?

    • 9 respostas
  • Marko Smith

    Como excluir um diretório não vazio no Terminal?

    • 4 respostas
  • Marko Smith

    Como descompactar um arquivo zip do Terminal?

    • 9 respostas
  • Marko Smith

    Como instalo um arquivo .deb por meio da linha de comando?

    • 11 respostas
  • Marko Smith

    Como instalo um arquivo .tar.gz (ou .tar.bz2)?

    • 14 respostas
  • Marko Smith

    Como listar todos os pacotes instalados

    • 24 respostas
  • Martin Hope
    Flimm Como posso usar o docker sem sudo? 2014-06-07 00:17:43 +0800 CST
  • Martin Hope
    led-Zepp Como faço para salvar a saída do terminal em um arquivo? 2014-02-15 11:49:07 +0800 CST
  • Martin Hope
    ubuntu-nerd Como descompactar um arquivo zip do Terminal? 2011-12-11 20:37:54 +0800 CST
  • Martin Hope
    TheXed Como instalo um arquivo .deb por meio da linha de comando? 2011-05-07 09:40:28 +0800 CST
  • Martin Hope
    Ivan Como listar todos os pacotes instalados 2010-12-17 18:08:49 +0800 CST
  • Martin Hope
    David Barry Como determino o tamanho total de um diretório (pasta) na linha de comando? 2010-08-06 10:20:23 +0800 CST
  • Martin Hope
    jfoucher "Os seguintes pacotes foram retidos:" Por que e como resolvo isso? 2010-08-01 13:59:22 +0800 CST
  • Martin Hope
    David Ashford Como os PPAs podem ser removidos? 2010-07-30 01:09:42 +0800 CST

Hot tag

10.10 10.04 gnome networking server command-line package-management software-recommendation sound xorg

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