J'ai un problème de montage d'un partage NFS que je ne peux pas résoudre et qui me rend fou. Voici la situation:
Trois machines impliquées:
Hôte A: mandrake, IP 192.168.1.4, serveur NFS
Hôte B: athlon64, IP 192.168.1.64, client NFS
Hôte C: lap-fzs-2, IP 192.168.1.27, client NFS
L'hôte A possède un serveur NFS en cours d'exécution qui exporte un répertoire qui est monté par l'hôte B. Cela fonctionne parfaitement et fonctionne depuis des siècles. Pas de problème. Maintenant, l'hôte C entre en scène. Ubuntu 12.04 LTS, système moderne. J'ai essayé de monter le même partage à partir de l'hôte A mais j'obtiens une erreur de refus d'autorisation:
root@lap-fzs-2:~# mount -t nfs mandrake:/data /data -onfsvers=2
mount.nfs: access denied by server while mounting mandrake:/data
Le fait qu'il fonctionne entre les hôtes A et B devrait prouver que l'exportation NFS fonctionne en soi. Voici les informations que je peux donner qui me font penser que cela devrait fonctionner. Peut-être que quelqu'un voit ce que je ne sais pas et sait pourquoi cela échoue sur le nouvel hôte C.
Exportations de serveur:
[root@mandrake /root]# cat /etc/exports
/suse 192.168.1.0/16(ro,no_root_squash)
/data 192.168.1.0/24(rw)
#/data3 192.168.2.0/24(rw)
#/data 192.168.2.0/16(rw,all_squash,anonuid=500,anongid=500)
#/data3 192.168.2.0/16(rw,all_squash,anonuid=500,anongid=500)
[root@mandrake /root]# exportfs
/suse 192.168.1.0/16
/data 192.168.1.0/24
Le portmapper est en cours d'exécution, les exportations sont connues et montées par l'hôte B "athlon64".
[root@mandrake /root]# showmount -e
Export list for mandrake:
/data 192.168.1.0/24
/suse 192.168.1.0/16
[root@mandrake /root]# showmount -a
All mount points on mandrake:
atlhon64.acme.local:/data
Lorsque l'hôte athlon64 monte le partage NFS, le journal du serveur affiche le succès:
Feb 11 20:06:46 mandrake mountd[460]: authenticated mount request from atlhon64.acme.local:770 for /data (/data)
Mais lorsque l'hôte C tente de monter le même partage, le journal du serveur affiche:
Feb 11 20:12:42 mandrake mountd[460]: refused mount request from lap-fzs-2 for /data (/): no export entry
L'hôte C voit le serveur, atteint le portmapper et le nfsd, mais échoue aux autorisations.
root@lap-fzs-2:~# showmount -e 192.168.1.4
Export list for 192.168.1.4:
/data 192.168.1.0/24
/suse 192.168.1.0/16
root@lap-fzs-2:~# mount -t nfs -v mandrake:/data /data -onfsvers=2,proto=udp
mount.nfs: timeout set for Mon Feb 11 21:49:23 2013
mount.nfs: trying text-based options 'nfsvers=2,proto=udp,addr=192.168.1.4'
mount.nfs: prog 100003, trying vers=2, prot=17
mount.nfs: trying 192.168.1.4 prog 100003 vers 2 prot UDP port 2049
mount.nfs: prog 100005, trying vers=1, prot=17
mount.nfs: trying 192.168.1.4 prog 100005 vers 1 prot UDP port 636
mount.nfs: mount(2): Permission denied
mount.nfs: access denied by server while mounting mandrake:/data
Je dois utiliser NFSv2 sur le client. L'utilisation de NFSv4 échouera car le serveur ne le prend pas en charge. Il échoue car il essaie de se connecter via TCP directement à 2049 mais le port n'est pas ouvert. Aucune solution de repli ne se produit. L'utilisation de NFSv3 entraînera une incompatibilité de programme / version RPC.
Qu'est-ce que je rate?
Mise à jour:
Les trois machines sont sur un LAN, sur le même commutateur. Il n'y a pas de pare-feu actif sur l'hôte C:
root@lap-fzs-2:~# iptables -vnL
Chain INPUT (policy ACCEPT 17 packets, 1853 bytes)
pkts bytes target prot opt in out source destination
Chain FORWARD (policy ACCEPT 0 packets, 0 bytes)
pkts bytes target prot opt in out source destination
Chain OUTPUT (policy ACCEPT 20 packets, 5611 bytes)
pkts bytes target prot opt in out source destination
Ni sur l'hôte A:
[root@mandrake /root]# ipchains -L
Chain input (policy ACCEPT):
Chain forward (policy ACCEPT):
Chain output (policy ACCEPT):
exportfs -a
commande sur l'hôte A, puis essayez lamount
commande sur l'hôte C. Essayez le nom d'hôte explicite ou l'adresse IP complète dans/etc/exports
.exportfs -a
au démarrage et comme il ne s'agit pas d'une nouvelle entrée, il est déjà exporté. Le fichier d'export n'a pas changé, c'est juste un nouvel hôte qui devrait le monter et ne peut pas./etc/exports
fait, cela fonctionne. J'ai maintenant le net / 24 plus l'IP complet répertorié et l'hôte C peut être monté. Je n'ai pas encore essayé l'hôte B. Une idée pourquoi c'est? J'ai remarqué que l'hôte B (celui qui fonctionnait) utilisait un appel MNT version 2, tandis que l'hôte C avait recours à un appel MNT version 1.Réponses:
Étant donné que l'avis de rejet du serveur prétend qu'il n'y a "aucune entrée d'exportation" pour l'hôte C, vous devriez peut-être essayer une ligne sans ambiguïté dans le
/etc/exports
fichier avec le nom d'hôte explicite ou l'adresse IP complète pour C.Essayez également d'émettre une
exportfs -a
commande sur le serveur.J'ai souvent des problèmes pour accéder à mon serveur NFS même après un redémarrage. Émettre explicitement la
exportfs -a
commande est la solution fiable (pour moi).la source
exportfs -a
n'a rien changé pour moi. L'utilisation de l'adresse IP complète pour l'hôte problématique a résolu mon problème. Donc, même si cela ne l'explique pas et que je ne le comprends pas, c'était la réponse à mon problème et ce que je peux recommander d'essayer pour d'autres personnes ayant le même problème.Vérifiez et voyez si l'UID et le GUID pour les utilisateurs NFS sont les mêmes sur le serveur et le client. Assurez-vous également que sur le serveur le dossier est autorisé 777. Il s'agit de mon / etc / exports sur mon serveur pour que mon client puisse y accéder.
Créez un répertoire de partage NFS: (Créez chaque serveur avec IP, espace séparé)
mkdir / var / nfs vim / etc / exports / var / nfs 10.180.82.250 (rw, sync, root_squash, anonuid = 530, anongid = 530, no_subtree_check)
la source
Dans mon cas, -o vers = 3 est la réponse:
la source