hive-issues mailing list archives

Site index · List index
Message view « Date » · « Thread »
Top « Date » · « Thread »
From "ASF GitHub Bot (JIRA)" <j...@apache.org>
Subject [jira] [Work logged] (HIVE-21764) REPL DUMP should detect and bootstrap any rename table events where old table was excluded but renamed table is included.
Date Fri, 21 Jun 2019 12:24:01 GMT

     [ https://issues.apache.org/jira/browse/HIVE-21764?focusedWorklogId=264574&page=com.atlassian.jira.plugin.system.issuetabpanels:worklog-tabpanel#worklog-264574
]

ASF GitHub Bot logged work on HIVE-21764:
-----------------------------------------

                Author: ASF GitHub Bot
            Created on: 21/Jun/19 12:23
            Start Date: 21/Jun/19 12:23
    Worklog Time Spent: 10m 
      Work Description: sankarh commented on pull request #679: HIVE-21764 : REPL DUMP should
detect and bootstrap any rename table events where old table was excluded but renamed table
is included.
URL: https://github.com/apache/hive/pull/679#discussion_r296203142
 
 

 ##########
 File path: standalone-metastore/metastore-server/src/main/java/org/apache/hadoop/hive/metastore/messaging/event/filters/ReplEventFilter.java
 ##########
 @@ -30,12 +31,22 @@ public ReplEventFilter(final ReplScope replScope) {
     this.replScope = replScope;
   }
 
+  // Return false if all the tables are included, as bootstrap during rename is done only
in case filter set for tables.
+  boolean isAlterDuringTableLevelReplication(final NotificationEvent event) {
+    if (replScope.includeAllTables() || !replScope.getDbNamePattern().matcher(event.getDbName()).matches())
{
 
 Review comment:
   Instead of exposing dbNamePattern outside ReplScope, can we add a method that checks if
Db matches the replScope. That seems cleaner.
 
----------------------------------------------------------------
This is an automated message from the Apache Git Service.
To respond to the message, please log on to GitHub and use the
URL above to go to the specific comment.
 
For queries about this service, please contact Infrastructure at:
users@infra.apache.org


Issue Time Tracking
-------------------

    Worklog Id:     (was: 264574)
    Time Spent: 4h 20m  (was: 4h 10m)

> REPL DUMP should detect and bootstrap any rename table events where old table was excluded
but renamed table is included.
> -------------------------------------------------------------------------------------------------------------------------
>
>                 Key: HIVE-21764
>                 URL: https://issues.apache.org/jira/browse/HIVE-21764
>             Project: Hive
>          Issue Type: Sub-task
>          Components: repl
>            Reporter: Sankar Hariappan
>            Assignee: mahesh kumar behera
>            Priority: Major
>              Labels: DR, Replication, pull-request-available
>         Attachments: HIVE-21764.01.patch, HIVE-21764.02.patch
>
>          Time Spent: 4h 20m
>  Remaining Estimate: 0h
>
> REPL DUMP fetches the events from NOTIFICATION_LOG table based on regular expression
+ inclusion/exclusion list. So, in case of rename table event, the event will be ignored if
old table doesn't match the pattern but the new table should be bootstrapped. REPL DUMP should
have a mechanism to detect such tables and automatically bootstrap with incremental replication.Also,
if renamed table is excluded from replication policy, then need to drop the old table at target
as well. 
> There are 4 scenarios that needs to be handled.
>  # Both new name and old name satisfies the table name pattern filter.
>  ## No need to do anything. The incremental event for rename should take care of the
replication.
>  # Both the names does not satisfy the table name pattern filter.
>  ## Both the names are not in the scope of the policy and thus nothing needs to be done.
>  # New name satisfies the pattern but the old name does not.
>  ## The table will not be present at the target.
>  ## Rename event handler for dump should detect this case and add the new table name
to the list of table for bootstrap.
>  ## All the events related to the table (new name) should be ignored.
>  ## If there is a drop event for the table (with new name), then remove the table from
the list of tables to be bootstrapped.
>  ## In case of rename (double rename)
>  ### If the new name satisfies the table pattern, then add the new name to the list of
tables to be bootstrapped and remove the old name from the list of tables to be bootstrapped.
>  ### If the new name does not satisfies then just removed the table name from the list
of tables to be bootstrapped.
>  # New name does not satisfies the pattern but the old name satisfies.
>  ## Change the rename event to a drop event.



--
This message was sent by Atlassian JIRA
(v7.6.3#76005)

Mime
View raw message