149 lines
		
	
	
		
			3.7 KiB
		
	
	
	
		
			Markdown
		
	
	
	
	
	
			
		
		
	
	
			149 lines
		
	
	
		
			3.7 KiB
		
	
	
	
		
			Markdown
		
	
	
	
	
	
# Hint Syntax
 | 
						|
 | 
						|
## Enabling routing hints
 | 
						|
 | 
						|
To enable user specified routing hints for a service, the hintfilter module
 | 
						|
needs to be configured and the filter needs to be applied to the service.
 | 
						|
 | 
						|
Here is an example service which has the hint filter configured and applied.
 | 
						|
 | 
						|
```
 | 
						|
[Read-Service]
 | 
						|
type=service
 | 
						|
router=readconnroute
 | 
						|
router_options=master
 | 
						|
servers=server1
 | 
						|
user=maxuser
 | 
						|
passwd=maxpwd
 | 
						|
filters=Hint
 | 
						|
 | 
						|
[Hint]
 | 
						|
type=filter
 | 
						|
module=hintfilter
 | 
						|
 | 
						|
```
 | 
						|
 | 
						|
## Comments and comment types
 | 
						|
 | 
						|
The client connection will need to have comments enabled. For example the
 | 
						|
`mysql` command line client has comments disabled by default and they need
 | 
						|
to be enabled by passing the `-c` option.
 | 
						|
 | 
						|
For comment types, use either `-- ` (notice the whitespace after the double
 | 
						|
hyphen) or `#` after the semicolon or `/* .. */` before the semicolon.
 | 
						|
 | 
						|
The MySQL manual doesn't specify if comment blocks, i.e. `/* .. */`, should
 | 
						|
contain a whitespace character before or after the tags, so adding
 | 
						|
whitespace at both the start and the end is advised.
 | 
						|
 | 
						|
## Hint body
 | 
						|
 | 
						|
All hints must start with the `maxscale` tag.
 | 
						|
 | 
						|
```
 | 
						|
-- maxscale <hint body>
 | 
						|
```
 | 
						|
 | 
						|
The hints have two types, ones that define a server type and others that contain
 | 
						|
name-value pairs.
 | 
						|
 | 
						|
### Routing destination hints
 | 
						|
 | 
						|
These hints will instruct the router to route a query to a certain type of a server.
 | 
						|
```
 | 
						|
-- maxscale route to [master | slave | server <server name> | last]
 | 
						|
```
 | 
						|
 | 
						|
A `master` value in a routing hint will route the query to a master
 | 
						|
server. This can be used to direct read queries to a master server for a
 | 
						|
up-to-date result with no replication lag. A `slave` value will route the
 | 
						|
query to a slave server. A `server` value will route the query to a named
 | 
						|
server. The value of <server name> needs to be the same as the server
 | 
						|
section name in maxscale.cnf. A `last` value will route the query to the
 | 
						|
same server the previous query was routed to.
 | 
						|
 | 
						|
### Name-value hints
 | 
						|
 | 
						|
These control the behavior and affect the routing decisions made by the router.
 | 
						|
 | 
						|
```
 | 
						|
-- maxscale <param>=<value>
 | 
						|
```
 | 
						|
 | 
						|
Currently the only accepted parameter is `max_slave_replication_lag`. This
 | 
						|
will route the query to a server with lower replication lag then what is
 | 
						|
defined in the hint value.
 | 
						|
 | 
						|
## Hint stack
 | 
						|
 | 
						|
Hints can be either single-use hints, which makes them affect only one
 | 
						|
query, or named hints, which can be pushed on and off a stack of active
 | 
						|
hints.
 | 
						|
 | 
						|
Defining named hints:
 | 
						|
 | 
						|
```
 | 
						|
-- maxscale <hint name> prepare <hint content>
 | 
						|
```
 | 
						|
 | 
						|
Pushing a hint onto the stack:
 | 
						|
 | 
						|
```
 | 
						|
-- maxscale <hint name> begin
 | 
						|
```
 | 
						|
 | 
						|
Popping the topmost hint off the stack:
 | 
						|
 | 
						|
```
 | 
						|
-- maxscale end
 | 
						|
```
 | 
						|
 | 
						|
You can define and activate a hint in a single command using the following:
 | 
						|
 | 
						|
```
 | 
						|
-- maxscale <hint name> begin <hint content>
 | 
						|
```
 | 
						|
 | 
						|
You can also push anonymous hints onto the stack which are only used as long
 | 
						|
as they are on the stack:
 | 
						|
 | 
						|
```
 | 
						|
-- maxscale begin <hint content>
 | 
						|
```
 | 
						|
 | 
						|
## Examples
 | 
						|
 | 
						|
### Example 1 - Routing SELECT queries to master
 | 
						|
 | 
						|
In this example, MariaDB MaxScale is configured with the readwritesplit
 | 
						|
router and the hint filter.
 | 
						|
 | 
						|
```
 | 
						|
[ReadWriteService]
 | 
						|
type=service
 | 
						|
router=readwritesplit
 | 
						|
servers=server1,server2
 | 
						|
user=maxuser
 | 
						|
passwd=maxpwd
 | 
						|
filters=Hint
 | 
						|
 | 
						|
[Hint]
 | 
						|
type=filter
 | 
						|
module=hintfilter
 | 
						|
```
 | 
						|
 | 
						|
Behind MariaDB MaxScale is a master server and a slave server. If there is
 | 
						|
replication lag between the master and the slave, read queries sent to the
 | 
						|
slave might return old data. To guarantee up-to-date data, we can add a
 | 
						|
routing hint to the query.
 | 
						|
 | 
						|
```
 | 
						|
INSERT INTO table1 VALUES ("John","Doe",1);
 | 
						|
SELECT * from table1; -- maxscale route to master
 | 
						|
```
 | 
						|
 | 
						|
The first INSERT query will be routed to the master. The following SELECT
 | 
						|
query would normally be routed to the slave but with the added routing hint
 | 
						|
it will be routed to the master. This way we can do an INSERT and a SELECT
 | 
						|
right after it and still get up-to-date data.
 |