The mine processes imposes a certain load on the source database when parsing the redo logs (CPU and memory). This maybe around 5% and may not be desirable in certain environments.
This is when the Fetcher process is very useful. It runs on the source database, reading the redo logs and sending them to mine process, which is running on a different machine.
The only operations the fetcher process does are:
- queries the source database for the location of the redo logs.
- repeatedly queries the database to find out when the current log is switched.
- in case of ASM files, connects to ASM instance and reads the logs using internal PL/SQL API.
- in case of filesystem files, reads the files from disk using standard system I/O.
- connects to mine over the network and transfers the redo log files to the mine process.
- listens for user commands.
All of the resource-consuming work of parsing the redo logs, writing the plogs and sending them to apply is done by the mine process.
The fetcher process is optional and is not needed when the mine runs on the primary server. In that case, the database querying and file reading is done directly by mine.