Team where I'm working has a luck to work on redesigning huge legacy system, with Oracle 12 on database end. Currently this monster software has 10% of insert/update/delete operations in DB, rest 90% of operations are the select operations (searching some for entities in a million records tables). And the search of course became slow. So our first thoughts of course is to have 2 same sets of data: Oracle DB and Elastic Search DB to perform search in Elastic, but store data in Oracle and right away to replicate data to Elastic. Between Oracle and Elastic will be some logic written on C# to convert data to Elastic Stack Format But first question we are don't have answer - how to get the changed data from Oracle as soon as it changed? First approach we found - to use Continuous Query Notification But this can be used only to initiate the data transfer process. The notification can contain the RowID of changed row, but it looks like the number of changed row notification event can carry limited to 80. Second approach - Use some Open source "Data Replicator", which monitors "Transaction logs". The only replicator I found - OpenLogReplicator, I like It but I want to ask StackOverflowers, may be this will not work for my case? Please note that Oracle GoldenGate we can not use, the client would not accept this. Can someone suggest which technology to use to replicate data changes from Oracle?
Continuously replicate data from Oracle to ElasticSearch
1.2k Views Asked by Viktor Fursov At
2
There are 2 best solutions below
Related Questions in .NET
- Does compiler optimize operation on const variable and literal const number?
- What is the point of definnig Asp.net Intrinsic Objects In different places and what is the different betwen them?
- Deleting Orphans with Fluent NHibernate
- IOrderedEnumerable to vb.net IOrderedEnumerable Conversion
- What is this namespace ITypeOfObjectsBoundToListBox ? Couldn't find it
- .net rest service with JSON string and consumed with java client
- What is best way to check if any of the property of object is null or empty?
- Telerik's WPF RadColorPicker NoColorText property not working
- Possible consequences of duplicate ProgId for different classes
- How are multiple requests to Task.Run handled from a resource management standpoint?
- Optimizing C++ call from C#
- Make a per-web-application object available to Web API and SignalR controllers
- System.ComponentModel.DataAnnotations.Schema namespace conflict
- LINQ Except/Distinct based on few columns only, to not add duplicates
- Not displaying content by its URL string - absolute urls
Related Questions in ORACLE
- Column displays each count
- MAX and GROUP BY - SQL
- Best Practice for adding columns to a Table in Oracle database
- Updating an Oracle row with value from same row
- Retrieving data from Oracle database
- Ibatis execute update sql on oracle, it is not working and no exceptions
- Building an sql execution plan history
- Implementation of Rank and Dense Rank in MySQL
- how to update the date field for this specific condition using oracle query?
- Oracle stored procedure wrapping compile error with inline comments
- Android: How to connect oracle database using Android Java code?
- SQL Conditional Join on Columns
- Multi value wildcard search in ibatis
- Get count of consecutive days meeting a given criteria
- How to update the metadata of a layer in Oracle imported through FME Workbench?
Related Questions in ELASTICSEARCH
- Elasticsearch schema for multiple versions of the same text
- Elasticsearch nested filter query
- Elasticsearch data model
- search with filter by token count
- Usage of - operator in elasticsearch
- Running multiprocessing on two different functions in Python 2.7
- How to get an Elasticsearch aggregation with multiple fields
- How to implement custom sort in elasticsearch?
- Custom Analyzer not working Elasticsearch
- How to implement full text search using Elasticsearch in Rails?
- UnresolvedAddressException in Logstash+elasticsearch
- Elasticsearch Fiddler No DNS
- Monolithic ETL to distributed/scalable solution and OLAP cube to Elasticsearch/Solr
- how to disable page query in Spring-data-elasticsearch
- Create Custom Analyzer after index has been created
Related Questions in DATA-INTEGRATION
- Workday: Submit_Customer_Invoice returning an error - The task submitted is not authorized
- Installing Silk Workbench on windows 10?
- How to integrate tabular data into GraphDB automatically?
- Format was not found error when running an imported EG on DI
- SAS DI Error 22-232 in ROW_NUMBER () OVER (PARTITION BY construction
- Data retrieval and search accross multiple services
- Unable to load the source file details into mysql database using TALEND tool
- Getting result from SQL Server Stored Procedure
- How can I integrate data on regular bases between 2 different MySQL Servers?
- How to configure Apache Flume to fetch data from Twitter for specific period?
- Extraction of data from Siebel Data base to Dat file and staging table
- Data loading is slow while using "Insert/Update" step in pentaho
- Can not override Talend job context parameters when launching from the command-line
- What is the best object mapper for merging DTOs from many sources?
- Unable to complete Oracle example for ODI Flat File to Flat File Export
Related Questions in DATA-REPLICATOR
- Transferring data between two PostgreSQL servers
- How does pglogical-2 handle logical replication on same table while allowing it to be writeable on both databases?
- Microservices Replication: What about the Database?
- Automatically set logical view on Data Replicator table on Exact Online
- Continuously replicate data from Oracle to ElasticSearch
Trending Questions
- UIImageView Frame Doesn't Reflect Constraints
- Is it possible to use adb commands to click on a view by finding its ID?
- How to create a new web character symbol recognizable by html/javascript?
- Why isn't my CSS3 animation smooth in Google Chrome (but very smooth on other browsers)?
- Heap Gives Page Fault
- Connect ffmpeg to Visual Studio 2008
- Both Object- and ValueAnimator jumps when Duration is set above API LvL 24
- How to avoid default initialization of objects in std::vector?
- second argument of the command line arguments in a format other than char** argv or char* argv[]
- How to improve efficiency of algorithm which generates next lexicographic permutation?
- Navigating to the another actvity app getting crash in android
- How to read the particular message format in android and store in sqlite database?
- Resetting inventory status after order is cancelled
- Efficiently compute powers of X in SSE/AVX
- Insert into an external database using ajax and php : POST 500 (Internal Server Error)
Popular Questions
- How do I undo the most recent local commits in Git?
- How can I remove a specific item from an array in JavaScript?
- How do I delete a Git branch locally and remotely?
- Find all files containing a specific text (string) on Linux?
- How do I revert a Git repository to a previous commit?
- How do I create an HTML button that acts like a link?
- How do I check out a remote Git branch?
- How do I force "git pull" to overwrite local files?
- How do I list all files of a directory?
- How to check whether a string contains a substring in JavaScript?
- How do I redirect to another webpage?
- How can I iterate over rows in a Pandas DataFrame?
- How do I convert a String to an int in Java?
- Does Python have a string 'contains' substring method?
- How do I check if a string contains a specific word?
SharePlex is a cheaper alternative to GoldenGate. Since your need is "immediate" replication you need a relatively sophisticated solution that both SharePlex and GoldenGate should be able to handle.