[ 
https://issues.apache.org/jira/browse/IMPALA-15051?page=com.atlassian.jira.plugin.system.issuetabpanels:all-tabpanel
 ]

Venugopal Reddy K reassigned IMPALA-15051:
------------------------------------------

    Assignee: Venugopal Reddy K

> INVALIDATE METADATA fails with java.lang.IllegalStateException in 
> TableEventExecutor.clear with case-sensitive rename
> ---------------------------------------------------------------------------------------------------------------------
>
>                 Key: IMPALA-15051
>                 URL: https://issues.apache.org/jira/browse/IMPALA-15051
>             Project: IMPALA
>          Issue Type: Bug
>          Components: Catalog
>            Reporter: Venugopal Reddy K
>            Assignee: Venugopal Reddy K
>            Priority: Major
>
>  
> *[Description]*
> The Impala Catalog service crashes during an Invalidate metadata command due 
> to the use of case-sensitive db name in rename table operation. It is treated 
> as a new instance even though the mapping of the table name to 
> TableEventExecutor already exists. Upon running invalidate metadata, since 
> the mapping to the old instance still exists, TableEventExecutor.clear() 
> triggers a Google Guava state check failure 
> ({{{}Preconditions.checkState{}}}). This occurs after a table is renamed to a 
> case-variant database name (e.g., changing from lowercase to uppercase or 
> vice versa).
> Exception is thrown at:
> [https://github.com/apache/impala/blob/master/fe/src/main/java/org/apache/impala/catalog/events/TableEventExecutor.java#L440]
> *[Reproduction steps]*
> Execute the python test sequence below:
> {code:java}
>   @CustomClusterTestSuite.with_args(
>     catalogd_args="--hms_event_polling_interval_s=0.2"
>                   " --enable_hierarchical_event_processing=true")
>   def test_case_sensitive_rename(self, unique_database):
>     t1 = "t1"
>     t2 = "t2"
>     self.execute_query("create table {}.{} (i int)".format(unique_database, 
> t1))
>     self.execute_query("alter table {}.{} rename to {}.{}"
>                        .format(unique_database, t1,unique_database, t2))
>     self.execute_query("alter table {}.{} rename to {}.{}"
>                       .format(unique_database, t2, unique_database.upper(), 
> t1.upper()))
>     EventProcessorUtils.wait_for_event_processing(self)
>     self.execute_query("invalidate metadata")
>     assert EventProcessorUtils.get_event_processor_status() == "ACTIVE"{code}
> *[Crash Logs]*
> {code:java}
> I20260529 08:01:44.534435 3797781 JniUtil.java:181] 
> e64db92811da7b34:e680dd3700000000] resetMetadata request: INVALIDATE ALL 
> issued by kvenureddy
> I20260529 08:01:44.536720 3797781 CatalogServiceCatalog.java:2450] 
> e64db92811da7b34:e680dd3700000000] Invalidating all metadata. Version: 2174, 
> IsCatalogServerRequest: false
> I20260529 08:01:44.537449 3797781 MetastoreEventsProcessor.java:1050] 
> e64db92811da7b34:e680dd3700000000] Event processing is paused. Greatest 
> synced event id is 3609262
> I20260529 08:01:44.537541 3797781 TableEventExecutor.java:443] 
> e64db92811da7b34:e680dd3700000000] Cleared executor: 
> DbEventExecutor-2.TableEventExecutor-0
> I20260529 08:01:44.537559 3797781 TableEventExecutor.java:443] 
> e64db92811da7b34:e680dd3700000000] Cleared executor: 
> DbEventExecutor-2.TableEventExecutor-1
> I20260529 08:01:44.537571 3797781 TableEventExecutor.java:443] 
> e64db92811da7b34:e680dd3700000000] Cleared executor: 
> DbEventExecutor-2.TableEventExecutor-2
> I20260529 08:01:44.537583 3797781 TableEventExecutor.java:443] 
> e64db92811da7b34:e680dd3700000000] Cleared executor: 
> DbEventExecutor-2.TableEventExecutor-3
> I20260529 08:01:44.537596 3797781 TableEventExecutor.java:443] 
> e64db92811da7b34:e680dd3700000000] Cleared executor: 
> DbEventExecutor-2.TableEventExecutor-4
> I20260529 08:01:44.537608 3797781 DbEventExecutor.java:622] 
> e64db92811da7b34:e680dd3700000000] Cleared executor: DbEventExecutor-2
> I20260529 08:01:44.537642 3797653 TableEventExecutor.java:443] Cleared 
> executor: DbEventExecutor-1.TableEventExecutor-0
> I20260529 08:01:44.537665 3797653 TableEventExecutor.java:443] Cleared 
> executor: DbEventExecutor-1.TableEventExecutor-1
> I20260529 08:01:44.537675 3797653 TableEventExecutor.java:443] Cleared 
> executor: DbEventExecutor-1.TableEventExecutor-2
> I20260529 08:01:44.537684 3797653 TableEventExecutor.java:443] Cleared 
> executor: DbEventExecutor-1.TableEventExecutor-3
> I20260529 08:01:44.537693 3797653 TableEventExecutor.java:443] Cleared 
> executor: DbEventExecutor-1.TableEventExecutor-4
> I20260529 08:01:44.537720 3797653 DbEventExecutor.java:622] Cleared executor: 
> DbEventExecutor-1
> I20260529 08:01:44.537763 3797655 DbEventExecutor.java:760] Unassigned 
> executor: DbEventExecutor-0.TableEventExecutor-2 for table: 
> TEST_CASE_SENSITIVE_RENAME_89F3C8C4.t1
> I20260529 08:01:44.537801 3797652 TableEventExecutor.java:443] Cleared 
> executor: DbEventExecutor-3.TableEventExecutor-0
> I20260529 08:01:44.537840 3797654 TableEventExecutor.java:443] Cleared 
> executor: DbEventExecutor-4.TableEventExecutor-0
> I20260529 08:01:44.537863 3797652 TableEventExecutor.java:443] Cleared 
> executor: DbEventExecutor-3.TableEventExecutor-1
> I20260529 08:01:44.537873 3797652 TableEventExecutor.java:443] Cleared 
> executor: DbEventExecutor-3.TableEventExecutor-2
> I20260529 08:01:44.537881 3797652 TableEventExecutor.java:443] Cleared 
> executor: DbEventExecutor-3.TableEventExecutor-3
> I20260529 08:01:44.537889 3797652 TableEventExecutor.java:443] Cleared 
> executor: DbEventExecutor-3.TableEventExecutor-4
> I20260529 08:01:44.537899 3797652 DbEventExecutor.java:622] Cleared executor: 
> DbEventExecutor-3
> I20260529 08:01:44.537923 3797655 DbEventExecutor.java:760] Unassigned 
> executor: DbEventExecutor-0.TableEventExecutor-1 for table: 
> test_case_sensitive_rename_89f3c8c4.t2
> I20260529 08:01:44.537954 3797654 TableEventExecutor.java:443] Cleared 
> executor: DbEventExecutor-4.TableEventExecutor-1
> I20260529 08:01:44.537988 3797655 DbEventExecutor.java:804] Unassigned 
> executor: DbEventExecutor-0 for db: test_case_sensitive_rename_89f3c8c4
> I20260529 08:01:44.538018 3797654 TableEventExecutor.java:443] Cleared 
> executor: DbEventExecutor-4.TableEventExecutor-2
> I20260529 08:01:44.538043 3797654 TableEventExecutor.java:443] Cleared 
> executor: DbEventExecutor-4.TableEventExecutor-3
> I20260529 08:01:44.538066 3797654 TableEventExecutor.java:443] Cleared 
> executor: DbEventExecutor-4.TableEventExecutor-4
> I20260529 08:01:44.538087 3797654 DbEventExecutor.java:622] Cleared executor: 
> DbEventExecutor-4
> E20260529 08:01:44.538468 3797781 JniUtil.java:198] 
> e64db92811da7b34:e680dd3700000000] Error in INVALIDATE ALL issued by 
> kvenureddy. Time spent: 4ms
> I20260529 08:01:44.538808 3797781 jni-util.cc:335] 
> e64db92811da7b34:e680dd3700000000] java.lang.IllegalStateException: 
> java.lang.IllegalStateException
>  at 
> java.base/jdk.internal.reflect.NativeConstructorAccessorImpl.newInstance0(Native
>  Method)
>  at 
> java.base/jdk.internal.reflect.NativeConstructorAccessorImpl.newInstance(NativeConstructorAccessorImpl.java:77)
>  at 
> java.base/jdk.internal.reflect.DelegatingConstructorAccessorImpl.newInstance(DelegatingConstructorAccessorImpl.java:45)
>  at 
> java.base/java.lang.reflect.Constructor.newInstanceWithCaller(Constructor.java:500)
>  at java.base/java.lang.reflect.Constructor.newInstance(Constructor.java:481)
>  at 
> java.base/java.util.concurrent.ForkJoinTask.getThrowableException(ForkJoinTask.java:562)
>  at 
> java.base/java.util.concurrent.ForkJoinTask.reportException(ForkJoinTask.java:591)
>  at java.base/java.util.concurrent.ForkJoinTask.invoke(ForkJoinTask.java:689)
>  at 
> java.base/java.util.stream.ForEachOps$ForEachOp.evaluateParallel(ForEachOps.java:159)
>  at 
> java.base/java.util.stream.ForEachOps$ForEachOp$OfRef.evaluateParallel(ForEachOps.java:173)
>  at 
> java.base/java.util.stream.AbstractPipeline.evaluate(AbstractPipeline.java:233)
>  at 
> java.base/java.util.stream.ReferencePipeline.forEach(ReferencePipeline.java:596)
>  at 
> java.base/java.util.stream.ReferencePipeline$Head.forEach(ReferencePipeline.java:765)
>  at 
> org.apache.impala.catalog.events.EventExecutorService.clear(EventExecutorService.java:195)
>  at 
> org.apache.impala.catalog.events.MetastoreEventsProcessor.clear(MetastoreEventsProcessor.java:1210)
>  at 
> org.apache.impala.catalog.CatalogServiceCatalog.reset(CatalogServiceCatalog.java:2475)
>  at 
> org.apache.impala.service.CatalogOpExecutor.execResetMetadataImpl(CatalogOpExecutor.java:7591)
>  at 
> org.apache.impala.service.CatalogOpExecutor.execResetMetadata(CatalogOpExecutor.java:7407)
>  at 
> org.apache.impala.service.JniCatalog.lambda$resetMetadata$4(JniCatalog.java:369)
>  at 
> org.apache.impala.service.JniCatalogOp.lambda$execAndSerialize$1(JniCatalogOp.java:90)
>  at org.apache.impala.service.JniCatalogOp.execOp(JniCatalogOp.java:58)
>  at 
> org.apache.impala.service.JniCatalogOp.execAndSerialize(JniCatalogOp.java:89)
>  at 
> org.apache.impala.service.JniCatalogOp.execAndSerialize(JniCatalogOp.java:100)
>  at org.apache.impala.service.JniCatalog.execAndSerialize(JniCatalog.java:253)
>  at org.apache.impala.service.JniCatalog.execAndSerialize(JniCatalog.java:267)
>  at org.apache.impala.service.JniCatalog.resetMetadata(JniCatalog.java:368)
> Caused by: java.lang.IllegalStateException
>  at com.google.common.base.Preconditions.checkState(Preconditions.java:496)
>  at 
> org.apache.impala.catalog.events.TableEventExecutor.clear(TableEventExecutor.java:440)
>  at java.base/java.util.ArrayList.forEach(ArrayList.java:1511)
>  at 
> org.apache.impala.catalog.events.DbEventExecutor.clearInternal(DbEventExecutor.java:612)
>  at 
> org.apache.impala.catalog.events.DbEventExecutor.clear(DbEventExecutor.java:621)
>  at 
> java.base/java.util.stream.ForEachOps$ForEachOp$OfRef.accept(ForEachOps.java:183)
>  at 
> java.base/java.util.ArrayList$ArrayListSpliterator.forEachRemaining(ArrayList.java:1625)
>  at 
> java.base/java.util.stream.AbstractPipeline.copyInto(AbstractPipeline.java:509)
>  at 
> java.base/java.util.stream.ForEachOps$ForEachTask.compute(ForEachOps.java:290)
>  at 
> java.base/java.util.concurrent.CountedCompleter.exec(CountedCompleter.java:754)
>  at java.base/java.util.concurrent.ForkJoinTask.doExec(ForkJoinTask.java:373)
>  at 
> java.base/java.util.concurrent.ForkJoinPool$WorkQueue.topLevelExec(ForkJoinPool.java:1182)
>  at java.base/java.util.concurrent.ForkJoinPool.scan(ForkJoinPool.java:1655)
>  at 
> java.base/java.util.concurrent.ForkJoinPool.runWorker(ForkJoinPool.java:1622)
>  at 
> java.base/java.util.concurrent.ForkJoinWorkerThread.run(ForkJoinWorkerThread.java:165)
> I20260529 08:01:44.538830 3797781 status.cc:129] 
> e64db92811da7b34:e680dd3700000000] IllegalStateException: 
> java.lang.IllegalStateException
> CAUSED BY: IllegalStateException: null
>     @          0x1367053  impala::Status::Status()
>     @          0x1cdff17  impala::JniUtil::GetJniExceptionMsg()
>     @          0x12e2c3f  impala::JniCall::Call<>()
>     @          0x12b07a0  impala::Catalog::ResetMetadata()
>     @          0x132959a  impala::CatalogServiceThriftIf::ResetMetadata()
>     @          0x1270e51  
> impala::CatalogServiceProcessorT<>::process_ResetMetadata()
>     @          0x129db63  impala::CatalogServiceProcessorT<>::dispatchCall()
>     @          0x11e60c5  apache::thrift::TDispatchProcessor::process()
>     @          0x16a6df5  
> apache::thrift::server::TAcceptQueueServer::Task::run()
>     @          0x16930a5  impala::ThriftThread::RunRunnable()
>     @          0x16940dc  
> boost::detail::function::void_function_obj_invoker0<>::invoke()
>     @          0x1dc2ea8  boost::function0<>::operator()()
>     @          0x1dc1d84  impala::Thread::SuperviseThread()
>     @          0x1dc27e5  boost::detail::thread_data<>::run()
>     @          0x291f967  thread_proxy
>     @     0x7f689ac9d609  start_thread
>     @     0x7f689a882133  clone
>     @              (nil)  (unknown)
> E20260529 08:01:44.555306 3797781 catalog-server.cc:431] 
> IllegalStateException: java.lang.IllegalStateException
> CAUSED BY: IllegalStateException: null
> {code}
>  



--
This message was sent by Atlassian Jira
(v8.20.10#820010)

---------------------------------------------------------------------
To unsubscribe, e-mail: [email protected]
For additional commands, e-mail: [email protected]

Reply via email to