Frequently asked questions and possible issues you can encounter with Cloud4RPi:
How to update Cloud4RPi client installation?
sudo pip install --upgrade cloud4rpi
What are packets?
Packet is a data portion sent from a device to the Cloud4RPi server (using the MQTT or HTTPs protocol). A single packet can include multiple variable values. Diagnostic data transfer is unlimited and does not consume packets.
Packet information is displayed at the top right corner of Cloud4RPi pages and in the Pricing Plan category of your account settings.
Learn more about the subscription plans in the Plans and Pricing section.
How to avoid an Installation Error?
You can get one of the following errors when you use the
sudo pip install cloud4rpi command to install the Cloud4RPi client library:
- InstallationError: Command "python setup.py egg_info" failed with error code 1
- Error while finding spec for 'pip.__main__' (<class 'ImportError'>: cannot import name 'IncompleteRead'); 'pip' is a package and cannot be directly executed
This happens because the setuptools and/or pip packages your Python interpreter uses are outdated. Update the packages with the following command:
sudo pip install --upgrade setuptools pip
After updating, reinstall cloud4rpi:
sudo pip install cloud4rpi
Raspberry Pi does not recognize my 1-Wire device
Follow the instructions below if you experience issues with the 1-Wire interface on Raspberry Pi.
sudo raspi-configand make sure that the 1-Wire interface is enabled (Interfacing Options | 1-Wire menu).
- Add the
dtoverlay=w1-gpiostring to your
echo dtoverlay=w1-gpio | sudo tee -a /boot/config.txt).
- Reboot (
Double-check the wiring and your device's operational voltage. The 1-Wire DATA bus should be connected to GPIO4 (Pin 7) and pulled-up to VCC.
How to avoid the "Insecure Platform" warning?
InsecurePlatformWarning: A true SSLContext object is not available... notification appears when you run Cloud4RPi on Python v2.7.9 and earlier. Use the following command to check the Python version:
You can use one of the following approaches to install the latest version:
Where are the log files?
Use one of the following commands to read the logs containing the service's output and errors:
less /var/log/cloud4rpi.log— if your init manager is
initand you have left the service name and log path unchanged;
sudo journalctl -u cloud4rpi— if your init manager is
systemdand you have not changed the service name.
ps -p 1 command to see your operating system's init manager. Refer to your init manager's documentation for more information or contact us if it differs from
You can also call the following function at the beginning of your script to save the script output. It is useful if you do not run your Cloud4RPi-enabled script as a service:
How to use the service installed using the service_install.sh script?
The default service's name is cloud4rpi (can be changed in service_install.sh:4). You can use the following commands if your init manager is
sudo service cloud4rpi start|stop|status|restart|uninstall
If your init manager is
systemd, you can use the same commands except for
uninstall. To remove the
systemd service, execute the following commands:
sudo systemctl stop cloud4rpi.service sudo systemctl disable cloud4rpi.service sudo rm /lib/systemd/system/cloud4rpi.service sudo systemctl daemon-reload
How to choose the DATA_SENDING_INTERVAL value?
Call device.publish_data() and device.publish_diag() functions frequently to update the monitored variables. The update frequency depends on the variable dynamics, for example, atmospheric conditions do not change every minute. This means the delay between updates for a weather station should be one to ten minutes. You should also consider available packets when choosing the
If you monitor several variables with different dynamics, the delay between updates should be the shortest.
The variable update interval does not affect commands, and variable changes made through the Web UI (Switch or Slider widget) are applied instantly.
[Arduino IDE] How to avoid WiFi library collision?
Multiple libraries were found for "WiFi.h" message can appear in Arduino IDE. This indicates the IDE has two libraries with the same name, and it does not know which one to use.
To avoid this error, specify the absolute path to the header file in the
#include directive, for example:
You can copy-paste the valid path to both libraries that appear in the error message. Add the
src\ subfolder between the library path and header file name.