Description
This article describes the typical steps involved to optimize memory consumption on desktop FortiGate models, and some 1RU models of FortiGate (smaller than 200F).
Every enabled feature on the FortiGate will consume memory. Models with lower amounts of available system memory, and that have many features enabled, may not have enough working memory for typical firewall tasks.
Scope
FortiGate models with 4GB system memory or less.
Solution
High baseline memory use on a device might be expected, particularly depending on the hardware platform. Total system memory is visible using the 'get hardware memory' command.
The commands below should be used under the 'config system global' in the multi-VDOM environment. 
get hardware memory | grep MemTotal
MemTotal: 1963668 kB
get system performance status | grep Memory -A 1
Memory: 1963668k total, 1207888k used (61.5%), 562756k free (28.7%), 193024k freeable (9.8%)
Average network usage: 39 / 37 kbps in 1 minute, 39 / 36 kbps in 10 minutes, 41 / 165 kbps in 30 minutes
If memory used is 60% or more during nominal traffic use, or the system experiences frequent conserve mode, consider the following optimization steps:
config ips settings
config ips sensor
config antivirus settings
Adjust IPS process count:
config ips global
    set engine-count 2      <----- Set it to the number of cores the unit has available, or less.
    set cp-accel-mode none
    unset exclude-signatures <----- If the OT database is not needed.
       set database regular
    set av-mem-limit 20
end
Note:
This configuration should be implemented during a maintenance window and carefully monitored during production hours for any performance impact.
Each daemon is bound to a single CPU core. Since the number of daemons/processes is reduced, depending on the volume of traffic or number of requests handled by a single daemon, this can lead to high CPU usage on that core, potentially resulting in dropped connections. It is recommended to monitor network usage, CPU load, and memory consumption, and adjust the configuration accordingly.
For example, if the device is handling around 100-200 Mbps of traffic (as shown in the output of 'get system performance status' under average network usage), allocating more than one WAD worker or IPS engine may be necessary. This should be done while ensuring efficient memory utilization so that the device does not enter conserve mode.
config system autoupdate schedule
    set frequency daily
    set time 03:00
end
config log memory setting
set status disable
end
config log disk filter
    set forward-traffic disable
end
Reducing the cache size is beneficial in environments where memory or performance optimization is a priority, as it ensures the DNS cache remains efficiently managed, preventing excessive resource consumption.
config system dns
    set dns-cache-limit 300 <----- The default value is 5000.
end
Disable the submission of Security Rating results to FortiGuard and scheduled runs of Security Rating:
      
config system global
    set security-rating-result-submission disable
    set security-rating-run-on-schedule disable
end
Reduce internet-service-database: By configuring the setting to 'on-demand', the FortiGate will load the Internet Service Database (ISDB) only when required, instead of keeping it continuously loaded in memory. This approach optimizes system resource usage, particularly in environments where the ISDB is not frequently utilized.
config sys global
    set internet-service-database on-demand
end
execute update-ffdb-on-demand
See the following article for more information on the above setting: Technical Tip: Internet-service-database: On-demand.
Advanced steps to optimize memory use:
If device memory use is low during periods of low traffic but increases significantly with use, it may be desirable to further tune memory consumption.
Note: Care should be taken with the following changes as they affect the overall behavior of the system and are not appropriate for all environments.
config firewall profile-protocol-options
edit <profile>
config <service>
set oversize-limit <maximum size>
end
    next
end
config system fortiguard
    set webfilter-cache-ttl 600     <----- The default value is 3600.
    set antispam-cache-ttl 600      <----- The default value is 1800.
end
config system dns
set dns-cache-ttl 600 <----- The default value is 1800.
end
config system global
    set tcp-halfopen-timer    <----- Enter an integer value from <1> to <86400> (default = <120>).
end
config system session-ttl
set default 900
end
For more granular session-ttl settings based on matched firewall policy or service, see Technical Tip: Session timeout settings.
config system session-ttl
    set default 900
        config port
            edit 1
                set protocol 17
                set timeout 120
            next
        end
end
Reduce logging to only important events (config log setting).
Reduce worker count: 
config system global
    set miglogd-children 1
    set sslvpn-max-worker-count 1
    set wad-worker-count 2
    set scanunit-count 2   <----- scanunit-count value must be in the range of 2-4 or = 0.
end
Refer to the following article for more information: Technical Tip: Reduce memory usage by reducing the number of spawned daemons.
config ips global
set socket-size [integer, 0-512, 0-128] <----- IPS socket buffer size. The maximum and default values depend on available memory. A lower value reduces memory usage at the cost of CPU.
set database [regular|extended] <----- Regular protects against the latest common and in-the-wild attacks. Extended includes protection from legacy attacks.
end
diagnose test application ipsmonitor 99 <----- After changing the engine, database, and socket size, restart the IPSEngine.
Note 1:
If a device is undersized for the required feature-set or traffic volume, memory optimization will have only a very limited benefit. If the steps above do not produce satisfactory results, consider using a higher-capacity FortiGate.
Note 2:
If memory optimization changes are made via CLI, they will need to be made individually on both primary and secondary units in a High-Availability cluster configuration.
Note 3:
In v7.6.3, further optimizations were made which remove or rework certain features on devices with 2GB of memory or less.
For further details, see Optimizations for physical FortiGate devices with 2 GB RAM 7.6.3 - FortiGate 7.6.0 new features.
Related articles:
Technical Tip: Free up memory to avoid conserve mode
Technical Tip: Priority of session-ttl settings in FortiGate
Technical Tip: How to extend the TCP Half-Close timer for specific TCP services
The Fortinet Security Fabric brings together the concepts of convergence and consolidation to provide comprehensive cybersecurity protection for all users, devices, and applications and across all network edges.
Copyright 2025 Fortinet, Inc. All Rights Reserved.