Releases: nicolargo/glances
Glances 4.3.0.8
Full Changelog: v4.3.0.7...v4.3.0.8
Glances 4.3.0.7
Full Changelog: v4.3.0.6...v4.3.0.7
Glances 4.3.0.6
Full Changelog: v4.3.0...v4.3.0.6
Deprecation warning
netifaces is deprecated and should be uninstall. instead netifaces2 should be install:
pip uninstall netifaces
pip install netifaces2
Glances 4.3.0
Glances 4.3.0 is available with the Browser Feature now available in your Web Browser. Run Glances with the following command line and all the Glances server (RestAPI or XML/RPC) will be avaialble in a single page:
glances -w --browser
Others enhancements:
- Web Based Glances Central Browser #1121
- Ability to specify hide or show for smart plugin #2996
- Thread mode ('j' hotkey) is not taken into accound in the WebUI #3019
- [WEBUI] Clear old alert messages in the WebUI #3042
- Raise an (Alert) Event for a group of sensors #3049
- Allow processlist columns to be selected in config file #1524
- Allow containers columns to be selected in config file #2722
- [WebUI] Unecessary space between Processcount and processlist #3032
- Add comparable NVML_LIB check for Windows #3000
- Change the default path for graph export to /tmp/glances
- Improve CCS of WebUI #3024
Bug corrected:
- Thresholds not displayed in the WebUI for the DiskIO plugin #1498
- FS module alias configuration do not taken into account everytime #3010
- Unexpected behaviour while running glances in docker with --export influxdb2 #2904
- Correct issue when key name contains space - Related to #2983
- Issue with ports plugin (for URL request) #3008
- Network problem when no bitrate available #3014
- SyntaxError: f-string: unmatched '[' in server list (on the DEVELOP branch only) #3018
- Uptime for Docker containers not working #3021
- WebUI doesn't display valid time for process list #2902
- Bug In the Web-UI, Timestamps for 'Warning or critical alerts' are showing incorrect month #3023
- Correct display issue on Containers plugin in WebUI #3028
Continuous integration and documentation:
- Bumped minimal Python version to 3.9 #3005
- Make the glances/outputs/static/js/uiconfig.json generated automaticaly from the make webui task
- Update unit-test for Glances Central Browser
- Add unit-test for new entry point in the API (plugin/item/key)
- Add a target to start Glances with Htop features
- Try new build and publish to Pypi CI actions
Thanks to all contributors and bug reporters !
Special thanks to:
- Ariel Otilibili for code quality improvements #2801
Glances 4.2.1
Enhancements:
Bug corrected:
- Possible memory leak #2976
- Docker/Podman shoud not flood log file with ERROR if containers list can not be retreived #2994
- Using "-w" option gives error: NameError: name 'Any' is not defined #2992
- Non blocking error message when Glances starts from a container (alpine-dev image) #2991
Continuous integration and documentation:
Thanks to all contributors and bug reporters !
Special thanks to:
- @branchvincent for pyproject migration
Glances 4.2.0
Enhancements:
- Call process_iter.clear_cache() (PsUtil 6+) when Glances user force a refresh (F5 or CTRL-R) #2753
- PsUtil 6+ no longer check PID reused #2755
- Add support for automatically hiding network interfaces that are down or that don't have any IP addresses #2799
Bug corrected:
- API: Network module is disabled but appears in endpoint "all" #2815
- API is not compatible with requests containing special/encoding char #2820
- 'j' hot key crashes Glances #2831
- Raspberry PI - CPU info is not correct #2616
- Graph export is broken if there is no graph section in Glances configuration file #2839
- Glances API status check returns Error 405 - Method Not Allowed #2841
- Rootless podman containers cause glances to fail with KeyError #2827
- --export-process-filter Filter using complete command #2824
- Exception when Glances is ran with limited plugin list #2822
- Disable separator option do not work #2823
Continuous integration and documentation:
- test test_107_fs_plugin_method fails on aarch64-linux #2819
Thanks to all contributors and bug reporters !
Special thanks to:
- Bharath Vignesh J K
- RazCrimson
- Vadim Small
Glances 4.1.2
Version 4.1.2
Bug corrected:
- AttributeError: 'CpuPercent' object has no attribute 'cpu_percent' #2859
Version 4.1.1
Bug corrected:
- Sensors data is not exported using InfluxDB2 exporter #2856
Version 4.1.0
Enhancements:
- Call process_iter.clear_cache() (PsUtil 6+) when Glances user force a refresh (F5 or CTRL-R) #2753
- PsUtil 6+ no longer check PID reused #2755
- Add support for automatically hiding network interfaces that are down or that don't have any IP addresses #2799
Bug corrected:
- API: Network module is disabled but appears in endpoint "all" #2815
- API is not compatible with requests containing spcial/encoding char #2820
- 'j' hot key crashs Glances #2831
- Raspberry PI - CPU info is not correct #2616
- Graph export is broken if there is no graph section in Glances configuration file #2839
- Glances API status check returns Error 405 - Method Not Allowed #2841
- Rootless podman containers cause glances to fail with KeyError #2827
- --export-process-filter Filter using complete command #2824
- Exception when Glances is ran with limited plugin list #2822
- Disable separator option do not work #2823
Continious integration and documentation:
- test test_107_fs_plugin_method fails on aarch64-linux #2819
Thanks to all contibutors and bug reporters !
Special thanks to:
- Bharath Vignesh J K
- RazCrimson
- Vadim Smal
Glances 4.1.1
Version 4.1.1
Bug corrected:
- Sensors data is not exported using InfluxDB2 exporter #2856
Version 4.1.0
Enhancements:
- Call process_iter.clear_cache() (PsUtil 6+) when Glances user force a refresh (F5 or CTRL-R) #2753
- PsUtil 6+ no longer check PID reused #2755
- Add support for automatically hiding network interfaces that are down or that don't have any IP addresses #2799
Bug corrected:
- API: Network module is disabled but appears in endpoint "all" #2815
- API is not compatible with requests containing spcial/encoding char #2820
- 'j' hot key crashs Glances #2831
- Raspberry PI - CPU info is not correct #2616
- Graph export is broken if there is no graph section in Glances configuration file #2839
- Glances API status check returns Error 405 - Method Not Allowed #2841
- Rootless podman containers cause glances to fail with KeyError #2827
- --export-process-filter Filter using complete command #2824
- Exception when Glances is ran with limited plugin list #2822
- Disable separator option do not work #2823
Continious integration and documentation:
- test test_107_fs_plugin_method fails on aarch64-linux #2819
Thanks to all contibutors and bug reporters !
Special thanks to:
- Bharath Vignesh J K
- RazCrimson
- Vadim Smal
Glances 4.0.8
Version 4.0.8
- Make CORS option configurable security webui #2812
- When Glances is installed via venv, default configuration file is not used documentation packaging #2803
- GET /1272f6e9e8f9d6bfd6de.png results in 404 bug webui #2781 by Emporea was closed May 25, 2024
- Screen frequently flickers when outputting to local display bug needs test #2490
- Retire ujson for being in maintenance mode dependencies enhancement #2791
Glances 4.0.7
Version 4.0.7
- cpu_hz_current not available on NetBSD #2792
- SensorType change in REST API breaks compatibility in 4.0.4 #2788
Version 4.0.6
- No GPU info on Web View #2796
Version 4.0.5
- SensorType change in REST API breaks compatibility in 4.0.4 #2788
- Please make pydantic optional dependency, not required one #2777
- Update the Grafana dashboard #2780
- 4.0.4 - On Glances startup "ERROR -- Can not init battery class #2776
- In codeSpace (with Python 3.8), an error occurs in ./unittest-restful.py #2773
Use Ruff as default Linter.
Version 4.0.4
Hostfix release for support sensors plugin on python 3.8
Version 4.0.3
Additional fixes for Sensor plugin
Version 4.0.2
- hotfix: plugin(sensors) - race conditions btw fan_speed & temperature… #2766
- fix: include requirements.txt and SECURITY.md for pypi dist #2761
Thanks to RazCrimson for the sensors patch !
Version 4.0.1
Correct issue with CI (miss pydantic dep).
Version 4.0.0
New Features
Export individual processes stats
Thanks to the new software architecture it is now possible to export individual processes stats.
You should define the processes to export from the configuration file (section processlist /option export)
or via the --export-process-filter option on the command line.
Those options are a comma separated list of Glances filter (example bellow):
- python.*: Filter processes name or command line starting with python
- .python.: Filter processes name or command line containing python
- username:nicolargo: Processes belong to nicolargo user
- cmdline:/usr/bin.*: Processes starting by /usr/bin
The following example exports all processes with the name 'python' or 'bash':
[processlist]
export=.*python.*,.*bash.*
Note: or the --export-process-filter ".python.,.bash." option in the command line.
Another example exports all processes belong to 'nicolargo' user:
[processlist]
export=username:nicolargo
Note: or the --export-process-filter "username:nicolargo" option in the command line.
Last example with the output result in a CSV file, with the following command line example:
glances -C ./conf/glances.conf --export csv --export-csv-file /tmp/glances.csv --disable-plugin all --enable-plugin processlist --quiet
the output CSV file (with the PID as primary key) will look like:
timestamp,845992.memory_percent,845992.status,845992.num_threads,845992.cpu_timesuser,845992.cpu_timessystem,845992.cpu_timeschildren_user,845992.cpu_timeschildren_system,845992.cpu_timesiowait,845992.memory_inforss,845992.memory_infovms,845992.memory_infoshared,845992.memory_infotext,845992.memory_infolib,845992.memory_infodata,845992.memory_infodirty,845992.name,845992.io_counters,845992.nice,845992.cpu_percent,845992.pid,845992.gidsreal,845992.gidseffective,845992.gidssaved,845992.key,845992.time_since_update,845992.cmdline,845992.username,total,running,sleeping,thread,pid_max
2024-04-03 18:39:55,3.692938041968513,S,138,1702.88,567.89,1752.79,244.18,0.0,288919552,12871561216,95182848,856064,0,984535040,0,firefox,1863281664,0,0.5,845992,1000,1000,1000,pid,2.2084147930145264,/snap/firefox/3836/usr/lib/firefox/firefox,nicolargo,403,1,333,1511,0
2024-04-03 18:39:57,3.692938041968513,S,138,1702.88,567.89,1752.79,244.18,0.0,288919552,12871561216,95182848,856064,0,984535040,0,firefox,1863281664,0,0.5,845992,1000,1000,1000,pid,2.2084147930145264,/snap/firefox/3836/usr/lib/firefox/firefox,nicolargo,403,1,333,1511,0
Note: more details in issue #794.
GPU plugin now support AMD GPU
Lasts Linux Kernel expose the GPU stats in the /sys/class/drm folder.
So, additionally to NVidia cards and without any external lib, Glances can display AMD GPU stats:
GPU plugin software architecture has been re-factorized in order to easily add others cards in the future (Intel).
Note: more details in issue #993.
Wifi plugin is back
As Glances version 4 is no longer supported Python 2, Wifi plugin has been refactor and do not need any external library.
Glances parses the /proc/net/wireless file on new Linux kernel.
Note: more details in issue #1377.
Refactor alias configuration
Alias has been completely refactor for all plugins in order to make it easier to configure.
Glances version 3.x and lower:
sda1_alias=InternalDisk
sdb1_alias=ExternalDisk
Glances version 4.x and higher:
alias=sda1:InternalDisk,sdb1:ExternalDisk
Note: more details in issue #1735.
Fields descriptions and units are now available through the API
You can now get stat description and unit through the Glances version 4 API.
$ curl http://0.0.0.0:61208/api/4/cpu/total
{"total":6.3}
$ curl http://0.0.0.0:61208/api/4/cpu/total/description
"Sum of all CPU percentages (except idle)."
$ curl http://0.0.0.0:61208/api/4/cpu/total/unit
"percent"
Note: more details in issue #2630.
Make the left menu configurable
It is now possible to configure the plugins list displayed in the Curses and Web interfaces thanks to the left_menu option in the outputs section of the Glances configuration file:
[outputs]
left_menu=network,diskio
Display:
Quick look plugin is now configurable
By default it displays CPU, Memory and Load information.
Example to cam back to the Glances version 3.0 configuration (with swap instead of load):
[quicklook]
# Stats list (default is cpu,mem,load)
# Available stats are: cpu,mem,load,swap
list=cpu,mem,swap
# Graphical bar char used in the terminal user interface (default is |)
bar_char=|
Note: More information in issue #2662.
Enhance per CPU display
Number of cores increase, so the "Per CPU" plugin has been adpated in order to display the top 'n' CPU consuption ('n' is configurable from the Glances configuration file through the max_cpu_display option in the percpu section (default is 4 CPUs).
Note: see more details in issue #2734.
Display guest CPU statistic in the CPU plugin
On Linux, guest CPU is percentage of time a virtual CPU spends servicing another virtual CPU under the control of the kernel.
- Ability to hide Engine and Pod columns in Containers #2423
A new logo !
Last and not least, thanks to Elad @eBarazi...
a new logo is released...
Improvements
Speed up Glances launch
Glances version 3 takes between 2 and 3 seconds to start.
Glances version 4 takes less than 1 seconds to start, with all plugins.
See #1534 for more information.
Huge improvement of the Restful API documentation
More example and information available in the single page documentation: https://github.com/nicolargo/glances/blob/develop/docs/api.rst
Breaking changes
Python version
Support of Python 2 has been removed. Glances needs Python 3.8 or higher.
Python dependencies
For package maintainers, please note that standards dependencies have changed.
Minimal requirements for Glances version 4 are:
- psutil
- defusedxml
- packaging
- ujson
- pydantic
- fastapi (for WebUI / RestFull API)
- uvicorn (for WebUI / RestFull API)
- jinja2 (for WebUI / RestFull API)
Majors changes between Glances version 3 and version 4:
- Bottle has been replaced by FastAPI and Uvicorn
- CouchDB has been replaced by PyCouchDB
- nvidia-ml-py has been replaced by py3nvml
- pysnmp has been replaced by pysnmp-lextudio
APIs
- XML/RPC API have changed between Glances 3 and Glances 4. It is not possible to use a Glances 3.x client with a Glances 4.x.
- Restful API upgraded to version 4 (default entry point is http://localhost:61208/api/4).
Alias definition change in the configuration file
Glances version 3.x and lower:
sda1_alias=InternalDisk
sdb1_alias=ExternalDisk
Glances version 4.x and higher:
alias=sda1:InternalDisk,sdb1:ExternalDisk
More details in issue #1735.
Others
- Alert data model change from a list of list to a list of dict #2633
- Docker memory usage uses the same algorithm than docker stats #2637
All the issues corrected in this version
Enhancements:
- Export individual processes stats #794
- [WebUI] Feature Request: Ability to hide Engine and Pod columns in Containers #2423
- [IP plugin] Make the public ip information more configurable (not only from the Censys service) #2732
- Getting field information (description, unit) from the API #2630
- Refactor alias configuration and allow alias for fs devices #1735
- Improve alert with mininimal interval/duration configuration keys #2558
- --stdout plugin.attr is not compliant with plugins returning list of dicts #2446
- Lot's of log messages when a proxy is used with the Podman plugin #2714
- [WEBUI & CURSES] Make the left menu configurable #2648
- [WEBUI] Custom system header information #2695
- [CURSES] Use normal color for normal text instead of an arbitrary color #2687
- [WEBUI] Showin...