Difference between revisions of "Cellular Communication"
Line 118: | Line 118: | ||
== Connecting more hives to modem == | == Connecting more hives to modem == | ||
− | First is to find out if you want to use static or DHCP setup for your hives. | + | First is to find out if you want to use static or DHCP setup for your hives.<br> |
− | If you want to have static setup there is more information on this on other pages here | + | If you want to have static setup there is more information on this on other pages here<br> |
'''DHCP setup | '''DHCP setup | ||
− | ''' | + | '''<br> |
− | First install SW | + | First install SW<br> |
'''$ sudo apt-get install hostapd isc-dhcp-server''' | '''$ sudo apt-get install hostapd isc-dhcp-server''' | ||
− | Next select interfaces you will use Pi as a DHCP server | + | Next select interfaces you will use Pi as a DHCP server<br> |
'''$ sudo vi /etc/default/isc-dhcp-server''' | '''$ sudo vi /etc/default/isc-dhcp-server''' | ||
Line 133: | Line 133: | ||
INTERFACES="'''eth0 wlan0'''" | INTERFACES="'''eth0 wlan0'''" | ||
− | Set up DHCP service | + | Set up DHCP service<br> |
− | '''$ sudo vi /etc/dhcp/dhcpd.conf''' | + | '''$ sudo vi /etc/dhcp/dhcpd.conf'''<br> |
− | At the end put in the network setup you will use | + | At the end put in the network setup you will use<br> |
− | subnet 192.168.42.0 netmask 255.255.255.0 { | + | subnet 192.168.42.0 netmask 255.255.255.0 {<br> |
− | range 192.168.42.10 192.168.42.50; | + | range 192.168.42.10 192.168.42.50;<br> |
− | option broadcast-address 192.168.42.255; | + | option broadcast-address 192.168.42.255;<br> |
− | option routers 192.168.42.1; | + | option routers 192.168.42.1;<br> |
− | default-lease-time 600; | + | default-lease-time 600;<br> |
− | max-lease-time 7200; | + | max-lease-time 7200;<br> |
− | option domain-name "local"; | + | option domain-name "local";<br> |
− | option domain-name-servers 8.8.8.8, 8.8.4.4; | + | option domain-name-servers 8.8.8.8, 8.8.4.4;<br> |
− | Put in static address on the interfaces | + | Put in static address on the interfaces<br> |
− | '''$ sudo vi /etc/network/interfaces''' | + | '''$ sudo vi /etc/network/interfaces'''<br> |
− | source-directory /etc/network/interfaces.d | + | source-directory /etc/network/interfaces.d<br> |
− | auto lo | + | auto lo<br> |
− | iface lo inet loopback | + | iface lo inet loopback<br> |
− | '''up iptables-restore < /etc/iptables.ipv4.nat''' | + | '''up iptables-restore < /etc/iptables.ipv4.nat'''<br> |
+ | <br> | ||
+ | iface eth0 inet manual<br> | ||
+ | <br> | ||
+ | '''iface eth0 inet dhcp<br> | ||
+ | iface eth0 inet static<br> | ||
+ | address 192.168.42.1<br> | ||
+ | netmask 255.255.255.0<br> | ||
+ | gateway 192.168.42.1'''<br> | ||
− | + | allow-hotplug wlan0<br> | |
− | + | #iface wlan0 inet manual<br> | |
− | + | # wpa-conf /etc/wpa_supplicant/wpa_supplicant.conf<br> | |
− | + | ''' iface wlan0 inet static<br> | |
− | + | address 192.168.42.2<br> | |
− | + | netmask 255.255.255.0<br> | |
− | |||
− | |||
− | allow-hotplug wlan0 | ||
− | #iface wlan0 inet manual | ||
− | # wpa-conf /etc/wpa_supplicant/wpa_supplicant.conf | ||
− | ''' iface wlan0 inet static | ||
− | address 192.168.42.2 | ||
− | netmask 255.255.255.0 | ||
''' | ''' | ||
− | allow-hotplug wlan1 | + | allow-hotplug wlan1<br> |
− | iface wlan1 inet manual | + | iface wlan1 inet manual<br> |
− | wpa-conf /etc/wpa_supplicant/wpa_supplicant.conf | + | wpa-conf /etc/wpa_supplicant/wpa_supplicant.conf<br> |
− | Set up WiFi as a access point | + | Set up WiFi as a access point<br> |
− | + | <br> | |
− | '''$ sudo vi /etc/hostapd/hostapd.conf''' | + | '''$ sudo vi /etc/hostapd/hostapd.conf'''<br> |
− | interface='''wlan0''' | + | interface='''wlan0'''<br> |
− | driver=rtl871xdrv | + | driver=rtl871xdrv<br> |
− | ssid='''Pi_AP''' | + | ssid='''Pi_AP'''<br> |
− | hw_mode=g | + | hw_mode=g<br> |
− | channel=6 | + | channel=6<br> |
− | macaddr_acl=0 | + | macaddr_acl=0<br> |
− | auth_algs=1 | + | auth_algs=1<br> |
− | ignore_broadcast_ssid=0 | + | ignore_broadcast_ssid=0<br> |
− | wpa=2 | + | wpa=2<br> |
− | wpa_passphrase='''Raspberry''' | + | wpa_passphrase='''Raspberry'''<br> |
− | wpa_key_mgmt=WPA-PSK | + | wpa_key_mgmt=WPA-PSK<br> |
− | wpa_pairwise=TKIP | + | wpa_pairwise=TKIP<br> |
− | rsn_pairwise=CCMP | + | rsn_pairwise=CCMP<br> |
− | ''' | + | '''<br> |
− | $ sudo vi /etc/default/hostapd''' | + | $ sudo vi /etc/default/hostapd'''<br> |
− | DAEMON_CONF="/etc/hostapd/hostapd.conf" | + | DAEMON_CONF="/etc/hostapd/hostapd.conf"<br> |
− | |||
− | |||
− | |||
− | |||
+ | '''$ sudo vi /etc/sysctl.conf'''<br> | ||
+ | At the end put in this line<br> | ||
+ | net.ipv4.ip_forward=1<br> | ||
+ | <br> | ||
'''$ wget http://adafruit-download.s3.amazonaws.com/adafruit_hostapd_14128.zip | '''$ wget http://adafruit-download.s3.amazonaws.com/adafruit_hostapd_14128.zip | ||
− | '''--2015-12-11 20:58:59-- http://adafruit-download.s3.amazonaws.com/adafruit_host | + | '''<br> |
− | unzip adafruit_hostapd_14128.zip | + | --2015-12-11 20:58:59-- http://adafruit-download.s3.amazonaws.com/adafruit_host<br> |
− | Archive: adafruit_hostapd_14128.zip | + | $ sudo unzip adafruit_hostapd_14128.zip<br> |
− | inflating: hostapd''' | + | Archive: adafruit_hostapd_14128.zip<br> |
− | $ sudo mv /usr/sbin/hostapd /usr/sbin/hostapd.ORIG | + | inflating: hostapd'''<br> |
− | $ sudo mv hostapd /usr/sbin | + | $ sudo mv /usr/sbin/hostapd /usr/sbin/hostapd.ORIG<br> |
− | $ sudo chmod 755 /usr/sbin/hostapd | + | $ sudo mv hostapd /usr/sbin<br> |
− | $ sudo service hostapd start | + | $ sudo chmod 755 /usr/sbin/hostapd<br> |
− | $ sudo service isc-dhcp-server start''' | + | $ sudo service hostapd start<br> |
− | Job for isc-dhcp-server.service failed. See 'systemctl status isc-dhcp-server.service' and 'journalctl -xn' for details. | + | $ sudo service isc-dhcp-server start'''<br> |
− | + | Job for isc-dhcp-server.service failed. See 'systemctl status isc-dhcp-server.service' and 'journalctl -xn' for details.<br> | |
+ | <br> | ||
== Set up Firewall (iptables) == | == Set up Firewall (iptables) == | ||
− | + | <br> | |
− | '''$ sudo iptables -t nat -A POSTROUTING -o eth0 -j MASQUERADE | + | '''$ sudo iptables -t nat -A POSTROUTING -o eth0 -j MASQUERADE<br> |
− | $ sudo iptables -A FORWARD -i eth0 -o wlan0 -m state --state RELATED,ESTABLISHED -j ACCEPT | + | $ sudo iptables -A FORWARD -i eth0 -o wlan0 -m state --state RELATED,ESTABLISHED -j ACCEPT<br> |
− | $ sudo iptables -A FORWARD -i wlan0 -o eth0 -j ACCEPT | + | $ sudo iptables -A FORWARD -i wlan0 -o eth0 -j ACCEPT<br> |
− | $ sudo iptables -t nat -A POSTROUTING -o ppp0 -j MASQUERADE | + | $ sudo iptables -t nat -A POSTROUTING -o ppp0 -j MASQUERADE<br> |
− | $ sudo iptables -A FORWARD -i ppp0 -o wlan0 -m state --state RELATED,ESTABLISHED -j ACCEPT | + | $ sudo iptables -A FORWARD -i ppp0 -o wlan0 -m state --state RELATED,ESTABLISHED -j ACCEPT<br> |
− | $ sudo iptables -A FORWARD -i wlan0 -o ppp0 -j ACCEPT | + | $ sudo iptables -A FORWARD -i wlan0 -o ppp0 -j ACCEPT<br> |
− | $ sudo sh -c "iptables-save > /etc/iptables.ipv4.nat"''' | + | $ sudo sh -c "iptables-save > /etc/iptables.ipv4.nat"'''<br> |
Revision as of 08:02, 22 January 2016
The main goal for this is to have a hive sending data in areas not covered with network cable to house or outside WiFi range. There is also a problem with sites without AC power. This is also covered in the section for Solar Panel.
My setup for this is:
- Raspberry Pi
- HAT board
- Weighing cells
- 2 x DHT22 Temperatur / Humidity sensors
- TSL2591 Lux sensor
- Edimax E180 3G modem
- WiFi from Raspberry
There are several things to think about
- Is this the only hive to be connected to internet.
- If there is more that one, you need to set it up as a router.
- If there is only two hives a ethernet cable between would be the most power effeciant.
- If there is more than two, you need a ethernet hub or using wifi between hives (wifi use a lot of power)
1. Only one hive connecting
Connect USB modem to pi
Check that you can see the USB modem:
$ lsusb
Bus 001 Device 004: ID 0c45:7401 Microdia
Bus 001 Device 006: ID 12d1:1003 Huawei Technologies Co., Ltd. E220 HSDPA Modem / E230/E270/E870 HSDPA/HSUPA Modem
Bus 001 Device 003: ID 0424:ec00 Standard Microsystems Corp. SMSC9512/9514 Fast Ethernet Adapter
Bus 001 Device 002: ID 0424:9512 Standard Microsystems Corp. LAN9500 Ethernet 10/100 Adapter / SMSC9512/9514 Hub
Bus 001 Device 001: ID 1d6b:0002 Linux Foundation 2.0 root hub
Update to latest versions
$ sudo apt-get update
Add program for connection to modem with disk partition
$ sudo apt-get install usb-modeswitch
Install PPP driver
$ sudo apt-get install ppp
Download and install Sakis3G application, this is stable, and easy to configure, more info on www.sakis3g.com
$ sudo wget "http://www.sakis3g.com/downloads/sakis3g.tar.gz" -O sakis3g.tar.gz
Unpack files
$ sudo tar -xzvf sakis3g.tar.gz
Make file executable
$ sudo chmod +x sakis3g
Copy file to /usr/local/bin
$ sudo cp sakis3g /usr/local/bin
Test connection (Use sudo, otherwise it maybe fails to open ports)
$ sudo ./sakis3g --interactive
1. Connect with 3G
1. USB device
3. HUAWEI Mobile
1. (internet) - (APN, maybe it differ at your mobile provider)
E180 connected to Phonero (24201). - Connected to internet
Check connection information
Interface: P-t-P (ppp0)
Connected since: 2016-01-18 14:39
Kilobytes received: 24
Kilobytes sent: 6
Network ID: 24201
Operator name: Phonero
APN: internet
Modem: E180
Modem type: USB
Kernel driver: option
Device: /dev/ttyUSB0
After testing internet connection, disconnect modem from menu
Make your own connection command
$ sudo ./sakis3g connect
Please select modem type by using OTHER variable, or by enabling interactive mode.
$ /home/pi/sakis3g --interactive "connect"
Available options are:
USBMODEM USB device
BLUETOOTH Bluetooth modem
CUSTOM_TTY Custom tty...
Example:
$ /home/pi/sakis3g OTHER="USBMODEM"
$ sudo ./sakis3g OTHER="USBMODEM" connect
Please select USB modem by using USBMODEM variable, or by enabling interactive mode.
$ /home/pi/sakis3g --interactive "OTHER=USBMODEM" "connect"
Available options are:
0424:9512 BUSNUM=001
0424:ec00 BUSNUM=001
12d1:1003 HUAWEI Mobile
1d6b:0002 DWC OTG Controller
Example:
$ /home/pi/sakis3g USBMODEM="0424:9512"
$ sudo ./sakis3g OTHER="USBMODEM" USBMODEM="12d1:1003" connect
Please select APN by using APN variable, or by enabling interactive mode.
$ /home/pi/sakis3g --interactive "OTHER=USBMODEM" "USBMODEM=12d1:1003" "connect"
Available options are:
internet (internet)
CUSTOM_APN Custom APN…
Example:
$ /home/pi/sakis3g APN="internet"
$ sudo ./sakis3g OTHER="USBMODEM" USBMODEM="12d1:1003" APN="internet" connect
E180 connected to Phonero (24201).
$ sudo ./sakis3g OTHER="USBMODEM" USBMODEM="12d1:1003" APN="internet" disconnect
Disconnected.
Connecting more hives to modem
First is to find out if you want to use static or DHCP setup for your hives.
If you want to have static setup there is more information on this on other pages here
DHCP setup
First install SW
$ sudo apt-get install hostapd isc-dhcp-server
Next select interfaces you will use Pi as a DHCP server
$ sudo vi /etc/default/isc-dhcp-server # On what interfaces should the DHCP server (dhcpd) serve DHCP requests? # Separate multiple interfaces with spaces, e.g. "eth0 eth1". INTERFACES="eth0 wlan0"
Set up DHCP service
$ sudo vi /etc/dhcp/dhcpd.conf
At the end put in the network setup you will use
subnet 192.168.42.0 netmask 255.255.255.0 {
range 192.168.42.10 192.168.42.50;
option broadcast-address 192.168.42.255;
option routers 192.168.42.1;
default-lease-time 600;
max-lease-time 7200;
option domain-name "local";
option domain-name-servers 8.8.8.8, 8.8.4.4;
Put in static address on the interfaces
$ sudo vi /etc/network/interfaces
source-directory /etc/network/interfaces.d
auto lo
iface lo inet loopback
up iptables-restore < /etc/iptables.ipv4.nat
iface eth0 inet manual
iface eth0 inet dhcp
iface eth0 inet static
address 192.168.42.1
netmask 255.255.255.0
gateway 192.168.42.1
allow-hotplug wlan0
#iface wlan0 inet manual
# wpa-conf /etc/wpa_supplicant/wpa_supplicant.conf
iface wlan0 inet static
address 192.168.42.2
netmask 255.255.255.0
allow-hotplug wlan1
iface wlan1 inet manual
wpa-conf /etc/wpa_supplicant/wpa_supplicant.conf
Set up WiFi as a access point
$ sudo vi /etc/hostapd/hostapd.conf
interface=wlan0
driver=rtl871xdrv
ssid=Pi_AP
hw_mode=g
channel=6
macaddr_acl=0
auth_algs=1
ignore_broadcast_ssid=0
wpa=2
wpa_passphrase=Raspberry
wpa_key_mgmt=WPA-PSK
wpa_pairwise=TKIP
rsn_pairwise=CCMP
$ sudo vi /etc/default/hostapd
DAEMON_CONF="/etc/hostapd/hostapd.conf"
$ sudo vi /etc/sysctl.conf
At the end put in this line
net.ipv4.ip_forward=1
$ wget http://adafruit-download.s3.amazonaws.com/adafruit_hostapd_14128.zip
--2015-12-11 20:58:59-- http://adafruit-download.s3.amazonaws.com/adafruit_host
$ sudo unzip adafruit_hostapd_14128.zip
Archive: adafruit_hostapd_14128.zip
inflating: hostapd
$ sudo mv /usr/sbin/hostapd /usr/sbin/hostapd.ORIG
$ sudo mv hostapd /usr/sbin
$ sudo chmod 755 /usr/sbin/hostapd
$ sudo service hostapd start
$ sudo service isc-dhcp-server start
Job for isc-dhcp-server.service failed. See 'systemctl status isc-dhcp-server.service' and 'journalctl -xn' for details.
Set up Firewall (iptables)
$ sudo iptables -t nat -A POSTROUTING -o eth0 -j MASQUERADE
$ sudo iptables -A FORWARD -i eth0 -o wlan0 -m state --state RELATED,ESTABLISHED -j ACCEPT
$ sudo iptables -A FORWARD -i wlan0 -o eth0 -j ACCEPT
$ sudo iptables -t nat -A POSTROUTING -o ppp0 -j MASQUERADE
$ sudo iptables -A FORWARD -i ppp0 -o wlan0 -m state --state RELATED,ESTABLISHED -j ACCEPT
$ sudo iptables -A FORWARD -i wlan0 -o ppp0 -j ACCEPT
$ sudo sh -c "iptables-save > /etc/iptables.ipv4.nat"