O Wi-Fi desconecta após um período de tempo no Raspberry Pi, não reconecta

14

Finalmente, consegui conectar meu Raspberry Pi a uma rede SSID oculta (WPA2 Personal) usando as configurações abaixo (sem usar o wpa_supplicant.conf).

No entanto, após algumas horas, ele se desconecta e não se reconecta.

  • Raspberry Pi B +, executando NOOBS.
  • Placa WiFi com alimentação USB (chipset Ralink RT5370)
  • Conectado a um SSID oculto (não sei se o SSID oculto tem algo a ver com esse problema, pode ser um arenque vermelho)

Aqui está o log:

Feb  6 14:36:01 raspberrypi wpa_supplicant[1641]: wlan0: CTRL-EVENT-DISCONNECTED bssid=90:72:40:1c:ed:c8 reason=4
Feb  6 14:36:01 raspberrypi kernel: [33883.785257] cfg80211: Calling CRDA to update world regulatory domain
Feb  6 14:36:01 raspberrypi ifplugd(wlan0)[1634]: Link beat lost.
Feb  6 14:36:11 raspberrypi ifplugd(wlan0)[1634]: Executing '/etc/ifplugd/ifplugd.action wlan0 down'.
Feb  6 14:36:11 raspberrypi dhclient: Internet Systems Consortium DHCP Client 4.2.2
Feb  6 14:36:11 raspberrypi ifplugd(wlan0)[1634]: client: Internet Systems Consortium DHCP Client 4.2.2
Feb  6 14:36:11 raspberrypi dhclient: Copyright 2004-2011 Internet Systems Consortium.
Feb  6 14:36:11 raspberrypi ifplugd(wlan0)[1634]: client: Copyright 2004-2011 Internet Systems Consortium.
Feb  6 14:36:11 raspberrypi dhclient: All rights reserved.
Feb  6 14:36:11 raspberrypi ifplugd(wlan0)[1634]: client: All rights reserved.
Feb  6 14:36:11 raspberrypi dhclient: For info, please visit https://www.isc.org/software/dhcp/
Feb  6 14:36:11 raspberrypi ifplugd(wlan0)[1634]: client: For info, please visit https://www.isc.org/software/dhcp/
Feb  6 14:36:11 raspberrypi dhclient: 
Feb  6 14:36:11 raspberrypi dhclient: Listening on LPF/wlan0/00:0f:60:01:de:14
Feb  6 14:36:11 raspberrypi ifplugd(wlan0)[1634]: client: Listening on LPF/wlan0/00:0f:60:01:de:14
Feb  6 14:36:11 raspberrypi dhclient: Sending on   LPF/wlan0/00:0f:60:01:de:14
Feb  6 14:36:11 raspberrypi ifplugd(wlan0)[1634]: client: Sending on   LPF/wlan0/00:0f:60:01:de:14
Feb  6 14:36:11 raspberrypi dhclient: Sending on   Socket/fallback
Feb  6 14:36:11 raspberrypi ifplugd(wlan0)[1634]: client: Sending on   Socket/fallback
Feb  6 14:36:11 raspberrypi dhclient: DHCPRELEASE on wlan0 to 192.168.128.254 port 67
Feb  6 14:36:11 raspberrypi ifplugd(wlan0)[1634]: client: DHCPRELEASE on wlan0 to 192.168.128.254 port 67
Feb  6 14:36:12 raspberrypi wpa_supplicant[1641]: wlan0: CTRL-EVENT-TERMINATING - signal 15 received
Feb  6 14:36:12 raspberrypi ifplugd(wlan0)[1634]: Program executed successfully.
Feb  6 14:36:14 raspberrypi ntpd[2157]: Deleting interface #2 wlan0, 192.168.128.122#123, interface stats: received=389, sent=396, dropped=0, active_time=33841 secs
Feb  6 14:36:14 raspberrypi ntpd[2157]: 192.96.207.244 interface 192.168.128.122 -> (none)
Feb  6 14:36:14 raspberrypi ntpd[2157]: 178.18.16.124 interface 192.168.128.122 -> (none)
Feb  6 14:36:14 raspberrypi ntpd[2157]: 204.2.134.164 interface 192.168.128.122 -> (none)
Feb  6 14:36:14 raspberrypi ntpd[2157]: 216.152.240.220 interface 192.168.128.122 -> (none)
Feb  6 14:36:14 raspberrypi ntpd[2157]: peers refreshed

Aqui está o / etc / network / interfaces

auto lo
iface lo inet loopback
iface eth0 inet dhcp
auto wlan0
allow-hotplug wlan0
iface wlan0 inet dhcp
    wpa-scan-ssid 1
    wpa-ap-scan 1
    wpa-key-mgmt WPA-PSK
    wpa-proto RSN WPA
    wpa-pairwise CCMP TKIP
    wpa-group CCMP TKIP
    wpa-ssid "Na*****"
    wpa-psk *********************************************************
Micah
fonte
1
você pode compartilhar sua saída de sudo iwconfig wlan0isso mostra Power Mgmt: On? Em caso afirmativo, então você precisa desativá-lo, o sudo iwconfig wlan0 power offque deve resolver o seu problema #
Shan-Desai
@ A solução Shan-Desai corrigiu meu problema. Meu raspberry Pi W será desconectado a cada 3-5 minutos. Muito obrigado!
Dave

Respostas:

10

A única maneira de resolver esse problema foi escrever um script de shell que é executado a cada minuto por um trabalho cron. Ele verifica se a rede está inoperante; se estiver, reconecta-a. Funcionou muito bem na última semana.

#!/bin/bash

MY_PATH="`dirname \"$0\"`"              # relative
LOG_PATH="`( cd \"$MY_PATH\" && cd .. && pwd )`/log/network.log"
now=$(date +"%m-%d %r")

# Which Interface do you want to check
wlan='wlan0'
# Which address do you want to ping to see if you can connect
pingip='google.com'

# Perform the network check and reset if necessary
/bin/ping -c 2 -I $wlan $pingip > /dev/null 2> /dev/null
if [ $? -ge 1 ] ; then
    echo "$now Network is DOWN. Perform a reset" >> $LOG_PATH
    /sbin/ifdown $wlan
    sleep 5
    /sbin/ifup --force $wlan
else
    echo "$now Network is UP. Just exit the program." >> $LOG_PATH
fi
Micah
fonte
1
Oi. Antes de usar ifup --force wlan0porque você está usandoifdown wlan0
S Andrew
@ Andrew Meu palpite é que, caso contrário, simplesmente não faria nada. E se ifupnão fizer nada, também não causará uma reconexão automática. Esse é o motivo ou era mais fácil codificá-lo dessa maneira do que testar se funcionaria de outra maneira.
Lucidbrot 7/03
No meu caso, a parte de reconexão parece desnecessária. Fazer ping no Google a cada minuto mantém a conexão 100% estável.
gromit190
6

Esse é o comportamento esperado; O WiFi não pode ser garantido 100% do tempo.

Isso se aplica ao Raspbian Wheezy anterior a 05/05/2015 para mais tarde (e Jessie) Consulte Como configurar a rede / WiFi / IP estático

Se você deseja reconectar automaticamente após a perda de conectividade, use wpa-roamem conjunto comwpa_supplicant.conf)

PS Não é sensato publicar seu SSID e PSK

/ etc / network / interfaces

auto lo

iface lo inet loopback
iface eth0 inet dhcp

allow-hotplug wlan0
auto wlan0
iface wlan0 inet manual
wpa-roam /etc/wpa_supplicant/wpa_supplicant.conf

iface home inet dhcp
iface default inet dhcp

/etc/wpa_supplicant/wpa_supplicant.conf

ctrl_interface=DIR=/var/run/wpa_supplicant GROUP=netdev
update_config=1

network={
    scan_ssid=1
    ssid="xxx"
    psk="yyy"
    id_str="home"
    proto=RSN
    key_mgmt=WPA-PSK
    pairwise=CCMP
    auth_alg=OPEN
    eap=MD5
}
Milliways
fonte
Você pode dar um exemplo do uso do wpa-roam em conjunto com o wpa_supplicant.conf? Não estou mais usando o arquivo conf porque, quando coloco os creds lá, ele nunca se conecta ao SSID oculto por algum motivo. BTW, que SSID e PSK não são válidos, embora eu os remova, pois eles são uma distração. Obrigado.
Miquéias
2
Eu listei o meu acima. o segredo para SSID oculto éscan_ssid=1
Milliways
3

Como sugerido, você pode usar o wpa-roam, embora eu recomende o wicd ou o gerenciador de rede. Eles cuidam de todas as configurações, também lidam com várias redes e são mais amigáveis.

Por exemplo, o wicd possui um gui de maldições que você pode instalar:

sudo apt-get install wicd-curses

E corra com:

wicd-curses
tfjgeorge
fonte
1

estava tendo os mesmos problemas com a desconexão ... tem a ver com o adaptador sem fio. Meu linksys ae3000 se desconecta a cada poucos dias. Eu o modifiquei levemente para funcionar com minhas câmeras usb motion e compartilhamento nfs, além de uma notificação por email adicionada.

Entrada do Crontab:

*/1 * * * * /root/netcheck.sh > /dev/null 2>&1

Script modificado:

#!/bin/bash

LOG_PATH="/var/log/network.log"
now=$(date +"%m-%d %r")

# Which Interface do you want to check (wlan = wireless, eth0 = ethernet)
iface='eth0'
# Which address do you want to ping to see if you can connect
pingip='google.com'

# Perform the network check and reset if necessary
/bin/ping -c 2 -I $iface $pingip > /dev/null 2> /dev/null
if [ $? -ge 1 ] ; then
    echo "$now Network is DOWN. Perform a reset" >> $LOG_PATH
    /sbin/ifdown $iface
    sleep 5
    /sbin/ifup --force $iface
    sleep 5
    /bin/mount -o remount /data (reconnects my NAS nfs share)
    sleep 2
    /etc/init.d/motion restart  (restarts motion to clean hung processes)
    sleep 3
    /etc/init.d/motion restart  (2nd restart for sanity sake, sometimes 1st restart doesn't pan out)
    mail -s "`hostname` $iface recovered" [email protected] < /dev/null  (send me an email so I know about this)
fi
bombeiro
fonte
0

Alterei as configurações de hora e tudo começou a funcionar para mim.

Preferências-> Configuração do Raspberry Pi-> Guia Localização

Verifiquei se todas as quatro opções estavam definidas corretamente para minha localização.

plyons126
fonte
0

Teve o mesmo problema, resolvi-o fazendo meu PI executar ping no Google a cada minuto.

corre sudo crontab -e

Adicione isso ao final do arquivo

* * * * * /bin/ping -c2 -I wlan0 8.8.8.8 >/dev/null
gromit190
fonte
Isso não é essencialmente o mesmo que a resposta aceita?
Dirk
Essencialmente sim. Praticamente não. Meu PI não se reconecta, porque não precisa. Nem OPs, provavelmente.
gromit190