Innholdsfortegnelse:
- Trinn 1: Installer nødvendig RaspberryPi -programvare
- Trinn 2: Opprette WiFi -tilgangspunktet
- Trinn 3: Nødvendig rekvisita: Old Broken Nintendo
- Trinn 4: Nødvendig rekvisita: Raspberry Pi 3 Model B
- Trinn 5: Nødvendig rekvisita: 1,44 "serie: UART/I2C/SPI TFT LCD 128x128 skjermmodul
- Trinn 6: Nødvendig rekvisita: 5V 0.1A Mini Fan Raspberry Pi
- Trinn 7: Nødvendig rekvisita: Ugreen USB 2.0 til 10/100 Fast Ethernet Lan kablet nettverkskort
- Trinn 8: Konstruksjon
- Trinn 9: Konstruksjonskont
- Trinn 10: Konstruksjonskont
- Trinn 11: Koble til Digole -skjermen
- Trinn 12: Installer verktøy for nettverksovervåking og DB -logging
- Trinn 13: Installer trafikkoppsummeringsrapporten (kjøres hvert 5. minutt av Cronjob)
- Trinn 14: Installer Dashboard -skjermen
- Trinn 15: Installer lokal bruk/statistikknettsted [http://10.0.10.1]
2025 Forfatter: John Day | [email protected]. Sist endret: 2025-01-13 06:58
Bruk en gammel Nintendo Entertainment -systemkasse til å produsere en svært funksjonell hjemmeruter med en RaspberryPI 3!
Trinn 1: Installer nødvendig RaspberryPi -programvare
Blinkende RaspberriPi -harddisk / installer nødvendig programvare (bruker Ubuntu Linux)
Last ned "RASPBIAN JESSIE LITE"
Lag din nye harddisk for DashboardPI
Sett inn microSD -en på datamaskinen din via USB -adapteren, og lag diskbildet med kommandoen dd
Finn det innsatte microSD -kortet via kommandoen df -h, demonter det og lag diskbildet med kommandoen disk copy dd
$ df -h/dev/sdb1 7.4G 32K 7.4G 1%/media/XXX/1234-5678
$ umount /dev /sdb1
Forsiktig: sørg for at kommandoen er helt nøyaktig, du kan skade andre disker med denne kommandoen
if = plassering av RASPBIAN JESSIE LITE bildefil av = plassering av microSD -kortet
$ sudo dd bs = 4M hvis =/path/to/raspbian-jessie-lite.img av =/dev/sdb (merk: i dette tilfellet er det/dev/sdb,/dev/sdb1 en eksisterende fabrikkpartisjon på microSD) Sette opp RaspberriPi
Sett inn det nye microSD -kortet i raspberrypi og slå det på med en skjerm koblet til HDMI -porten
Logg Inn
bruker: pi pass: bringebær Endre passordet ditt for sikkerhet
sudo passwd pi Aktiver RaspberriPi avanserte alternativer
sudo raspi-config Velg: 1 Utvid filsystemet
9 Avanserte alternativer
A2 Hostname endre det til "NESRouter"
A4 SSH Aktiver SSH -server
A7 I2C Aktiver i2c -grensesnitt Aktiver engelsk/amerikansk tastatur
sudo nano/etc/default/keyboard Endre følgende linje: XKBLAYOUT = "oss" Sett opp den enkle katalogen l -kommandoen [valgfritt]
vi ~/.bashrc
legg til følgende linje:
alias l = 'ls -lh'
kilde ~/.bashrc Fix VIM standardsyntaks utheving [valgfritt]
sudo vi/etc/vim/vimrc
ikke kommenter følgende linje:
syntaks på Reboot PI for å få de siste endringene
reboot Oppdater lokale tidssoneinnstillinger
sudo dpkg-omkonfigurer tzdata velg din tidssone ved hjelp av grensesnittet
Trinn 2: Opprette WiFi -tilgangspunktet
Vær oppmerksom på at før dette blir en ruter, kobler vi RaspberryPi til et eksisterende nettverk via sin ethernet -port for å installere følgende pakker
sudo apt-get update && sudo apt-get -y oppgradering
sudo apt-get install dnsmasq hostapd vim
sudo apt-get install vim git python-smbus i2c-tools python-imaging python-smbus build-essential python-dev rpi.gpio python3 python3-pip libi2c-dev
sudo vi /etc/dhcpcd.conf
Legg til følgende linje:
denyinterfaces wlan0 sudo vi/etc/network/interfaces
Rediger wlan0 -delen slik at den ser slik ut:
auto lo iface lo inet loopback
iface eth0 inet manual
auto wlan0 iface wlan0 inet statisk adresse 10.0.10.1 netmask 255.255.255.0 nettverk 10.0.10.0 kringkasting 10.0.10.255
auto eth1 iface eth1 inet statisk adresse 10.0.20.1 netmask 255.255.255.0 nettverk 10.0.20.0 kringkasting 10.0.20.255 Last DHCP -server på nytt og avvis konfigurasjonen for eth0- og wlan0 -tilkoblinger
sudo service dhcpcd start på nytt
sudo ifdown eth0; sudo ifup wlan0
Konfigurer HOSTAPD (Endre ssid og wpa_passphrase til verdiene du selv velger)
sudo vi /etc/hostapd/hostapd.conf
# Dette er navnet på WiFi -grensesnittet vi konfigurerte ovenfor grensesnittet = wlan0
# Bruk nl80211 -driveren med brcmfmac -driverdriveren = nl80211
# Dette er navnet på nettverket ssid = NintendoWiFi
# Bruk 2,4 GHz -båndet hw_mode = g
# Bruk kanal 6 kanal = 6
# Aktiver 802.11n ieee80211n = 1
# Aktiver WMM wmm_enabled = 1
# Aktiver 40MHz-kanaler med 20ns vaktintervall ht_capab = [HT40] [SHORT-GI-20] [DSSS_CCK-40]
# Godta alle MAC -adresser macaddr_acl = 0
# Bruk WPA -godkjenning auth_algs = 1
# Krev at klientene kjenner nettverksnavnet ignore_broadcast_ssid = 0
# Bruk WPA2 wpa = 2
# Bruk en forhåndsdelt nøkkel wpa_key_mgmt = WPA-PSK
# Nettverkspassordet wpa_passphrase = passord
# Bruk AES, i stedet for TKIP rsn_pairwise = CCMP Vi kan sjekke om det fungerer på dette stadiet ved å kjøre (men har ikke full internettforbindelse ennå):
sudo/usr/sbin/hostapd /etc/hostapd/hostapd.conf
sudo vi/etc/default/hostapd
Finn linjen
#DAEMON_CONF = "" og erstatt den med
DAEMON_CONF = "/etc/hostapd/hostapd.conf" Konfigurer DNSMASQ
sudo mv /etc/dnsmasq.conf /etc/dnsmasq.conf.orig
sudo vi /etc/dnsmasq.conf
bind-interfaces # Bind til grensesnittet for å sikre at vi ikke sender ting andre steder server = 8.8.8.8 # Videresend DNS-forespørsler til Google DNS-domenebehovet # Ikke videresend korte navn falske-priv # Aldri videresend adresser i -ruterte adresserom.
# Tilordne IP-adresser m/uendelig leietid (for enhetsbruksstatistikk) dhcp-range = wlan0, 10.0.10.100, 10.0.10.200, 255.255.255.0, 10.0.10.255, uendelig dhcp-range = eth1, 10.0.20.100, 10.0. 20.200, 255.255.255.0, 10.0.20.255, uendelig OPPSETT IPV4 FREMGÅ
sudo vi /etc/sysctl.conf
[uncomment] net.ipv4.ip_forward = 1
Aktiver den umiddelbart med sudo sh -c "echo 1>/proc/sys/net/ipv4/ip_forward"
sudo iptables -t nat -A POSTROUTING -o eth0 -j MASQUERADE
sudo iptables -E FREMTID -i eth0 -o eth1 -m tilstand -stat RELATERT, ESTABLISHED -j ACCEPT
sudo iptables -A FREMTIL -i eth1 -o eth0 -j Aksepter
sudo iptables -E FREMTID -i eth0 -o wlan0 -m tilstand -stat RELATERT, ESTABLISHED -j ACCEPT
sudo iptables -A FORWARD -i wlan0 -o eth0 -j GODTAK
Lagre iptables -innstillinger for neste omstart
sudo sh -c "iptables -save> /etc/iptables.ipv4.nat"
Lag ipv4 reglerfil (med nytt innhold)
sudo vi/lib/dhcpcd/dhcpcd-hooks/70-ipv4-nat
iptables-restore </etc/iptables.ipv4.nat Restart Services
sudo service hostapd start sudo service dnsmasq start
sudo omstart
Tilordne statiske IP -er [valgfritt]
Hvis du vil at verter på nettverket ditt skal ha statisk ips, kan du bruke følgende
Skaff vertene som for øyeblikket er tilkoblet via DHCP vi /var/lib/misc/dnsmasq.leases
Legg til MAC -adressen (fra utdata ovenfor) og IP -adressen du vil tildele dem til sudo vi /etc/dnsmasq.conf
# main desktop dhcp-host = 12: 34: 56: 78: 9a: bc, 10.0.20.20 Merk: Dette vil tilordne nettverksgrensesnittet til MAC-adressen: 12: 34: 56: 78: 9a: bc til IP-adressen 10.0.20.20. IP -adressen som er oppført trenger IKKE å være i det angitte DHCP -området, bare på det samme delnettet. Hovedskrivebordet mitt ovenfor er på subnett eth1: 10.0.20.0, så jeg ga den IP -adressen 10.0.20.20.
Legger til UFW -brannmur
sudo apt-get install ufw
Tillat port 22 for offentlig bruk (for ekstern nettverkstilgang)
sudo ufw tillate 22
Tillat alle porter på mitt lokale nettverk
sudo ufw tillate fra 10.0.10.0/24 sudo ufw tillate fra 10.0.20.0/24
Tillat nettporter for alle
sudo ufw tillate 80
Tillat sikre nettporter for alle
sudo ufw tillate 443
Aktiver UFW og sjekk statusen
sudo ufw -tvinge til
sudo ufw status
Fix BUG med UFW som ikke starter ved oppstart
sudo su crontab -e
Legg til følgende linje: @reboot /bin /sleep 60; ufw -tvinge til
Trinn 3: Nødvendig rekvisita: Old Broken Nintendo
Gammelt Nintendo -etui fra en ødelagt NES (fjern alt det gamle innholdet inne i etuiet, slik at bare den ytre rammen, strøm- / tilbakestillingsknappene og kontrollertilkoblingene etterlates)
Trinn 4: Nødvendig rekvisita: Raspberry Pi 3 Model B
Trinn 5: Nødvendig rekvisita: 1,44 "serie: UART/I2C/SPI TFT LCD 128x128 skjermmodul
|Trinn 6: Nødvendig rekvisita: 5V 0.1A Mini Fan Raspberry Pi
Trinn 7: Nødvendig rekvisita: Ugreen USB 2.0 til 10/100 Fast Ethernet Lan kablet nettverkskort
Trinn 8: Konstruksjon
Installer inne i NES
Bruk en 3D-skriver til å skrive ut Digole Display-rammen "NESPanel" i/construction/display-frame/folder. [hvis du ikke har en 3D -skriver, kan du forsiktig kutte et firkantet hull for Digole -skjermen med et Dremel -verktøy] Klipp de følgende hullene opp på baksiden og siden av saken for å gjøre det mulig å feste den lille viften på siden og strøm-/ethernet- og USB -ethernet -kablene for å komme inn gjennom baksiden.
Trinn 9: Konstruksjonskont
Skru av det øverste høyre sorte panelet fra NES og skjær et stort nok firkantet hull for å montere din digole -skjerm. Hot Lim skjermen på plass med "NESPanel" 3D -trykt ramme over toppen av den.
Trinn 10: Konstruksjonskont
Monter RaspberryPi midt på bunnen av det tomme NES -etuiet, fest med lim eller en liten skrue gjennom bunnen. Koble "power on LED" på NES til 5V- og GND -pinnene i Raspberry Pi ved hjelp av en 270 ohm resistor (kort LED -ledning er bakken). Koble den lille viften til 5V- og GND -pinnene også for å få den til å kjøre når enheten starter, lim viften mot hullet i siden for den.
Trinn 11: Koble til Digole -skjermen
Koble følgende pinner til pinnene på RaspberryPi
VCC er koblet til 3v GND er jordet DATA er SDA CLOCK er SCL Nå bør du se enheten i i2cdetect -kommandoen
i2cdetect -y 1 det skal vises i rutenettet for tekst som 27
Trinn 12: Installer verktøy for nettverksovervåking og DB -logging
sudo apt-get install ifstat memcached python-memcache postgresql postgresql-contrib python-psycopg2
sudo vi /etc/postgresql/9.4/main/pg_hba.conf
Legg til følgende linje i slutten av filen: local all pi password sudo -i -u postgres
psql
opprett rolle -pi -passord 'passord her';
endre rolle pi pålogging;
endre rolle pi superbruker;
du
(du bør se din PI -bruker med tillatelsene gitt) opprett database network_stats;
q
exit
psql -d network_stats
Kjør følgende spørsmål:
OPPRETT TABELL trafikk_per_minutt (ID seriell, tidsstempel uten tidssone IKKE NULL, eth0_down ekte, eth0_up ekte, eth1_down ekte, eth1_up ekte, wan0_down ekte, wan0_up ekte);
OPPRETT UNIK INDEKS time_idx PÅ traffic_per_minute (tid); Kopier koden "logging" med kode fra dette prosjektet til hjemmekatalogen til RPi -en
crontab -e
Legg til denne linjen
@reboot /bin /sleep 60; nohup python /home/pi/logging/networkUsage.py>/dev/null 2> & 1
Trinn 13: Installer trafikkoppsummeringsrapporten (kjøres hvert 5. minutt av Cronjob)
crontab -e
legg til følgende linje
*/5 * * * * python /home/pi/logging/trafficSummary.py
Trinn 14: Installer Dashboard -skjermen
Kopier "vis" -mappen med kode fra dette prosjektet til hjemmekatalogen til RPi -en
Kjør den som følger
$ python /home/pi/display/NESRouter.py Konfigurer displayskriptet for å kjøre ved oppstart
crontab -e
Legg til denne linjen
@reboot nohup python /home/pi/display/NESRouter.py>/dev/null 2> & 1
Kontroller at skjermen begynner å fungere på omstart
sudo omstart
Trinn 15: Installer lokal bruk/statistikknettsted [https://10.0.10.1]
Installer det lokale bruks-/statistikknettstedet [https://10.0.10.1]
sudo apt-get update && sudo apt-get upgrade -y
sudo apt-get install apache2
sudo service apache2 starter på nytt
Fjern standardsider
cd /var /www
sudo rm -rf html
Kopier "webportal" -mappen fra dette prosjektet til hjemmemappen på RPi -en og opprett symlink for apache å bruke
cd /var /www
sudo ln -s/home/pi/webportal html
cd/var/www/html
chmod +x *.py
sudo a2enmod cgi
sudo vi /etc/apache2/sites-enabled/000-default.conf
Aktiver Python CGI Scripting
Legg til inne i taggen
Options +ExecCGI AddHandler cgi-script.py sudo service apache2 restart
Du kan nå besøke det lokale HTTP -nettstedet [https://10.0.10.1]
Konfigurer avansert nettverksovervåking (via IPFM)
sudo apt-get oppdatering
sudo apt-get install ipfm
sudo mv /etc/ipfm.conf /etc/ipfm.conf-bak
sudo vi /etc/ipfm.conf
Lag med følgende innhold:
# Globale variabler
# IPFM kan bare overvåke én enhet. ENHET eth0
# GLOBAL LOGGING KONFIGURASJONSLOGG
FILENAME "/var/log/ipfm/%Y_%d_%m/%H_%M"
# logg hvert minutt DUMP HVERT 1 minutt
# klar statistikk hver dag SLETT HVER 24 timers SORTERING I LØSNING sudo service ipfm start
VALGFRITT: Lag dine egne Nintendo -bilder som skal gjengis på skjermen
Last opp din egen 128x128 -fil til følgende URL:
www.digole.com/tools/PicturetoC_Hex_convert…
Velg bildefilen du vil laste opp, legg til hvilken størrelse du vil at den skal ha på skjermen (bredde/høyde)
Velg "256 farger for farge OLED/LCD (1 byte/piksel)" i rullegardinmenyen "Brukes til"
Få hex -utgangen.
Legg til hex -utgangen til en display/ build/ header (.h) -fil, bruk de andre som veiledninger for syntaks.
Inkluder den nye filen i digole.c -filen #include myimage.h
Inkluder en ny kommandolinjekrok til bildefilen i. Merk: Kommandoen nedenfor sier at tegnet bildet ditt i posisjon 10 piksler over 10 piksler ned. Du kan endre den til forskjellige X-, Y -koordinater, du kan også endre verdiene 128, 128 til hvilken størrelse det nye bildet ditt faktisk er.
} annet hvis (strcmp (digoleCommand, "myimage") == 0) {drawBitmap256 (10, 10, 128, 128, og myimageVariableHere, 0); // myimageVariableHere er definert i (.h) filen}
Nå må du bygge om (ignorere feilene) nedenfor for å få det nye bildet ditt gjengitt med følgende kommando.
$./digole myimage Re-Building [Inkludert] Digole Display Driver for valgfrie endringer
$ cd -visning/bygge $ gcc digole.c $ mv a.out../../digole $ chmod +x../../digole