-
Incident report
-
Resolution: Duplicate
-
Trivial
-
None
-
2.0.6
-
Linux, CentOS-6.4, PostgreSQL 9.1.9, Apache HTTPD-2.2.15, PHP-5.3.3
There is a significant performance difference in using the API method event.get depending on the user type. The performance of event.get is extremely slow and very heavy for the database in cases where user type is not 'Zabbix Super Admin'.
I encounter this issue while testing a 3rd party Zabbix mobile application. After starting the mobile application it wasn't long before the whole Zabbix system became unavailable due to an overloaded Zabbix database.
It turns out that the heavy load was caused by several calls of the API method event.get.
I reproduced the issue by putting the following command twice into a script file for execution. The first call was always set with an 'Zabbix Super Admin' authentication token:
- curl -i -X POST -H 'Content-Type:application/json' -d'
Unknown macro: {"jsonrpc"}
' https://zabbix.example.com/zabbix/api_jsonrpc.php > /dev/null
Execution with 1st authentication token = 'Zabbix Super Admin' takes 2 seconds.
Execution with 2nd authentication token = 'Zabbix User' takes 57 seconds.
Execution with 1st authentication token = 'Zabbix Super Admin' takes 2 seconds.
Execution with 2nd authentication token = 'Zabbix Admin' takes 57 seconds.
Execution with 1st authentication token = 'Zabbix Super Admin' takes 2 seconds.
Execution with 2nd authentication token = 'Zabbix Super Admin' takes 2 seconds.
The execution time is multiplied by the number of hostids to query.
See attached EXPLAIN.txt for the execution plan.