Search
Varnish Enterprise

Introduction Installation Upgrading Troubleshooting Changelog Changelog for 6.0.x Changes (Varnish Cache 4.1) Changes (Varnish Cache Plus 4.1) Known Issues Features Backend SSL/TLS Client SSL/TLS termination Cluster In-Process TLS MSE 4 Basic Configuration / Getting Started Configuration Persisted caching Categories Configuration Reference MSE 3.0 Settings mkfs.mse Memory Governor MSE 2.0 NUMA Parallel ESI Backend health counter HTTP/2 Support JSON Logging TCP Only Probes Timeouts Transit Buffer Varnish scoreboard VMODs Accept Accounting ACL (aclplus) ActiveDNS Akamai Connector AWS VCL Body Access & Transformation (xbody) Brotli Cookie Plus (cookieplus) DeviceAtlas DeviceAtlas3 Digest Dynamic backends (goto) Edgestash File Format Geolocation (geoip/mmdb) Header Manipulation (headerplus) HTTP communication (http) Image JSON parsing (json) JWT Key value storage (kvstore) Least connections director (leastconn) Module to control the built-in HTTP2 transport (h2) MSE control (mse) MSE4 control (mse4) Probe Proxy ProxyV2 TLV Attribute Extraction (proxy) Pseudo Random Number Generator Purge (purge/softpurge) Real-time Status (rtstatus) Reverse DNS (resolver) Rewrite S3 VMOD Session Slicer SQLite3 Stale Standard (std) Stat (Prometheus) Strings (str) Synthetic backends (synthbackend) Tag-based invalidation (Ykey/Xkey) TCP configuration (tcp) TLS Total Encryption (crypto) Unified director object (udo) Uniform Resource Identifier (uri) Unix Socket Utilities (unix) URL Plus (urlplus) Utils Vsthrottle

Least connections director (leastconn)

Description

The leastconn vmod implements a least connections director for Varnish. The director will direct traffic to the backend with the least number of active connections.

Each backend has an associated weight. A backend with e.g. weight 10 will balance at twice the number of connection as a backend with weight 5.

An optional linear ramp up time can be specified for the director. If set, the weight of each backend is linearly increased in the time frame until it reaches the set weight. This allows for backends that have e.g. recently become healthy again to be eased into the workload. Without a ramp up time, the newly inserted backend would get all the load until it has its share, which can have detrimental effects on some applications.

Only actual backends can be added, ie. it is not stackable. If another director is added as a backend, it will be ignored.

Example

vcl 4.0;
import leastconn;

backend backend1 {
  .host = "192.168.0.10";
  .port = "80";
}

backend backend2 {
  .host = "192.168.0.11";
  .port = "80";
}

sub vcl_init {
  new dir = leastconn.leastconn();
  dir.rampup(1m);
  dir.add_backend(backend1, 3);
  dir.add_backend(backend2, 8);
}

sub vcl_backend_fetch {
  set bereq.backend = dir.backend();
}

API

leastconn

OBJECT leastconn()

Creates a new leastconn director and returns the object.

Arguments: None

Type: Object

Returns: Object.

.add_backend

VOID .add_backend(BACKEND, REAL)

Add a backend to the director. First argument is the backend to add, the second is its associated weight.

Arguments: None

Type: Method

Returns: None

.backend

BACKEND .backend()

Returns a backend to use for the fetch processing.

Arguments: None

Type: Method

Returns: Backend

.rampup

VOID .rampup(DURATION)

Sets the ramp up duration to use whenever a backend changes its status to healthy. The default is zero rampup.

Arguments: None

Type: Method

Returns: None

Availability

The leastconn VMOD is available in Varnish Enterprise version 6.0.0r0 and later.


®Varnish Software, Wallingatan 12, 111 60 Stockholm, Organization nr. 556805-6203