Indirect routes

A route with intermediate sites is called an indirect route.

For example, in Figure 6-2, NY_RS το SAC_RS is an indirect route, based on the direct routes NY_RS το SF_RS and SF_RS το SAC_RS. In an indirect route, the source Replication Server sends messages for the destination Replication Server to an intermediate Replication Server, which makes use of a route (direct or indirect) to the destination Replication Server.

To create an indirect route, you create direct routes between each successive Replication Server along the intended indirect route. Once all the direct routes are in place, then you create the indirect route itself. See “Creating routes” for details.

For example, to create the indirect route NY_RS το SAC_RS, first create the direct routes NY_RS το SF_RS and SF_RS το SAC_RS. Then create the indirect route based on the existing direct routes.

Figure 6-2: Sites connected with indirect routes in a hierarchical configuration

Figure 6-2 illustrates sites connected with indirect routes in a hierarchical configuration. N Y underscore R S to S A C underscore R S is an indirect route, based on the direct routes N Y underscore R S to S F underscore R S and S F underscore R S to S A C underscore R S. In an indirect route, the source Replication Server sends messages for the destination Replication Server to an intermediate Replication Server, which makes use of a route, direct or indirect, to the destination Replication Server.

By setting up indirect routes, you reduce the amount of processing at the primary site and distribute the load among intermediate Replication Servers.

Table 6-1: Direct and indirect routes between sites in Figure 5-2

Direct routes

Indirect routes

NY_RS το SF_RS

NY_RS το SAC_RS

NY_RS το LA_RS

NY_RS το SJ_RS

SF_RS το SAC_RS

NY_RS το SD_RS

SF_RS το SJ_RS

NY_RS το SB_RS

LA_RS το SD_RS

LA_RS το SB_RS

When you use indirect routes, the primary Replication Server can route portions of subscriptions that are common to destination sites through the same intermediate site. When subscriptions overlap, the primary Replication Server is required to send only one message per row modification to the intermediate Replication Server that is common to the destination sites.

For example, in Figure 6-3, the intermediate Replication Server in LON_RS receives row modification changes for customer accounts whenever changes occur at the bank headquarters in New York. The New York modifications are also required at branch bank replicate sites in Zurich and Bonn. Because LON_RS is set up to distribute changes to ZUR_RS and BON_RS, the NY_RS primary Replication Server sends only one copy of each change to LON_RS. The number of direct routes is also reduced through the use of the two indirect routes, NY_RS το ZUR_RS and NY_RS το BON_RS.

Figure 6-3: Sites with overlapping subscriptions

Figure 6-3 shows sites with overlapping subscriptions. The intermediate Replication Server in L O N underscore R S receives row modification changes for customer accounts whenever changes occur at the bank headquarters in New York. The New York modifications are also required at branch bank replicate sites in Zurich and Bonn. The N Y underscore R S primary Replication Server sends only one copy of each change to L O N underscore R S because L O N underscore R S is set up to distribute changes to Z U R underscore R S and B O N underscore R S. The number of direct routes is also reduced through the use of the two indirect routes, N Y underscore R S to Z U R underscore R S and N Y underscore R S to B O N underscore R S.

Although indirect routes are helpful for distributing computing resources among sites on the network, overall propagation of data is slowed somewhat because messages are queued by more than one Replication Server. It is better to use direct routes when there are few replicate sites. When using indirect routes, minimize the number of intermediate sites to obtain the best propagation times.