Skip to content

Commit

Permalink
document mirror rules
Browse files Browse the repository at this point in the history
Signed-off-by: Max Englander <[email protected]>
  • Loading branch information
maxenglander committed May 15, 2024
1 parent f155378 commit 10126b9
Show file tree
Hide file tree
Showing 3 changed files with 94 additions and 0 deletions.
70 changes: 70 additions & 0 deletions content/en/docs/20.0/reference/features/schema-mirror-rules.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,70 @@
---
title: Schema Mirror Rules
weight: 15
---

Mirror rules are a feature for testing how a query will perform when executed against a different keyspace. It is intended to reduced the uncertainty involved when migrating application queries from one keyspace to another via `MoveTables`.

## Viewing Mirror Rules

The mirror rules are global and can be viewed using the [`GetMirrorRules` client command](../../programs/vtctldclient/vtctldclient_getmirrorrules/).

## Updating Mirror Rules

Mirror rules are managed by the [`MoveTables MirrorTraffic` client command](../../programs/vtctldclient/vtctldclient_getmirrorrules/). For advanced use cases, you can update the mirror rules using the [`ApplyMirrorRules` client command](../../programs/vtctldclient/vtctldclient_applymirrorrules/).

## Syntax

Mirror rules are managed using the JSON format. Here's an example, showing the mirror rules that would be produced using `MoveTables MirrorTraffic` against the [local examples](../../../get-started/local/), where the queries to `customer` and `corder` tables mirrored from the the `commerce` keyspace to the `customer` keyspace:
```json
$ vtctldclient --server=localhost:15999 GetMirrorRules
{
"rules": [
{
"from_table": "commerce.corder",
"to_table": "customer.corder",
"percent": 1.0
},
{
"from_table": "commerce.corder@replica",
"to_table": "customer.corder",
"percent": 1.0
},
{
"from_table": "commerce.corder@rdonly",
"to_table": "customer.corder",
"percent": 1.0
},
{
"from_table": "commerce.customer",
"to_table": "customer.customer",
"percent": 1.0
},
{
"from_table": "commerce.customer@replica",
"to_table": "customer.customer",
"percent": 1.0
},
{
"from_table": "commerce.customer@rdonly",
"to_table": "customer.customer",
"percent": 1.0
}
]
}
```

## When Mirror Rules Are Applied

Mirror rules are evaluated after routing rules. So, if there are routing rules in place redirecting traffic from `commerce` tables to `customer` tables, then the mirror rules in the example above would not be applied.

## Additional Details

For most cases, you should allow `MoveTables MirrorTraffic` to manage mirror rules. Here are some details to keep in mind if you will be creating and managing your own custom mirror rules:

- `from_table` may optionally specify a `@<tablet-type>`; `to_table` may not.
- `from_table` and `to_table` must both be fully qualified.
- For a given `from_table` value, there can be at most one mirror rule.
- A keyspace that is named in the `from_table` of one rule may not be named in the `to_table` of that rule or any other rule.
- `percent` may be a value between `0` and `100`, inclusive.
- Setting `percent` to `0` removes that mirror rule.
10 changes: 10 additions & 0 deletions content/en/docs/20.0/reference/vreplication/movetables.md
Original file line number Diff line number Diff line change
Expand Up @@ -75,6 +75,16 @@ It is too expensive to get real-time row counts of tables, using _count(*)_, say

</div>

#### MirrorTraffic
<div class="cmd">

[`mirrortraffic`](../../programs/vtctldclient/vtctldclient_movetables/vtctldclient_movetables_mirrortraffic/) mirrors a percentage of traffic forward for the `tablet-types` specified.

`mirrortraffic` must be run before `switchtraffic`. `switchtraffic` will automatically remove any mirror rules that were created by `mirrortraffic`.

</div>


#### SwitchTraffic
<div class="cmd">

Expand Down
14 changes: 14 additions & 0 deletions content/en/docs/20.0/user-guides/migration/move-tables.md
Original file line number Diff line number Diff line change
Expand Up @@ -486,6 +486,20 @@ $ vtctldclient VDiff --format=json --target-keyspace customer --workflow commerc
This can take a long time to complete on very large tables.
{{</ info >}}

## Mirroring Traffic

Optionally, you can test how queries will perform once traffic is switched by mirroring traffic from the source keyspace to the target keyspace. A mirrored query will be routed to the source keyspace (`commerce`), and a copy of that query will be sent to the target keyspace (`customer`). Results and errors from the source keyspace will be returned to the client, while results and errors from the target keyspace wil be ignored.

```bash
$ vtctldclient MoveTables --target-keyspace customer --workflow commerce2customer MirrorTraffic --percent 1.0
SwitchTraffic was successful for workflow customer.commerce2customer

Start State: Reads Not Switched. Writes Not Switched
Current State: All Reads Switched. Writes Switched
```

`MirrorTraffic` increases VTGate CPU usage and memory allocations, while decreasing performance. It is recommended to start with small values of `--percent` (between `0` and `1`), and increase in small increments. If you observe decreases in performance or increases in VTGate memory usage, either revert to smaller values of `--percent` or increase the amount of resources allocated to VTGate.

## Switching Traffic

Once the `MoveTables` operation is complete ([in the "running" or replicating phase](../../../../design-docs/vreplication/life-of-a-stream/)), the first step in making the changes live is to _switch_ all query serving
Expand Down

0 comments on commit 10126b9

Please sign in to comment.