Utilities package
Project description
ScadaUtils V0.2
DESCRIPTION
This package contains utilities for :
- comUtils : to standardize the dumping of data from different devices(Modbus,Meteo,OPCUA) with a Streamer, SuperDumper_daily and VisualisationMaster_daily
- Simulators : to simulate the flow of data from devices(servers) from comUtils
- utilsD : convenient plotly,pandas extensions to work faster
- versionManagers : to deal with historical data folders and to make them compatible with the daily visualisation master.
DASHBOARD
for your dashboard application to work with the standard dashboard template you need :
- instanciate an Dashboard application as in the example bellow:
from sylfenUtils import dashboard
dash=dashboard.Dashboard(cfg,LOG_DIR,root_folder)
cfg is a standard from ComUtils VisualisationMaster_daily object from comUtils.
TUTORIAL
There is a jupyter-notebook available here to learn how to dump realtime data from different modbus,opcua devices, and how to read them in realtime. A dashboard can also be used
pre-requisites
postgresSQL
- postgressql server should be active running on port 5432(user:postgres,password:sylfenbdd) containing a jules database with a realtimedata table(default settings).
- do not forget to cofnigure pg_hba.conf correctly.
- you change password of user postgres with :
alter user <postgres> password '<newpassword>';
DEPLOYMENT AND PRODUCTION
Create a file .service :
[Unit]
Description=dumping data from <my_project>
After=network.target
[Service]
User=<user>
Group=<group_user>
WorkingDirectory=<your_path_to_job>/job/
Environment="PATH=<your_virtual_env_path>/bin"
ExecStart=<your_virtual_env_path>/bin/python <your_job>.py
[Install]
WantedBy=multi-user.target
- Make a symbolic link of this file (or copy it) into
systemd
folder:
cd /etc/systemd/system/
ln -s <your_service_path>
REMARKS:
- of course the dumper can be manually started with
python job/<your_job>.py
. - systemctl command
- start :
systemctl start <your_job>.service
- status :
systemctl status <your_job>.service
- enable(start at boot):
systemctl enable <your_job>.service
- stop :
systemctl stop <your_job>.service
- start :
Serving dashboard
To serve the dashboard(from your virtual environment) just :
python dashboard/dashboard_<your_project>.py
Dashbaord in production environmment ==> GUNICORN
To serve the dashboard in a production environment(more reliable) you need to start it with gunicorn. The best is to create a file <your_dashboard>.service with following content:
[Unit]
Description=Gunicorn instance to serve small power dashboard
After=network.target
[Service]
User=<username>## the user that runs the dashboard
Group=<group>## the group that runs the dashboard
WorkingDirectory=<path>### path of the dashboard application
Environment="PATH=<path_to_venv>"## the python environment used
ExecStart=<path_gunicorn> -b localhost:<port_dashboard> -w 4 dashboard_<your_project>:app ## precise the full path where to find gunicorn in your venv and the port of the dashboard. You can also change -w which is the number of clients served simultaneously.
[Install]
WantedBy=multi-user.target
- Make a symbolic link of this file (or copy it) into
systemd
folder:
cd /etc/systemd/system/
ln -s <your_service_path><your_project>.service
You can start <your_project> service (this is to be done only once).
sudo systemctl start <your_project>
If you get this error Unit <your_project>.service could not be found.
do :systemctl daemon-reload
Enable the <your_project> dashboard service so that it automatically starts at boot:
sudo systemctl enable <your_project>
Check status, enabled status, and log activity with respectively:
sudo systemctl status <your_project>
systemctl list-unit-files
journalctl | grep <your_project>
If there are not any big error but the dashboard is not accessible, it means there is an error in the dashboard_<your_project>.py somewhere. Try to run in with flask : app.run(), check access and then with gunicorn ==> <your_env>/gunicorn -b localhost:<port> dashboard_<your_project>:app
Link a domain name to the website ==> NGINX
If you want to redirect the name of the url using your domain name you have to do a redirection of the port using nginx. Create a file <url_app>.conf virtual host file with following content:
server {
listen 80;
server_name <domain name><your_project>.sylfen.com <domain name>;
location / {
proxy_pass http://127.0.0.1:<port_dashboard>;
}
}
- Make a symbolic link of this file (or copy it) into
sites-available
andsites-enabled
folders:
ln -s <your_<your_project>.conf_file> /etc/nginx/sites-available
ln -s <your_<your_project>.conf_file> /etc/nginx/sites-enabled
REMARK :
- On a local network a switch can only redirect the port 80(default port for HTTP) and/or the port 443(default port for HTTPS) to one device on the network. This means that if the port is already forwarded to a machine different from yours, your website won't be accessible.
- if you still want to make test on your reverse proxy, you can force the redirection by editing
/etc/hosts
by adding a line ==> 127.0.0.1 <your_domain_name>. Your browser will directly associate the domain_name to your machine and won't search on the internet.
update your configuration
To take the modification of your configuration into account :
sudo nginx -s reload
This will reload all the configuration of the websites in sites-available
.
GOOD PRACTICES :
make tests on remote machine
In order no to corrupt and create bugs to a deployed version while trying to make some tests on remote machine, a good way is :
- to create another user
- give him access to the data but make sure it can't modify them. Datafolder should be 775 permissions.
- clone the git project in a folder
- create a virtual environmment(as always) and install the library. You are ready to make tests safely!!!
easy procedure to update the production environment
Once you are done with you your tests and your are sure that the version is stable and not creating bugs you are ready for release it for users. Then
- update(stabilize) the version of sylfenUtils and that of <your_project> with the sylfenUtils dependency.
- git push both
- git pull in the production folder
- install with pip in your .env environment virtual the new version and uninstall if necessary the sylfenUtils dependency before new installation.
- restart <your_project>.service to see the effect :
systemctl restart <your_project>.service
cd <your_project>
git pull
source .env/bin/activate
pip uninstall sylfenUtils
pip install .
systemctl restart <your_project>.service
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
File details
Details for the file scadaUtils-0.2.1.tar.gz
.
File metadata
- Download URL: scadaUtils-0.2.1.tar.gz
- Upload date:
- Size: 4.7 MB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/3.1.1 pkginfo/1.4.2 requests/2.28.1 setuptools/45.2.0 requests-toolbelt/0.8.0 tqdm/4.57.0 CPython/3.8.10
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | bbc5041b52f1947a16645f7e4ac6441615b2c643c78ba7c8666c1b92e6d56e7d |
|
MD5 | 4ac8dd381a77abaaebcc6acfc8c69a34 |
|
BLAKE2b-256 | 85e549f47843400015596f1a95760d7ed1ecd63e3f1950976e735b344247906c |
File details
Details for the file scadaUtils-0.2.1-py3-none-any.whl
.
File metadata
- Download URL: scadaUtils-0.2.1-py3-none-any.whl
- Upload date:
- Size: 4.7 MB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/3.1.1 pkginfo/1.4.2 requests/2.28.1 setuptools/45.2.0 requests-toolbelt/0.8.0 tqdm/4.57.0 CPython/3.8.10
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | d8d1c5ee51cf031754ef2bfd91bee76f0df5df9472e2e42705ad02971b35aeea |
|
MD5 | 2d409776eab2532ba39ee880f4ebfdfb |
|
BLAKE2b-256 | b94b68211f79c167bc380195fdf258e6524712747fc694130022f52e045d81be |