These notes are for upgrading from Zabbix 7.2.x to Zabbix 7.4.0.
All notes are grouped into:
See also:
To complete a successful Zabbix server upgrade on MySQL/MariaDB, you may require to set GLOBAL log_bin_trust_function_creators = 1 in MySQL if binary logging is enabled, there are no superuser privileges and log_bin_trust_function_creators = 1 is not set in MySQL configuration file.
To set the variable using the MySQL console, run:
Once the upgrade has been successfully completed, this option can be disabled:
The PCRE (or PCRE1) library has been dropped. Zabbix is now compiled with PCRE2.
All users are now allowed to manage their own media by default.
User permissions to change media details for themselves can be granted (or revoked) based on their user role (see Create and edit own media option).
Additionally, Super admin user permissions to change media details for others can also be granted/revoked based on their user role (see Create and edit user media option).
If upgrading from older versions, both options will be enabled for all roles having the Default access to new actions enabled. Note that if Default access to new actions is not enabled, administrators and super administrators may lose the ability to edit media after the upgrade.
Proper escaping of backslashes has been added in history function string parameters since Zabbix 7.0.0.
As additional backslashes are added during the upgrade from pre-7.0 Zabbix versions, this leads to longer parameters which may result in broken trigger functions if the parameter length exceeds the maximum data size of 255 characters.
To avoid this problem it is recommended to manually move long parameters into user macros before the upgrade.
Additional checks for the resulting parameter length have been added for upgrades from pre-7.0 Zabbix versions. If the resulting length exceeds the maximum size, such parameters are not upgraded while printing a warning in the logs asking users to fix the listed parameters manually.
See also escaping-related upgrade issues.
The template MSSQL by Zabbix agent 2 has been updated with filters to include or exclude discovered quorum members by name as well as a service filter that allows filtering by cluster name to exclude empty clusters. To have the template work without errors, the MSSQL Zabbix agent 2 plugin must be updated to a version equal to or above 7.4.0.
The minimum required libssh2 version has been raised from 1.0.0 to 1.8.0.
If your current configuration includes host prototypes that use templates containing other host prototypes, upgrading to Zabbix 7.4 will cause all discovered hosts to have the host prototypes defined in those templates. If this behavior is not intended, please manually delete the host prototypes from the relevant templates before upgrading.
To identify discovered hosts that will receive host prototypes during the upgrade, you can run the following SQL query in your Zabbix database:
SELECT h.hostid,ht.templateid
       FROM hosts_templates ht
       JOIN hosts h ON ht.hostid=h.hostid
       WHERE h.flags=4
         AND EXISTS (
           SELECT NULL
           FROM items i,host_discovery hd
           WHERE i.hostid=ht.templateid
           AND hd.parent_itemid=i.itemid
           )
       ORDER BY hostid;DBPort and DBSocket are now mutually exclusive. When specifying database connection parameters, you may define either DBPort or DBSocket, or leave both undefined to use defaults.
SNMP walk items, in case none of the OIDs or OID instances exist, now return an error and the item becomes unsupported. The non-existing OID/instance details are logged with DebugLevel=5. Previously they would return an empty string in such cases.
Similarly, SNMP discovery items, in case none of the OIDs or OID instances exist, now return an error and the item becomes unsupported. Previously they would return an empty array in such cases.
Note that empty string/array is now returned only if the OID/instance exists, but there is no data for it.
In some data collection scenarios, specific items can temporarily block the server/proxy history cache. This may delay writing history data to the database and slow down the system. To help manage the history cache, the following improvements have been introduced:
For long-term system stability, make sure that data collection is balanced with available resources (database performance, cache size, collection intervals, log item parameters, etc.). You can monitor Zabbix history cache using the zabbix[wcache] internal item. You can also consider increasing the size of the history cache for Zabbix server/proxy.
For better visibility of user media, user notifications now have their own menu section under User settings.
The new Notifications section contains two tabs - Media and Frontend notifications, which previously were part of the user profile section.
Information from nested host groups is now correctly displayed in maps, for example:
The settings table now replaces the config table for storing global configuration parameters. The new table uses a key-value format instead of storing parameters in a single row with a column per parameter. For an example of how this affects data exchange, see Server-proxy data exchange protocol ("settings" object).
The maximum cache sizes have been raised from 2 GB to 16 GB to delay cache exhaustion and sustain operation during temporary issues (e.g. configuration, database, or network problems):
The default storage period for user session data has been reduced from 365 days to 31 days. This change affects the hk_sessions parameter, which now defaults to 31d instead of 365d.
The minimum supported Go version has been raised from 1.21 to 1.23.
If you previously built Zabbix agent 2, agent 2 loadable plugins, or web service from source using a Go version older than 1.23, it is recommended to rebuild these components using a supported Go version to receive the latest security updates and bug fixes. Components built with an older Go version will continue to work, but upgrading them will require a newer Go environment.
The new Host Wizard introduces a guided, step-by-step interface for setting up your monitoring target (device, application, service, etc.) in Zabbix. It simplifies the configuration of new or existing hosts by walking users through key steps such as selecting a template, installing Zabbix agent, adding host interfaces, and more.
After upgrading from an earlier Zabbix version, templates must be upgraded to work with the Host Wizard. For instructions, see Template upgrade.