172 votes

On obtient "Cannot ioctl TUNSETIFF tun : Operation not permitted" lorsqu'on essaie de se connecter à OpenVPN

J'essaie de configurer un serveur d'accès OpenVPN dans AWS en utilisant l'AMI du marché, mais j'ai du mal à m'y connecter.

Le serveur d'accès est en place et fonctionne. J'ai également ajouté un utilisateur avec Auto-Login et généré la configuration client et les certificats appropriés.

J'ai ensuite copié ces fichiers sur mon ordinateur et j'ai essayé de me connecter en utilisant la fonction openvpn client.ovpn mais j'ai obtenu la sortie et l'erreur suivantes,

Wed Nov 26 12:41:10 2014 OpenVPN 2.3.2 x86_64-pc-linux-gnu [SSL (OpenSSL)] [LZO] [EPOLL] [PKCS11] [eurephia] [MH] [IPv6] built on Feb  4 2014
Wed Nov 26 12:41:10 2014 Control Channel Authentication: using 'ta.key' as a OpenVPN static key file
Wed Nov 26 12:41:10 2014 Outgoing Control Channel Authentication: Using 160 bit message hash 'SHA1' for HMAC authentication
Wed Nov 26 12:41:10 2014 Incoming Control Channel Authentication: Using 160 bit message hash 'SHA1' for HMAC authentication
Wed Nov 26 12:41:10 2014 Socket Buffers: R=[212992->200000] S=[212992->200000]
Wed Nov 26 12:41:10 2014 UDPv4 link local: [undef]
Wed Nov 26 12:41:10 2014 UDPv4 link remote: [AF_INET]<REMOVED_IP>:1194
Wed Nov 26 12:41:10 2014 TLS: Initial packet from [AF_INET]<REMOVED_IP>:1194, sid=2a06a918 c4ecc6df
Wed Nov 26 12:41:11 2014 VERIFY OK: depth=1, CN=OpenVPN CA
Wed Nov 26 12:41:11 2014 VERIFY OK: nsCertType=SERVER
Wed Nov 26 12:41:11 2014 VERIFY OK: depth=0, CN=OpenVPN Server
Wed Nov 26 12:41:11 2014 Data Channel Encrypt: Cipher 'BF-CBC' initialized with 128 bit key
Wed Nov 26 12:41:11 2014 Data Channel Encrypt: Using 160 bit message hash 'SHA1' for HMAC authentication
Wed Nov 26 12:41:11 2014 Data Channel Decrypt: Cipher 'BF-CBC' initialized with 128 bit key
Wed Nov 26 12:41:11 2014 Data Channel Decrypt: Using 160 bit message hash 'SHA1' for HMAC authentication
Wed Nov 26 12:41:11 2014 Control Channel: TLSv1, cipher TLSv1/SSLv3 DHE-RSA-AES256-SHA, 2048 bit RSA
Wed Nov 26 12:41:11 2014 [OpenVPN Server] Peer Connection Initiated with [AF_INET]54.173.232.46:1194
Wed Nov 26 12:41:14 2014 SENT CONTROL [OpenVPN Server]: 'PUSH_REQUEST' (status=1)
Wed Nov 26 12:41:14 2014 PUSH: Received control message: 'PUSH_REPLY,explicit-exit-notify,topology subnet,route-delay 5 30,dhcp-pre-release,dhcp-renew,dhcp-release,route-metric 101,ping 12,ping-restart 50,comp-lzo yes,redirect-private def1,redirect-private bypass-dhcp,redirect-private autolocal,redirect-private bypass-dns,route-gateway 172.16.224.129,route 172.16.1.0 255.255.255.0,route 172.16.224.0 255.255.255.0,block-ipv6,ifconfig 172.16.224.131 255.255.255.128'
Wed Nov 26 12:41:14 2014 Unrecognized option or missing parameter(s) in [PUSH-OPTIONS]:4: dhcp-pre-release (2.3.2)
Wed Nov 26 12:41:14 2014 Unrecognized option or missing parameter(s) in [PUSH-OPTIONS]:5: dhcp-renew (2.3.2)
Wed Nov 26 12:41:14 2014 Unrecognized option or missing parameter(s) in [PUSH-OPTIONS]:6: dhcp-release (2.3.2)
Wed Nov 26 12:41:14 2014 Unrecognized option or missing parameter(s) in [PUSH-OPTIONS]:18: block-ipv6 (2.3.2)
Wed Nov 26 12:41:14 2014 OPTIONS IMPORT: timers and/or timeouts modified
Wed Nov 26 12:41:14 2014 OPTIONS IMPORT: explicit notify parm(s) modified
Wed Nov 26 12:41:14 2014 OPTIONS IMPORT: LZO parms modified
Wed Nov 26 12:41:14 2014 OPTIONS IMPORT: --ifconfig/up options modified
Wed Nov 26 12:41:14 2014 OPTIONS IMPORT: route options modified
Wed Nov 26 12:41:14 2014 OPTIONS IMPORT: route-related options modified
Wed Nov 26 12:41:14 2014 ROUTE_GATEWAY 192.168.0.1/255.255.255.0 IFACE=wlan0 HWADDR=c4:85:08:c9:14:f4
Wed Nov 26 12:41:14 2014 ERROR: Cannot ioctl TUNSETIFF tun: Operation not permitted (errno=1)
Wed Nov 26 12:41:14 2014 Exiting due to fatal error

Une idée du problème ? Je suppose que la création du tunnel échoue à cause de la ligne ERROR ?

J'utilise la version 2.0.10 du serveur et la version client,

OpenVPN 2.3.2 x86_64-pc-linux-gnu [SSL (OpenSSL)] [LZO] [EPOLL] [PKCS11] [eurephia] [MH] [IPv6] built on Feb  4 2014
Originally developed by James Yonan
Copyright (C) 2002-2010 OpenVPN Technologies, Inc. <sales@openvpn.net>
Compile time defines: enable_crypto=yes enable_debug=yes enable_def_auth=yes enable_dependency_tracking=no enable_dlopen=unknown enable_dlopen_self=unknown enable_dlopen_self_static=unknown enable_eurephia=yes enable_fast_install=yes enable_fragment=yes enable_http_proxy=yes enable_iproute2=yes enable_libtool_lock=yes enable_lzo=yes enable_lzo_stub=no enable_maintainer_mode=no enable_management=yes enable_multi=yes enable_multihome=yes enable_pam_dlopen=no enable_password_save=yes enable_pedantic=no enable_pf=yes enable_pkcs11=yes enable_plugin_auth_pam=yes enable_plugin_down_root=yes enable_plugins=yes enable_port_share=yes enable_selinux=no enable_server=yes enable_shared=yes enable_shared_with_static_runtimes=no enable_small=no enable_socks=yes enable_ssl=yes enable_static=yes enable_strict=no enable_strict_options=no enable_systemd=no enable_win32_dll=yes enable_x509_alt_username=yes with_crypto_library=openssl with_gnu_ld=yes with_ifconfig_path=/sbin/ifconfig with_iproute_path=/sbin/ip with_mem_check=no with_plugindir='${prefix}/lib/openvpn' with_route_path=/sbin/route with_sysroot=no

5 votes

// , Pourquoi ces erreurs ? Cela semble être une façon assez stupide de détecter que vous n'avez pas sudo les privilèges.

308voto

Vlado Klimovský Points 196

On dirait que c'est une simple question de sudo.

sudo openvpn client.ovpn a fonctionné à merveille.

15 votes

** insert hair pulling comment here ** wow this took me a while. Merci pour le rappel. Vous pouvez également avoir besoin de l'option --config en fonction de la distribution.

5 votes

// Pouvez-vous nous dire pourquoi c'est le cas ?

1 votes

Je me sens stupide ! sudo a fait l'affaire. Merci !

7voto

user417751 Points 61

La création de l'adaptateur TUN ou TAP nécessite des privilèges que vous n'avez peut-être pas - la commande fonctionne donc avec sudo, mais pas sans.

Sur mon système, si la commande openvpn est exécutée comme ceci ;

sudo openvpn --config file.ovpn

puis un dispositif tun0 est créé. Presque toujours, la création de périphériques nécessite des privilèges.

2voto

Jonathan Points 166

Utilisant Linux Mint, et me connectant via l'interface utilisateur de Network Manager (qui ne demande pas de sudo pwd), j'ai supposé que ce n'était pas nécessaire. Il s'avère que c'était le problème pour moi ! Connexion via sudo depuis un terminal a parfaitement fonctionné.

-2voto

Rahmi Acar Points 1

Vous pouvez toujours exécuter chmod u+s sur le binaire openvpn en tant que root (en mettant uid 0).

sudo chmod u+s $(which openvpn)

Cela permettra à un utilisateur local d'exécuter le processus en tant qu'utilisateur root. À ce stade, votre gestionnaire de réseau/nm-applet permettra également l'établissement de la connexion.

0 votes

L'ajout du bit SUID à une application peut constituer une violation majeure de la sécurité.

0 votes

Je ne suis pas totalement en désaccord avec vous, mais avoir sudo sans protection par mot de passe est mieux ? Il est vrai que l'on peut modifier les sudoers pour n'autoriser que l'utilisation sans mot de passe d'un programme spécifique, etc Cependant Tout dépend du type d'exposition de la machine, non ? Normalement, certaines applications ont besoin du bit SUID pour obtenir une bonne expérience, c'est pourquoi je le suggère dans cette circonstance. Cela permettra également l'utilisation de NetworkManager e.t.c.

0 votes

Sudo doit toujours être protégé par un mot de passe et il peut être limité dans le fichier sudoers à une application particulière par utilisateur.

SistemesEz.com

SystemesEZ est une communauté de sysadmins où vous pouvez résoudre vos problèmes et vos doutes. Vous pouvez consulter les questions des autres sysadmins, poser vos propres questions ou résoudre celles des autres.

Powered by:

X