Dossier par défaut lors d'une connection vsftpd

Bonjour,
Je n’avais pas vu ce guide plus linuxien que raspbien. :rofl:
Je me suis basé sur https://linuxize.com/post/how-to-setup-ftp-server-with-vsftpd-on-raspberry-pi/
Et tout simplement LA référence Manpage of VSFTPD.CONF
C’est en anglais, mais même traduit ce n’est pas un avantage pour moi car l’informatique est un vaste domaine et je suis tout petit dans les télécoms.
Quels autres logs pourrais-je consulter ?
Bien à toi et encore merci pour ta réponse

Dans ls /var/log.
Tu as quelques logs système (messages, syslog, daemon par exemple) qui peuvent avoir des traces d’activité du FTP, et peut-être te dire une erreur de le part qui fait que VSFTP agis de manière non voulu.

Et juste pour être sur, tu as bien « restart » le service après avoir créer tes fichiers de configuration ?

Oui, bien entendu ! Là je vais aller protéger mes premières plantations des foutus gels nocturnes à venir.
Je reviens

Je viens de passer le guide que tu as suivi et ton fichier de configuration et tu as un manque, et c’est l’auteur qui en parle pas…

secure_chroot_dir=/var/run/vsftpd/empty
pam_service_name=vsftpd

PAM est le service de gestion des comptes, alors peut-être qui va mieux marcher avec cette commande :stuck_out_tongue:


Si PAM n’est pas défini, il ne peut pas auth les usager, et place l’user dans un dossier secure, mais si c’est pas setter, sa retourne / (surement). VSFTP je l’utilise pas faut dire, je suis plus style proFTPd quand j’ai besoins, et c’est pas le cas avec mes Pi :stuck_out_tongue: (j’utilise le sFTP)

Bon, j’ai donc essayé tes modifications, et cela ne fonctionne pas mieux.

Mes besoins sont simples, j’ai un Arduino qui fabrique des fichiers horaires (aammjjhh.tfa) avec simplement par ligne:
n° thermomètre;date et heure; température; humidité.
Par exemple :

1;2021/01/16 14:00;20.2;50
2;2021/01/16 14:00;20.2;48
3;2021/01/16 14:00;20.2;45

Au max 8 x 60 lignes et 4 à 5 ko

Il devraient être envoyés sur le Pi 1x/5 minutes pour y finir leur traitement
Tout cela en local (et en Ethernet)

As-tu une autre piste facile pour moi ?
Merci encore !

Si tu ne veux transférer qu’un document a toutes les 5 minutes, il y a plusieurs moyens;

  1. Via SSH/sFTP par ligne de commande et cron job; A toutes les 5 minutes (cron) une commande lance un transfert de Arduino @ Pi
  2. Via wget et un serveur web et cronjob; Tu met un serveur web sur Arduino et sur le Pi un cron job lance une commande wget pour télécharger un fichier sur le serveur web arduino
  3. Réinstaller VSFTP ou installer ProFTP et faire ce que tu demande

Avec PHP tu peux scripter pas mal de chose, dont de gérer les nom de fichiers différent, une liste de transfert réussi etc… et plusieurs codes sont disponibles. ET tu peux sécuriser par mot de passe le script.

Merci de ta réponse.

  1. D’après ce que j’ai lu (c’est une piste que j’avais exploré), il n’y a pas assez de place pour du SSH/sFTP dans les arduino (je ne crois même pas qu’il y ait de la doc)
  2. Serveur Web ça existe sur arduino, mais jamais vu de cron
  3. C’est bien pour le PHP et du Python que j’envoie les données vers le PI

Les Arduino sont de belles petites bêtes, mais presque justes bonnes à récolter des données et leur appliquer un traitement de base. C’est d’ailleurs bien souvent pour cela qu’ils sont associés.
Auparavant, j’envoyais ces fichiers sur un vieux pc en Seven qui faisait tout le taf en vb.net.
Mais j’ai beaucoup de problèmes à adapter avec le PI

Il n’y a rien à faire, il faut faire fonctionner ce vsFTPd qui, en plus, à fonctionné !
Merci encore,
Titi

SSH c’est Telnet, si tu peux avoir un serveur Web mais pas SSH, c’est pas logique, SSH c’est la base du remote accès sur les OS linux (ce que tu utilise avec Putty).
Guide;

Pour VSFTP, alors désinstalle et réinstalle, c’est la seul qui te reste à faire, peut-être de quoi à mal passé. Vérifie aussi si le fichier de configuration est bien pris en compte, peut-être as tu fait une erreur de syntaxe qui fait que tu travail pas sur le bon fichier. Je dis ça comme ça, pour retirer toutes les possibilités.

Je sais que Arduino est plus micro-controleur que ordinateur, mais si tu peux avoir un FTP, tu as le SSH, et tu peux offrir du HTTP. Ton Arduino fait office de serveur de fichiers (peux importe la méthode0 et ton Pi le client.

Cronjob c’est avec crontab -e que tu peux éditer les règles. à ce que je sache, c’est par défaut.

J’ai un blog que je ne tiens pas à jour (trop de lièvres à la fois) qui explique mes décodages TFA
http://cambier.eu/ubicomp/index.php?category/Programmation/Arduino

Lien pour régler VSFTP;

https://www.cyberciti.biz/tips/vsftp-chroot-users-limit-to-only-their-home-directory.html

^^^ Celui la parle de simplement ajouter userlist_enable=YES dans la config. ^^^

D’accord, mais pas possible en Arduino et j’en ai d’ailleurs pas besoin (réseau local, données non sensible). N’oublie pas que Arduino sont des micro contrôleurs, ils n’ont pas d’OS

Cela fait des semaines que je tourne en rond. Ce n’est pas dans mes habitudes de venir pleurer dans un forum à la première pierre d’achoppement.
Un problème est que j’ai ma station météo (officielle) qui tourne dessus, avec des milliers de données. Je dois donc faire attention…

Tu roule en IPv6 seulement ? Et en local !?

Merci je vais regarder

Il me semble avoir compris que ip6/ip4 importait peu. Est-ce cela qui ne me fait pas diriger dans mon répertoire ?
Je vais essayer, mais c’est illogique

Backup ta carte SD avant d’effectuer le reinstall, comme ça retour rapide à une config « safe » en cas de bobo.

J’ai pas de Arduino alors je connais que les grands titres. Je n’ai pas vu de OS dédié à Arduino (ou même de LCD) alors je vois que Arduino est comme le Pi Pico dans sont roulement.

Alors ton Arduino agit comme client sur le Pi qui est serveur, dont c’est le Pi qui a le serveur (dans ma tête je m’imaginais plus l’inverse).

EN théorie, Ip4 ou IP6 importe peut, mais en pratique, le IP6 peut apporter un lot de problème. Surtout si un système gère du IP4.

Si tu vois aucun dossier, c’est un problème de IP avec mode PASSIVE (que tu vois dans les logs) et tu doit passer en mode Actif (active/direct). Je rencontre ce problème avec les serveur NAT entre autres, c’est que le serveur va passer en mode passive, ce qui veux dire un ip/port différent que le 21, ce qui est bien pour libérer le port à d’autres connection, mais marche mal si (en passant en IPv6);

  • le serveur connait ton IP4 local,
  • si le client fournis un IP4 local
  • si le client gère mal sont IPv6
  • si le client ne connait pas sont IPv6
  • si le serveur gère un firewall mal configuré en IPv6

Passe en mode Active, ce qui devrais résoudre ce problème. ET remet tout en IPv4 qui est plus simple et compatible (sauf si tout ton réseau utilise le IPv6 principalement).

Il n’a pas été content que je désactive l’IP6. Ce la devient une norme incontournable
Je vais manger et je reviens

Tu n’est pas obliger de le désactiver, peut-être rendre ip4+ip6. Mais déjà, si tu essai de connecter le ftp en mode active, tu devrais avoir un résultat de listing.

SI tu veux tester avec FIlezilla.

Moi je laisse toujours dans ce mode, sinon j’ai trop de trouble vu que c’est le routeur qui gère la connection à internet, si je passerais ma commande de connection PPPoe sur mon PC, je pourrais utiliser le mode Passif sans problème.

Bon, de toute façon cela a fonctionné durant des mois sans problème. Je pensais d’abord à un problème de routeur et je me suis dit que cela allait revenir. Mais non.
Pour les backups, je fais une tournante de 3 µSD…

Bonjour,
comme petit nouveau, j’ai été bloqué par mon quota de messages sur 24 heures, et j’étais ailleurs hier.
Alors voilà,

c’est chroot_local_user=YES qui foutait le brun.

Merci de ton aide @levelKro et aux autres

Le fichier de configuration complet, où les logs maintenant inutiles sont désactivés

listen=NO
listen_ipv6=YES
anonymous_enable=NO
local_enable=YES
write_enable=YES
dirmessage_enable=YES
secure_chroot_dir=/var/run/vsftpd/empty
pam_service_name=vsftpd
dual_log_enable=YES
# Option pour gérer les deux types de logs simultanément
#dual_log_enable=YES
# Partie XFER
#xferlog_enable=YES
#xferlog_file=/var/log/vsftpd.xfer.log
# Partie VSFTPD
#log_ftp_protocol=YES
#vsftpd_log_file=/var/log/vsftpd.log
#connect_from_port_20=YES
user_sub_token=$USER
#chroot_local_user=YES
local_root=/home/$USER/ftp/