Forwarding Policy
Scenarios
You can add forwarding policies to HTTP or HTTPS listeners to forward requests to different backend server groups based on domain names or URLs.
This is suited for applications that are deployed on multiple backend servers and provide multiple types of services such as videos, images, audios, and texts.
A forwarding policy consists of a forwarding rule and an action.
- There are two types of forwarding rules: domain name and URL.
- The only supported action is to forward requests to another backend server group.
Constraints and Limitations
- Forwarding policies can be added only to HTTP and HTTPS listeners.
- When you add a forwarding policy, note the following:
- Each URL path must exist on the backend servers. Otherwise, the backend servers return 404 to the load balancer.
- A URL path cannot be configured for two forwarding policies.
- In regular expression match, the characters are matched sequentially, and matching ends when any rule is successfully matched. Matching rules cannot overlap with each other.
- After you add a forwarding policy, the load balancer forwards requests based on the specified domain name or URL:
- If the domain name or URL in a request matches that specified in the forwarding policy, the request is forwarded to the backend server group you select when you add the forwarding policy.
- If the domain name or URL in a request does not match that specified in the forwarding policy, the request is forwarded to the default backend server group of the listener.
If you add a forwarding policy that is the same as an existing forwarding policy, there will be a conflict. Even if you delete the existing forwarding policy, the newly-added forwarding policy is still in the Faulty state. Delete both the forwarding policies and add two different forwarding policies.
Adding a Forwarding Policy
- Log in to the management console.
- In the upper left corner of the page, click
and select the desired region and project. - Hover on
in the upper left corner to display Service List and choose Network > Elastic Load Balancing. - Locate the load balancer and click its name.
- Click Listeners, locate the listener, and click its name.
- Click Add on the right of Forwarding Policies.
- In the Add Forwarding Policy dialog box, configure the parameters based on Table 1.
- Click OK.
Alternatively, locate the load balancer in the load balancer list and click the name of the listener in the Listener column. In the Listeners area, click Add on the right of Forwarding Policies and then add a forwarding policy.
Table 1 Forwarding policy parametersItem
|
Parameter
|
Description
|
Example Value
|
Configure Forwarding Policy
|
Name
|
Specifies the forwarding policy name.
|
forwarding_policy-q582
|
Domain Name
|
Specifies the domain name used for forwarding requests. The domain name in the request must exactly match that in the forwarding policy. You need to specify either a domain name or URL.
|
www.test.com
|
URL Matching Rule
|
|
Exact match
|
URL
|
Specifies the URL used for forwarding requests.
|
/login.php
|
Description
|
Provides supplementary information about the forwarding policy.
|
N/A
|
Add Backend Server Group
|
Backend Server Group
|
Specifies whether a new or existing backend server group will be used. Select Create new or Use existing.
If you select Create new, configure the parameters based on Table 1 and Table 2.
NOTE: The backend protocol can only be HTTP.
|
Create new
|
URL Matching Example
The following table lists how a URL is matched, and Figure 1 shows how a request is forwarded to a backend server group.
Table 2 URL matchingURL Matching Rule
|
URL
|
URL in the Forwarding Policy
|
-
|
-
|
/elb/index.html
|
/elb
|
/elb[^\s]*
|
/index.html
|
Exact match
|
/elb/index.html
|
√
|
-
|
-
|
-
|
Prefix match
|
√
|
√
|
-
|
-
|
Regular expression match
|
√
|
-
|
√
|
-
|
Figure 1 Request forwarding
In this figure, the system first searches for an exact match of the requested URL (/elb_gls/glossary.html). If there is no exact match, the system searches for a prefix match. If a match is found, the request is forwarded to backend server group 2 even if a regular expression match is also found, because the prefix match has a higher priority.
Modifying a Forwarding Policy
- Log in to the management console.
- In the upper left corner of the page, click
and select the desired region and project. - Hover on
in the upper left corner to display Service List and choose Network > Elastic Load Balancing. - Locate the load balancer and click its name.
- Click Listeners, locate the listener, and click its name.
- Click Forwarding Policies.
- Locate the forwarding policy and click
on the right of its name. - In the Modify Forwarding Policy dialog box, modify the parameters and click OK.
Deleting a Forwarding Policy
- Log in to the management console.
- In the upper left corner of the page, click
and select the desired region and project. - Hover on
in the upper left corner to display Service List and choose Network > Elastic Load Balancing. - Locate the load balancer and click its name.
- Click Listeners, locate the listener, and click its name.
- Click Forwarding Policies.
- Locate the forwarding policy and click
on the right of its name. - Click Yes.
Parent topic: Advanced Features of HTTP/HTTPS Listeners