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 / unix / Perguntas / 784259
Accepted
Matt Ellis
Matt Ellis
Asked: 2024-09-29 17:51:12 +0800 CST2024-09-29 17:51:12 +0800 CST 2024-09-29 17:51:12 +0800 CST

Montando câmera usando jmtpfs dentro de uma regra udev

  • 772

Estou tentando usar jmtpfsminha GoPro para transferir arquivos quando a conecto ao meu computador.

Tenho um script que funciona fora de uma regra udev. No entanto, quando executado dentro da regra udev, o script falha e desconecta meu dispositivo USB.

Um exemplo mínimo de funcionamento é dado aqui:

roteiro

#!/usr/bin/env bash
jmtpfs /media/GoPro > /tmp/gopro.log 2> /tmp/gopro.err

regra udev

SUBSYSTEM=="usb", ATTR{idVendor}=="2672", ATTR{idProduct}=="004b", ACTION=="add", RUN+="/bin/bash -c /home/matt/Projects/GoProScraping/scripts/grab_go_pro_files.sh"

A saída do arquivo /tmp/gopro.erré:

Device 0 (VID=2672 and PID=004b) is UNKNOWN in libmtp v1.1.19.
Please report this VID/PID and the device model to the libmtp development team
fusermount: mount failed: Operation not permitted

A saída de journalctl -fé:

Sep 29 09:45:31 nina kernel: usb 1-4: new high-speed USB device number 16 using xhci_hcd
Sep 29 09:45:31 nina kernel: usb 1-4: New USB device found, idVendor=2672, idProduct=004b, bcdDevice= 0.01
Sep 29 09:45:31 nina kernel: usb 1-4: New USB device strings: Mfr=1, Product=2, SerialNumber=3
Sep 29 09:45:31 nina kernel: usb 1-4: Product: GoPro MAX
Sep 29 09:45:31 nina kernel: usb 1-4: Manufacturer: GoPro
Sep 29 09:45:31 nina kernel: usb 1-4: SerialNumber: C3351325091705
Sep 29 09:45:31 nina sudo[1455]:     root : PWD=/ ; USER=root ; COMMAND=/usr/bin/jmtpfs /media/GoPro
Sep 29 09:45:31 nina sudo[1455]: pam_unix(sudo:session): session opened for user root(uid=0) by (uid=0)
Sep 29 09:45:34 nina sudo[1455]: pam_unix(sudo:session): session closed for user root
Sep 29 09:45:34 nina kernel: usb 1-4: USB disconnect, device number 16
Sep 29 09:45:34 nina systemd-udevd[1453]: 1-4: Process '/bin/bash -c /home/matt/Projects/GoProScraping/scripts/grab_go_pro_files.sh' failed with exit code 1.

Parece que eu conecto a GoPro, o udev detecta que ela está conectada, então ocorre um erro de permissão e o erro faz com que o USB seja desconectado e então o udev detecta novamente.

Entretanto, se eu tentar executar o comando: jmtpfs /media/GoProcomo usuário root, ele monta bem e eu consigo acessar os arquivos manualmente.

Achei que as regras do udev eram executadas como root. O que estou esquecendo?

usb
  • 1 1 respostas
  • 17 Views

1 respostas

  • Voted
  1. Best Answer
    telcoM
    2024-09-29T22:04:30+08:002024-09-29T22:04:30+08:00

    Você pode estar tentando seguir conselhos obsoletos. Executar coisas arbitrárias a partir de regras udev costumava ser possível, mas então uma falha de segurança foi encontrada e algumas restrições foram aplicadas. Agora, o systemd-udevdprocesso de serviço geralmente é sandboxed, o que limita suas ações diretas a basicamente apenas criar, sondar e excluir nós de dispositivos. Mas ele ainda pode dizer systemdpara iniciar outras coisas.

    Em sistemas modernos, o capítulo sobre a RUNpalavra-chave man udevdiz:

    Isso só pode ser usado para tarefas de foreground de execução muito curta. Executar um processo de evento por um longo período de tempo pode bloquear todos os eventos futuros para este ou um dispositivo dependente.

    Observe que a execução de programas que acessam a rede ou montam/desmontam sistemas de arquivos não é permitida dentro das regras do udev, devido ao sandbox padrão que é imposto em systemd-udevd.service.

    Não é permitido iniciar daemons ou outros processos de execução longa ; os processos bifurcados, desanexados ou não, serão mortos incondicionalmente após o término do tratamento de eventos. Para ativar processos de execução longa a partir de regras do udev, forneça uma unidade de serviço e puxe-a de um dispositivo udev usando a propriedade de dispositivo SYSTEMD_WANTS. Veja systemd.device(5) para detalhes.

    Então, primeiro crie um arquivo de serviço, por exemplo /etc/systemd/system/gopro-jmtpfs.service, com o seguinte conteúdo:

    [Unit]
    Description=Mount GoPro when plugged in
    After=local-fs.target
    
    [Service]
    Type=exec
    # if your systemd does not have Type=exec, use Type=simple instead
    ExecStart=/usr/bin/jmtpfs /media/GoPro
    

    Isto define uma unidade estática , que não pode ser iniciada manualmente. Ela será acionada por uma regra udev mais tarde.

    E outro serviço para seu script de captura de arquivos, por exemplo /etc/systemd/system/gopro-grabfiles.service:

    [Unit]
    Description=Grab files from a mounted GoPro
    After=gopro-jmtpfs.service
    ConditionPathIsMountPoint=/media/GoPro
    
    [Service]
    Type=oneshot
    ExecStart=/bin/bash -c /home/matt/Projects/GoProScraping/scripts/grab_go_pro_files.sh
    
    [Install]
    WantedBy=gopro-jmtpfs.service
    

    Após criar o arquivo de serviço, lembre-se de executar systemctl daemon-reloadpara que ele tenha efeito.

    Em seguida, crie uma regra udev para sua GoPro como esta:

    SUBSYSTEM=="usb", ATTR{idVendor}=="2672", ATTR{idProduct}=="004b", TAG+="systemd", SYSTEMD_WANTS+="gopro-jmtpfs.service"
    

    Agora, o gopro-jmtpfs.servicedeve ser iniciado automaticamente quando a GoPro for conectada e gopro-grabfiles.servicedeve ser acionado após o primeiro serviço começar a ser executado.

    Marcar uma regra udev com TAG+="systemd"deve fazer com systemdque o dispositivo em questão fique ciente disso, resultando em uma *.deviceunidade sendo criada automaticamente para ele. Você poderá usar isso para systemdautomação baseada em mais, se desejar.

    Por padrão, o nome da unidade do dispositivo será uma sys-devices-pci...-usb....devicesequência longa e estranha, mas você pode adicionar ENV{SYSTEMD_ALIAS}="/sys/subsystem/usb/somename"à sua regra udev para obter um nome de unidade de dispositivo mais gerenciável.

    • 0

relate perguntas

  • Inicialização sem cabeça e instalação no mesmo dispositivo USB

  • Como inserir com segurança o pendrive/dispositivo USB no computador Linux?

  • Como instalar o pacote pppoe do usb em vez do cdrom?

  • Como modificar um stick USB para ter um nó de dispositivo como /dev/sda1 em vez de /dev/sda?

  • Use USBIP para dispositivos que estão sendo removidos e reconectados

Sidebar

Stats

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

    Possível firmware ausente /lib/firmware/i915/* para o módulo i915

    • 3 respostas
  • Marko Smith

    Falha ao buscar o repositório de backports jessie

    • 4 respostas
  • Marko Smith

    Como exportar uma chave privada GPG e uma chave pública para um arquivo

    • 4 respostas
  • Marko Smith

    Como podemos executar um comando armazenado em uma variável?

    • 5 respostas
  • Marko Smith

    Como configurar o systemd-resolved e o systemd-networkd para usar o servidor DNS local para resolver domínios locais e o servidor DNS remoto para domínios remotos?

    • 3 respostas
  • Marko Smith

    apt-get update error no Kali Linux após a atualização do dist [duplicado]

    • 2 respostas
  • Marko Smith

    Como ver as últimas linhas x do log de serviço systemctl

    • 5 respostas
  • Marko Smith

    Nano - pule para o final do arquivo

    • 8 respostas
  • Marko Smith

    erro grub: você precisa carregar o kernel primeiro

    • 4 respostas
  • Marko Smith

    Como baixar o pacote não instalá-lo com o comando apt-get?

    • 7 respostas
  • Martin Hope
    user12345 Falha ao buscar o repositório de backports jessie 2019-03-27 04:39:28 +0800 CST
  • Martin Hope
    Carl Por que a maioria dos exemplos do systemd contém WantedBy=multi-user.target? 2019-03-15 11:49:25 +0800 CST
  • Martin Hope
    rocky Como exportar uma chave privada GPG e uma chave pública para um arquivo 2018-11-16 05:36:15 +0800 CST
  • Martin Hope
    Evan Carroll status systemctl mostra: "Estado: degradado" 2018-06-03 18:48:17 +0800 CST
  • Martin Hope
    Tim Como podemos executar um comando armazenado em uma variável? 2018-05-21 04:46:29 +0800 CST
  • Martin Hope
    Ankur S Por que /dev/null é um arquivo? Por que sua função não é implementada como um programa simples? 2018-04-17 07:28:04 +0800 CST
  • Martin Hope
    user3191334 Como ver as últimas linhas x do log de serviço systemctl 2018-02-07 00:14:16 +0800 CST
  • Martin Hope
    Marko Pacak Nano - pule para o final do arquivo 2018-02-01 01:53:03 +0800 CST
  • Martin Hope
    Kidburla Por que verdadeiro e falso são tão grandes? 2018-01-26 12:14:47 +0800 CST
  • Martin Hope
    Christos Baziotis Substitua a string em um arquivo de texto enorme (70 GB), uma linha 2017-12-30 06:58:33 +0800 CST

Hot tag

linux bash debian shell-script text-processing ubuntu centos shell awk 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