How to Activate NetFlow Support in ESX Server 3.5
Enter the commands needed to activate NetFlow using the service console on the ESX Server host. You can enter the commands over an SSH connection or directly at the ESX Server host.
Take the following steps to activate NetFlow:
1 Prepare ESX Server for NetFlow configuration.
Make sure the VMkernel TCP/IP stack is properly configured and that a VMkernel virtual interface
(vmknic) exists on the network where your collector is located.
The ESX Server implementation of NetFlow uses the ESX Server TCP/IP stack to send NetFlow packets on the network.
2 Load the NetFlow module.
Enter the following command:
vmkload_mod netflow
You see the following response from the system:
Using /usr/lib/vmware/vmkmod/netflow
Module load of netflow succeeded.
3 Confirm that the NetFlow module is loaded.
Enter the following command:
vmkload_mod -l | grep netflow
You see a response from the system similar to the following:
netflow 0xc2e000 0x6000 0x2bf53a0 0x1000 16 Yes
4 Configure NetFlow
Use the application called net-netflow for the remaining configuration steps. The application is located in /usr/lib/vmware/bin/ and takes multiple parameters, as shown in the following example:
net-netflow -e <vswitchname> <collectorhostname:port>
The minimum parameters required include:
- Names of the virtual switches where NetFlow will be activated
- Host IP address and port number of the NetFlow collector/analyzer
NetFlow export is supported on ESX Sever 3.5 only as an experimental feature. Additionally, ESX Sever 3.5 exports flows in the NetFlow Version 5 format, with the following information missing (the corresponding fields have a value of zero):
- IP address of next hop router (“nexthop” in the specification)
- Autonomous system number of the source, either origin or peer (“src_as” in the specification)
- Autonomous system number of the destination, either origin or peer (“dst_as” in the specification)
- Source address prefix mask bits (“src_mask” in the specification)
- Destination address prefix mask bits (“dst_mask” in the specification)
The idle timeout and active timeout are respectively statically set to 15 seconds and 5 minutes. Currently these values are not changeable.
There is no way to dynamically change the set of virtual switches where NetFlow is enabled. To make a change, you must kill the previous net-netflow process and launch a new one.
There is no sampling mode available on this version of ESX Server.
This implementation should not be used to do strict traffic accounting. Although the implementation is generally quite accurate, memory pressure conditions and network congestion may result in dropped flows, without any way to retrieve them.
In order to enable and configure NetFlow, you must use the service console directly. With ESX Server 3.5, there is no support for configuring or managing NetFlow using VirtualCenter or the remote command line interface. This means NetFlow is not supported in ESX Server 3i environments.
Cautions on Using NetFlow in ESX Server 3.5
- Do not launch more than one instance of net-netflow.
- Do not launch two net-netflow instances at the same time. Although in theory this should be safe, the configuration has not been tested. It may lead to unexpected behavior.
- Do not delete a virtual switch that has NetFlow activated.
- Deleting a virtual switch with NetFlow activated may cause ESX Server to become unstable.