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 / computer / Perguntas / 1520819
Accepted
Greg0ry
Greg0ry
Asked: 2020-01-29 05:38:07 +0800 CST2020-01-29 05:38:07 +0800 CST 2020-01-29 05:38:07 +0800 CST

Execute openvpn como usuário não root

  • 772

Estou tentando executar o servidor openvpn dentro do contêiner podman sem privilégios.

O Openvpn precisa ser capaz de gerenciar interfaces de rede (ou seja, criar uma interface tun, atribuir um endereço IP a ela, criá-la). No meu sistema (arch linux) dentro openvpn-server.serviceeu notei CapabilityBoundingSete isso me fez experimentar e criar meu próprio serviço que ao invés de rodar o openvpn vai rodar podman run.

Primeiro criei meu container openvpn, abaixo está o Dockerfile (usei archlinux como base por conveniência):

FROM archlinux
RUN pacman -Sy --noconfirm openvpn

Eu então construo este contêiner (sendo logado como my_unprivileged_user)

podman build \
--force-rm \
--no-cache \
--rm \
--device=/dev/net/tun \
-t openvpn .

Então eu criei my_custom_openvpn.service:

Description=OpenVPN in Podman container
After=syslog.target network-online.target
Wants=network-online.target

[Service]
User=my_unprivileged_user
Group=my_unprivileged_group
WorkingDirectory=/etc/openvpn
ExecStart=/usr/bin/podman run --rm --name openvpn -v ./server:/server --device /dev/net/tun --network "host" --cap-add CAP_IPC_LOCK,CAP_NET_ADMIN,CAP_NET_BIND_SERVICE,CAP_NET_RAW,CAP_SETGID,CAP_SETUID,CAP_SYS_CHROOT,CAP_DAC_OVERRIDE,CAP_AUDIT_WRITE localhost/openvpn:latest /usr/bin/openvpn --config /server/my_config.conf
ExecStop=/usr/bin/podman stop -t 0 openvpn
Capabilities=CAP_IPC_LOCK CAP_NET_ADMIN CAP_NET_BIND_SERVICE CAP_NET_RAW CAP_SETGID CAP_SETUID CAP_SYS_CHROOT CAP_DAC_OVERRIDE CAP_AUDIT_WRITE
DeviceAllow=/dev/null rw
DeviceAllow=/dev/net/tun rw
#ProtectSystem=true
#ProtectHome=true
RestartSec=5s
Restart=on-failure
TimeoutSec=5s

[Install]
WantedBy=multi-user.target

Então, pensei que o systemd passaria os recursos para o podman, que por sua vez os passaria para o openvpn.

Mas o openvpn falha ao começar a reclamar que não pode criar a interface tun0. Mesmo se eu mesmo criar o tun0 assim openvpn --mktun --dev tun0, recebo outro erro de que o openvpn não pode configurar esta interface tun0.

Achei que talvez precisasse fazer setcapdentro do container, então entrei podman execnele e executei abaixo:

setcap CAP_IPC_LOCK,CAP_NET_ADMIN,CAP_NET_BIND_SERVICE,CAP_NET_RAW,CAP_SETGID,CAP_SETUID,CAP_SYS_CHROOT,CAP_DAC_OVERRIDE,CAP_AUDIT_WRITE=+ep /usr/bin/openvpn

Mas isso não ajudou. Eu continuo recebendo esse erro:

Tue Jan 28 13:34:31 2020 /usr/bin/ip link set dev tun0 up mtu 1500
RTNETLINK answers: Operation not permitted

Talvez tentar usar recursos como esse não faça sentido?

openvpn privileges
  • 1 1 respostas
  • 2124 Views

1 respostas

  • Voted
  1. Best Answer
    Greg0ry
    2020-02-15T11:39:09+08:002020-02-15T11:39:09+08:00

    Consegui fazer o openvpn funcionar substituindo ipdentro do contêiner pelo script bash que sempre retorna 0. Achei que a única coisa que o openvpn tenta fazer é configurar tun0e, em seguida, atribuir o endereço IP e ativá-lo. Decidi fazer isso manualmente de fora do contêiner (como root) e, portanto, o openvpn não precisa fazer isso. Eu descrevi o procedimento no wiki openvpn aqui

    • 1

relate perguntas

  • O arquivo de configuração Openvpn funciona com CLI, mas não com o gerenciador de rede

  • Por que Little Snitch negou uma conexão de entrada para openvpn de vpn.btguard.com?

  • OpenVPNServiceInteractive não foi iniciado. Tarefas que requerem acesso administrativo podem não funcionar

  • Selecione o servidor de destino VPN aleatório ao iniciar o openVPN com systemd

  • Impossível fazer o openVPN funcionar

Sidebar

Stats

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

    Como posso reduzir o consumo do processo `vmmem`?

    • 11 respostas
  • Marko Smith

    Baixar vídeo do Microsoft Stream

    • 4 respostas
  • Marko Smith

    O Google Chrome DevTools falhou ao analisar o SourceMap: chrome-extension

    • 6 respostas
  • Marko Smith

    O visualizador de fotos do Windows não pode ser executado porque não há memória suficiente?

    • 5 respostas
  • Marko Smith

    Como faço para ativar o WindowsXP agora que o suporte acabou?

    • 6 respostas
  • Marko Smith

    Área de trabalho remota congelando intermitentemente

    • 7 respostas
  • Marko Smith

    O que significa ter uma máscara de sub-rede /32?

    • 6 respostas
  • Marko Smith

    Ponteiro do mouse movendo-se nas teclas de seta pressionadas no Windows?

    • 1 respostas
  • Marko Smith

    O VirtualBox falha ao iniciar com VERR_NEM_VM_CREATE_FAILED

    • 8 respostas
  • Marko Smith

    Os aplicativos não aparecem nas configurações de privacidade da câmera e do microfone no MacBook

    • 5 respostas
  • Martin Hope
    CiaranWelsh Como posso reduzir o consumo do processo `vmmem`? 2020-06-10 02:06:58 +0800 CST
  • Martin Hope
    Jim Pesquisa do Windows 10 não está carregando, mostrando janela em branco 2020-02-06 03:28:26 +0800 CST
  • Martin Hope
    v15 Por que uma conexão de Internet gigabit/s via cabo (coaxial) não oferece velocidades simétricas como fibra? 2020-01-25 08:53:31 +0800 CST
  • Martin Hope
    fixer1234 O "HTTPS Everywhere" ainda é relevante? 2019-10-27 18:06:25 +0800 CST
  • Martin Hope
    andre_ss6 Área de trabalho remota congelando intermitentemente 2019-09-11 12:56:40 +0800 CST
  • Martin Hope
    Riley Carney Por que colocar um ponto após o URL remove as informações de login? 2019-08-06 10:59:24 +0800 CST
  • Martin Hope
    zdimension Ponteiro do mouse movendo-se nas teclas de seta pressionadas no Windows? 2019-08-04 06:39:57 +0800 CST
  • Martin Hope
    jonsca Todos os meus complementos do Firefox foram desativados repentinamente, como posso reativá-los? 2019-05-04 17:58:52 +0800 CST
  • Martin Hope
    MCK É possível criar um código QR usando texto? 2019-04-02 06:32:14 +0800 CST
  • Martin Hope
    SoniEx2 Altere o nome da ramificação padrão do git init 2019-04-01 06:16:56 +0800 CST

Hot tag

windows-10 linux windows microsoft-excel networking ubuntu worksheet-function bash command-line hard-drive

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