Troubleshooting Fortinet
Troubleshooting Fortnet Firewalls
These are some of the commands I have used to troubleshoot on Fortinet FortiGate (and FortiWifi) firewalls
CLI commands
We’ll start out with some basic CLI command sets
Basics
1
2
3
4
5
6
7
8
get sys status              # Show status summary
get sys perf stat           # Show Fortigate ressources summary
exec shutdown/reboot        # Shutdown the device/reboot
execute ping(-options)      # Ping something (can add options)
execute ssh <user>@<ip>     # SSH to another server
get sys arp                 # Show the arp table
show | grep -f something    #  Find where “something” is used (cases-sensitive, can use -i
to be case insensitive)
Config Management
1
2
3
4
5
6
7
8
9
diag hard deviceinfo disk   # Show disks and partitions usage
diag sys flash list         # Show partitions status
exec factoryreset           # Reset to factory default
exec restore config         # Restore configuration (reboots)
exec backup conf            # Backup configuration
exec formatlogdisk          # Format log disk
get sys ha status           # Display HA conf summary
diag sys ha history read    # Display HA history events
exec ha synchronize all     # Synchronize all parts of the confi
Interface Commands
1
2
3
4
5
6
7
8
9
10
show/get system interface   # Show interfaces status. Use get to retrieve dynamic information
(such as PPPoE IP)
config sys interface        # Basic interface ip configuration
 edit <port>
 set ip x.x.x.x/y
 set allow ssh ping https
end
diag hard dev nic <port>    # Show interfaces statistics
diag netlink device list    # Show interfaces statistics (errors)
VPN Commands
1
2
3
4
5
6
7
8
diag vpn ike gateway list   # Show phase 1
diag vpn tunnel list        # Show phase 2
diag vpn ike gateway flush name <phase1> # Flush phase 1
diag vpn tunnel up <phase2> # Bring up a phase 2
diag debug en               # Troubleshoot VPN issue
diag vpn ike log-filter daddr x.x.x.x
diag debug app ike 1
Routing Commands
1
2
3
4
5
6
7
8
9
10
11
config router static            # Add a static route
 edit 0
 set device internal
 set dst x.x.x.x/y
 set gateway z.z.z.z
end
get ro info ro details x.x.x.x  # Display the route used
diag firewall proute list       # Display the Policy Routes
get router info routingtable all    # Display the current routing table active/configured
diag ip route list              # Display the kernel routing table
Now we can dive a little deeper into more specific troubleshooting and the various debug commands used.
Flow Tracing
One of my favorite things to use is Flow Tracing. It lets you see what happens to the packets as they ingress and/or egress the firewall
1
2
3
4
5
6
diag debug disable
diag debug reset
diag debug flow filter addr 10.2.10.20
diag debug flow trace start 5
diag debug console timestamp enable
diag debug enable
You can modify some of these parameters, but this is a baseline I start with
Packet Capture
1
2
3
diag debug disable
diag debug reset
diag debug packet any 'host <IP>' 4 0
Debug SSLVPN
1
diag debug application sslvpn -1
Debug FortiGate non-blocking AUTH daemon
To debug authentication issues
1
2
3
diag debug disable
diag debug reset
diag debug application fnbamd -1
Log into Secondary firewall, in an HA cluster
During a recent firmware upgrade, I ran into a problem and needed to log into the secondary firewall to kick off the upgrade process. We didn’t have seperate/out-of-band management interfaces, so this is how I did it.
1
2
3
4
5
# On primary FW, the following command lists the firewalls in the cluster
execute ha manage ?
# Then just do this, 0 being the ID of the secondary firewall
execute ha manager 0 admin  <-- Replace with your username
That will log you into the secondary FW and allow you to run commands on it.
Filter IPsec VPN connections
diag vpn ike log-filter
Available options are:
1
2
3
4
5
6
7
8
9
10
11
12
clear erase the current filter
dst-addr4 the IPv4 destination address range to filter by
dst-addr6 the IPv6 destination address range to filter by
dst-port the destination port range to filter by
interface interface that IKE connection is negotiated over
list display the current filter
name the phase1 name to filter by
negate negate the specified filter parameter
src-addr4 the IPv4 source address range to filter by
src-addr6 the IPv6 source address range to filter by
src-port the source port range to filter by
vd index of virtual domain. -1 matches all
For example if you have a VPN tunnel from your firewall to a remote gateway with IP 1.2.3.4 you would use the following commands:
1
2
3
4
5
6
7
diag vpn ike log-filter dst-addr4 1.2.3.4
diag debug enable
diag debug console
diag debug app ike 200
get vpn ike gateway fd-wv-fw03
get vpn ipsec tunnel name fd-wv-fw03
Now only log messages matching a destination address of 1.2.3.4 will be displayed.
1
2
3
4
5
6
7
diag debug reset
diag debug enable
diag debug console timestamp enable
diag debug flow show console enable
diag debug flow filter saddr X.X.X.X
diag debug flow filter daddr X.X.X.X
diag debug flow trace start 200
Also don’t forget to reset your debug level when you are done to conserve system resources:
1
2
diag debug disable
diag debug reset
Find Addresses Objects
Many times it happens that we have a lot of firewall policies for one address defined in our address Pool. Let’s take an example:
We have “WWW_Server” defined with the IP of 172.18.1.10. To see what policies are using this Address we can use the following:
1
diag sys checkused firewall.address:name 'WWW_Server'
What about address group? We can find out where that address group is used by executing the following commands:
1
diag sys checkused firewall.addgrp:name 'Server_Groups'
Useful Links
These are some useful links, which I’ve used in the past to help troubleshoot various FortiGate issues
Troubleshooting HA synchronization issues
Procedure for HA manual synchronization
Fix an HA (High Availability) cluster upgrade failure
-eof-