HAProxy load balancer discovery with patterns
Summarize
Summary of HAProxy load balancer discovery with patterns
The Discovery and Service Mapping Patterns application in ServiceNow uses the HAProxy pattern to detect HAProxy Community load balancers operating on Linux servers. This open-source load balancer supports HTTP and TCP modes, but ServiceNow Discovery only supports HTTP load balancing detection. As of version 1.15.0, pattern-based discovery is the default method for identifying HAProxy load balancers.
Show less
Note that the discovery process maps one-to-one relationships between front-end and back-end ports, linking only the lowest front-end port number within a defined range to a back-end port. For environments requiring TCP load balancing discovery, separate probe-based methods exist.
Prerequisites
- Ensure the Discovery and Service Mapping Patterns and Visibility Content applications are updated to the latest versions.
- Verify that HAProxy software is installed and running on a Linux server.
- Confirm permission to execute the HAProxy version command (
haproxy -v). - Have read access to the HAProxy configuration file (
haproxy.cfg). - Create and configure SSH credentials to enable Discovery to access the server.
- Schedule a horizontal discovery scan to initiate data collection.
Data Collected and CMDB Integration
During discovery, the HAProxy pattern populates the ServiceNow Configuration Management Database (CMDB) with detailed information about the load balancer and its components, organized into related tables:
- HAProxy Load Balancer [cmdbcilbhaproxy]: Captures the load balancer's name, version, and description.
- Load Balancer Service [cmdbcilbservice]: Records the name (format: <LB name>:<LB port>), listening port, IP address, highest port number in use, and references the HAProxy load balancer.
- Load Balancer Pool [cmdbcilbpool]: Contains pool name, associated load balancer, load balancing method (e.g., Round Robin), last discovery timestamp, and installation status.
- Load Balancer Pool Member [cmdbcilbpoolmember]: Details pool member name, service port, IP address, and references to both the pool and load balancer.
CI Relationships
The discovery establishes key relationships among configuration items (CIs) to accurately represent the HAProxy load balancer environment:
- Load Balancer Pool is allocated to Load Balancer Service.
- Load Balancer Pool owns Load Balancer Pool Members.
- Load Balancer Pool and Pool Members reference the HAProxy Load Balancer.
- Load Balancer Services reference the HAProxy Load Balancer and run on specific hardware.
Practical Benefits for ServiceNow Customers
By leveraging this pattern-based discovery, customers can efficiently identify and map HAProxy load balancers and their components in their IT environments. This ensures accurate CMDB data, supports impact analysis, and enhances service visibility for HAProxy-based load balancing infrastructure. Keeping prerequisites met and applications updated enables smooth discovery and accurate relationship mapping.
The Discovery and Service Mapping Patterns application uses the HA Proxy pattern to find HAProxy Community load balancers running on a Linux server. Discovering some of these resources may require updating to the latest version of the Discovery and Service Mapping Patterns application from the ServiceNow Store.
HAProxy Community edition is an open-source load balancer that can run in either TCP or HTTP mode. Note that although Discovery supports HAProxy for HTTP load balancing, TCP load balancing isn’t supported.
Starting with Discovery and Service Mapping Patterns 1.15.0 version, pattern-based discovery is the default method for discovering HAProxy load balancers. For information on probe-based HAProxy discovery, see HAProxy load balancer discovery using probes.
Request apps on the Store
Visit the ServiceNow Store website to view all the available apps and for information about submitting requests to the store. For cumulative release notes information for all released apps, see the ServiceNow Store version history release notes.
To learn about HAProxy load balancers and their versions that you can discover, refer to Detailed information on products discovered by ITOM Visibility.
Prerequisites
- Verify that the applications are up to date
-
- Discovery and Service Mapping Patterns
- Visibility Content
- Verify HAProxy is installed on the Linux server
- Verify the HAProxy software is installed and running on a Linux server.
- Verify permission to run HAProxy command
- Verify you have permission to run the following command: <HAproxy Installation Path>/haproxy -v.
- Verify read access to HAProxy configuration file
- Verify you have read access to the haproxy.cfg file.
- Create SSH credentials
- For more information, see SSH credentials.
- Schedule a horizontal discovery
- For more information, see Schedule a horizontal discovery.
Data collected by Discovery during horizontal discovery
Discovery populates the data in the CMDB when running the HA Proxy Pattern.
| Field | Description |
|---|---|
| Name [name] | Name of the HAProxy load balancer. |
| Version [version] | Version of the HAProxy load balancer. |
| Description [short_description] | Description of the HAProxy process, which is obtained by running the command: haproxy -version. |
| Field | Description |
|---|---|
| Name [name] | Name of the load balancer in the following format: <LB name>:<LB port>. |
| Port [port] | Port on which the load balancer is listening. |
| IP Address [ip_address] | IP address of the load balancer service. |
| Last port [last_port] | Highest port number used by the load balancer service. |
| Load balancer [load_balancer] | References the HAProxy Load Balancer [cmdb_ci_lb_haproxy] table. |
| Field | Description |
|---|---|
| Name [name] | Name of the load balancer pool. |
| Load balancer [load_balancer] | References the HAProxy Load Balancer [cmdb_ci_lb_haproxy] table. |
| Load balancing method [load_balancing_method] | Method used to load balance the pool, for example: Round Robin. |
| Most recent discovery [last_discovered] | Timestamp of the most recent discovery. |
| Install Status [install_status] | Install status of the load balancer pool, for example: Installed. |
| Field | Description |
|---|---|
| Name [name] | Name of the load balancer pool member. |
| Service port [service_port] | Port used by the pool member. |
| IP Address [ip_address] | IP address of the pool member host. |
| Pool [pool] | References the Load Balancer Pool [cmdb_ci_lb_pool] table. |
| Load balancer [load_balancer] | References the HAProxy Load Balancer [cmdb_ci_lb_haproxy] table. |
CI relationships
Discovery creates these relationships to support the HAProxy load balancer discovery.
| CI | Relationship | CI |
|---|---|---|
| Load Balancer Pool [cmdb_ci_lb_pool] | Allocated to::Allocated from | Load Balancer Service [cmdb_ci_lb_service] |
| Load Balancer Pool [cmdb_ci_lb_pool] | Owns::Owned by | Load Balancer Pool Member [cmdb_ci_lb_pool_member] |
| Load Balancer Pool [cmdb_ci_lb_pool] | References | HAProxy Load Balancer [cmdb_ci_lb_haproxy] |
| Load Balancer Pool [cmdb_ci_lb_pool] | References | Load Balancer Pool Member [cmdb_ci_lb_pool_member] |
| Load Balancer Pool Member [cmdb_ci_lb_pool_member] | References | HAProxy Load Balancer [cmdb_ci_lb_haproxy] |
| Load Balancer Service [cmdb_ci_lb_service] | References | HAProxy Load Balancer [cmdb_ci_lb_haproxy] |
| Load Balancer Service [cmdb_ci_lb_service] | Runs on::Runs | Hardware [cmdb_ci_hardware] |