This guide will explain the origin groups feature and show you how to configure and add an origin group to your CDN resource.
Origin groups is a feature that allows you to specify sources for a CDN resource. One origin group can consist of a single site/private bucket or of multiple sites.
Specifying several sites increases fault tolerance. If one origin fails, another can function as a backup. You can specify a group and set the logic of interaction between origins.
For example, if you make both origins in the group active, requests between them will be distributed 50:50. If you make one source the backup, then that source will respond only when the primary source gives an error 5xx.
You can do this in two ways: in the CDN resource settings or in the "origin groups" section.
Open the settings of the desired CDN resource.
Find the "Origin pull protocol" option in the Origin section, and click Add group.
Continue to Step 2.
Note: The created origin group won’t automatically bind to the CDN resource. Follow the instructions untill the end.
Open the "Origin groups" section and click Add origin group.
Note: The created origin group will appear in the general list of origin groups. It won’t automatically bind to the CDN resource.
A pop-up window for group configuration and adding will appear. Perform steps 2–5, regardless of the option chosen above.
Enter the origin group name into the field. After step 5, the origin group that was created will appear in the list of origins groups and the CDN resource settings.
There are two types of origin authentication: None and AWS signature V4. Choose None if your origin from where CDN servers will request content is public, i.e., available to all users on the internet. Choose AWS signature V4 if you want to use a private S3 bucket as an origin.
1. In the "Origin source" field, enter the origin IP or its domain name without "http" or "https://". The CDN will pull content from this source.
2. (Optional) If your source uses ports other than 80 or 443, disable the Use default port toggle and enter the port on the right.
3. (Optional) If you want to use several sources of content, click +Add origin and enter the value. The CDN will determine the origin IPs as separate sources and distribute requests to them according to the round robin algorithm. In other words, the first request will go to the first source, the second request will go to the second source, and so on.
When you have more than one origin in a group, you can adjust the balance between them. To do so:
Enable/disable origin. By default, the slider next to each origin is in the On position. ‘On’ means that the CDN can pull content from this origin; it has been added to the balance. If you want to disable the content origin in the group, move the slider to Off. You’ll only disable the origin in the current group, but it will continue to work in other groups. CDN requests will stop coming to the disabled origin within fifteen minutes.
Note: You can’t disable the last active origin.
Active/backup origin. All new origins are automatically assigned an "Active" status. The CDN pulls content from such origins. The balancing between them is determined by the round-robin algorithm. You can turn the active origin into the backup origin by selecting the "Use origin as a backup" option. Backup origins are taken out of balance by default. The CDN requests content from them only if the active origin gives a 5xx response code.
Use next upstream. This option only works if each origin contains the same content. When enabled, the CDN will call the following origins on the list if the previous one is unavailable and responds with any 4xx or 5xx series response code, except 400. Code 400 is an exception. In this case, the CDN won’t redirect requests to another source. If all origins are unavailable, the CDN will show the response of the last one in the list.
At first glance, the interaction between the active/backup origins and the "Use next upstream" option may seem complicated, so to make it easier to understand, let’s look at examples of how it works.
|Case||How the CDN requests content|
|The "Use next upstream" option is disabled; all origins are active.||If the active origin responds with an error, the CDN will hand it off to the end user.|
|The "Use next upstream" option is enabled. One origin is active, and the rest are backups.||If the active origin responds with 4xx and 5xx response codes, the CDN will start requesting content from the other origins, moving down the list.|
|The "Use next upstream" option is enabled. All origins are active.||If the first active origin responds with 404, 500, 502, 503, or 504 response codes, the CDN will start requesting content from the other origins, moving down the list.|
|The "Use next upstream" option is disabled. One origin is active, and the rest are backups.||If the active origin doesn’t respond within 5 seconds or responds with a 5xx response code, the CDN will request content from the backup origin. If the active origin responds with a 4xx response code, the CDN won’t request the backup origin and will send an error message to the user.|
Read about this type of origin in our article about using a private bucket as an origin.
1. Select the type of S3 storage: Amazon or Other.
2. Specify the required authentication data. It depends on the type of storage selected in the previous step.
3. Enter the Bucket name.
Note: If you selected Amazon S3 storage in step #1, go to the next step. If you selected Other, go to the resource settings and open the Host header option in the "HTTP headers" section. Specify the URL of your storage Hostname (the URL depends on your S3 provider) in the following format:
Don’t forget to save the changes.
Click Add group to save changes.
To bind a created group to the CDN resource, open the required CDN resource settings, and go to the Origin section. Then, click the ᐯ symbol, and select the created group from the drop-down list. Next, click Save changes.
No. If you switch the CDN resource from one origins group to another, the Host header won’t automatically change. You’ll have to do it manually.
Was this article helpful?
Learn more about our next-gen CDN