Repository with the Weather Station Sensors Reader solution.
Based on the open project for Raspberry Pi "Build your own weather station".
Here, you can find a diagram about how to make the connections between each component easily. Useful for people who do not know much about circuits... like me :-). Be aware that the Raspberry Pi used is the old version 1, the GPIO pins may differ from one revision to another one.
As commented previously, the same components described in the project "Build your own weather station" have been used. Here is a list and where to find them (At least from Spain).
- Raspberry Pi - Actually I'm using the very old Raspberry Pi 1, hence high hardware requirements are not needed. You may have enough with a Raspberry Pi Zero W. ~ 30€ Amazon
- Micro SD - I'm using a very old 4 GB SD card, so I guess it is enough with a 8GB micro SD card, but as they are cheap, you choose your desired capacity. ~ 6€ Amazon
- Raspberry Pi OS - Download it from the official page!
- Bme280 - Ambient temperature, atmosphere pressure and air humidity sensor. ~ 5€ Ebay
- Cables jumper Male - Female - To join the sensors with the Raspberry Pi. ~ 3€ Ebay
- Cables jumper Female - Female - To enlarge the cables if desired. ~ 3€ Ebay
- DS18B20 temperature sensor - Ground temperature sensor, to measure the temperature on the ground as it may be colder above all in winter with snow. ~ 3.65€ Ebay
- 4.7K Ohm Resistor - Do not ask me why... my idea about circuits is really limited. ~ 1.39€ Ebay
- Breadboard - To mount sensors and cables. ~ 1.30€ Ebay
- 5mm Terminals - To join cables and electronic components on the breadboard. ~ 1.29€ Ebay
- Rigid cables - To make bridges between different lines on the proto board. ~ 1€ Ebay
- Digital-analogical converter - To be able to analyze vane analogical signals. ~ 3.5€ Ebay
- RJ11 breakout - To join RJ11 devices with the proto board. ~ (8.39 * 2)€ Amazon
- Weather Meter Kit - All the needed devices, pole and arms to mount them. ~ 42.31€ Aliexpress
- WeatherStationSensorsReader - Folder with the solution and its unit tests.
- .coveragerc - File with configuration for the coverage tests, to skip virtual environment folders.
- Dockerfile - Dockerfile to build the solution. Note that it is dockerized based on an ARMv6 Python image.
- docker-compose.yml - Example of compose file to run the solution from a Docker host. Note that the container must be launched with privileged mode enabled to be allowed to read information from the ic2 component.
- Jenkins files - Files with Jenkins pipelines, separating branches from master branch. They are using this shared library project.
- LICENSE - File with the license, basically it says that you can use the code as you wish.
- README.md - This file!
- sonar-project.properties - File with configuration to execute Sonarqube analysis during master build.
- VERSION - Plain/text file with the version of the solution. It is used to tag the image once it is deployed.
- All the components must be connected to the Raspberry Pi follow the link about the project to know how to do it.
- The device needs a LAN connection, either Wi-Fi or wired.
- I2C interface must be enabled. Follow this tutorial.
- 1-wire interface must be enabled. Follow this tutorial.
The solution is intended to take measurements from the environment and also to store the obtained values in a database passed as parameters. There are some parameters to define the behavior of the solution or just to limit some aspects of its execution, they are described below.
- LOGGING_LEVEL - Possible values are CRITICAL, ERROR, WARNING, INFO and DEBUG. It defines the level of logging traces to register.
- MINUTES_BETWEEN_READS - By default, the app waits 5 minutes between measurements, with this parameter you can change the waiting time.
- FAKE_SENSOR_ENABLED - true / false. Just for testing purposes, instead of getting values from the sensors, random values are obtained. No values are inserted in the database but only showed in the log traces. It is useful for checking if the application runs correctly and it has access to the database configured. In case of configuring a fake sensor, the rest of the possible sensors defined are skipped.
- BME_280_SENSOR_ENABLED - true / false. In case of being enabled, the application will perform ambient temperatures, air humidity and atmosphere pressure measurements.
- GROUND_SENSOR_ENABLED - true / false. In case of being enabled, the application will perform ground temperature measurements.
- WIND_SENSOR_ENABLED - true / false. In case of being enabled, the application will perform wind measurements such as wind speed, gust speed and wind direction.
- RAINFALL_SENSOR_ENABLED - true / false. In case of being enabled, the application will perform amount of rain measurements.
- ANEMOMETER_PORT_NUMBER - The GPIO port number where the anemometer device is connected to.
- RAIN_GAUGE_PORT_NUMBER - The GPIO port number where the rain gauge device is connected to.
- SERVER - Database server. In case of it is empty, measurements retrieved will not be stored anywhere, just showed in the log traces with INFO level.
- DATABASE - Database name
- USER - User name
- PASSWORD - User password
A docker-compose example is provided with the solution code, but it can be launched via command-line. Either way, the container must be created with privileged permissions to be able to access to Raspberry Pi hardware.
version: '3.5'
services:
sensors-reader:
container_name: sensors-reader
image: weatherstationproject/sensors-reader
privileged: true
restart: unless-stopped
environment:
- LOGGING_LEVEL=ERROR
- BME_280_SENSOR_ENABLED=true
- GROUND_SENSOR_ENABLED=true
- WIND_SENSOR_ENABLED=true
- RAINFALL_SENSOR_ENABLED=true
- ANEMOMETER_PORT_NUMBER=22
- RAIN_GAUGE_PORT_NUMBER=25
- SERVER=127.0.0.1
- DATABASE=my_db
- USER=my_user
- PASSWORD=my_password
volumes:
- '/etc/timezone:/etc/timezone:ro'
- '/etc/localtime:/etc/localtime:ro'
docker run --rm -d --name=sensors-reader --privileged -e LOGGING_LEVEL=ERROR -e BME_280_SENSOR_ENABLED=true -e GROUND_SENSOR_ENABLED=true -e WIND_SENSOR_ENABLED=true -e RAINFALL_SENSOR_ENABLED=true -e ANEMOMETER_PORT_NUMBER=22 -e RAIN_GAUGE_PORT_NUMBER=25 -e SERVER=127.0.0.1 -e DATABASE=my_db -e USER=my_user -e PASSWORD=my_password -v /etc/timezone:/etc/timezone:ro -v /etc/localtime:/etc/localtime:ro weatherstationproject/sensors-reader
version: '3.5'
services:
sensors-reader:
container_name: sensors-reader
image: weatherstationproject/sensors-reader
restart: unless-stopped
environment:
- LOGGING_LEVEL=ERROR
- FAKE_SENSOR_ENABLED=true
volumes:
- '/etc/timezone:/etc/timezone:ro'
- '/etc/localtime:/etc/localtime:ro'
docker run --rm -d --name=sensors-reader -e LOGGING_LEVEL=ERROR -e FAKE_SENSOR_ENABLED=true -v /etc/timezone:/etc/timezone:ro -v /etc/localtime:/etc/localtime:ro weatherstationproject/sensors-reader
- 1.3.0 - Added rain gauge device to measure amount of rain. Improved the way to gather measurements.
- 1.2.0 - Added wind sensors such as the anemometer and the vane. Restructuring of Jenkins files. Improved the health check.
- 1.1.0 - Added ground temperature sensor, fixed some code smells and documentation.
- 1.0.0 - First version with ambient temperature, air humidity and atmosphere pressure sensors.
Use this code as you wish! Totally free to be copied/pasted.
If you liked the repository, you found it useful and you are willing to contribute, don't hesitate! I will be very grateful! :-)