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

Venugopal Reddy K updated IMPALA-15051:
---------------------------------------
    Description: 
 

*[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]*
{code:java}
create database mydb;
use mydb;
create table test1(i int);
insert into test1 values(1),(2),(3);
alter table mydb.test1 rename to mydb.test2;
alter table mydb.test2 rename to Mydb.Test1;
invalidate metadata{code}
*[Crash Logs]*

 
{code:java}
I20260529 18:31:07.856305 4116682 JniUtil.java:181] 
16431b7fb1c71a99:2c87910c00000000] resetMetadata request: INVALIDATE ALL issued 
by kvenureddy
I20260529 18:31:07.856406 4116682 CatalogServiceCatalog.java:2450] 
16431b7fb1c71a99:2c87910c00000000] Invalidating all metadata. Version: 4319, 
IsCatalogServerRequest: false
I20260529 18:31:07.857302 4116682 MetastoreEventsProcessor.java:1050] 
16431b7fb1c71a99:2c87910c00000000] Event processing is paused. Greatest synced 
event id is 3609368
I20260529 18:31:07.857375 4116682 TableEventExecutor.java:443] 
16431b7fb1c71a99:2c87910c00000000] Cleared executor: 
DbEventExecutor-2.TableEventExecutor-0
I20260529 18:31:07.857390 4116682 TableEventExecutor.java:443] 
16431b7fb1c71a99:2c87910c00000000] Cleared executor: 
DbEventExecutor-2.TableEventExecutor-1
I20260529 18:31:07.857402 4116682 TableEventExecutor.java:443] 
16431b7fb1c71a99:2c87910c00000000] Cleared executor: 
DbEventExecutor-2.TableEventExecutor-2
I20260529 18:31:07.857414 4116682 TableEventExecutor.java:443] 
16431b7fb1c71a99:2c87910c00000000] Cleared executor: 
DbEventExecutor-2.TableEventExecutor-3
I20260529 18:31:07.857425 4116682 TableEventExecutor.java:443] 
16431b7fb1c71a99:2c87910c00000000] Cleared executor: 
DbEventExecutor-2.TableEventExecutor-4
I20260529 18:31:07.857436 4116682 DbEventExecutor.java:622] 
16431b7fb1c71a99:2c87910c00000000] Cleared executor: DbEventExecutor-2
I20260529 18:31:07.857458 4116682 TableEventExecutor.java:443] 
16431b7fb1c71a99:2c87910c00000000] Cleared executor: 
DbEventExecutor-4.TableEventExecutor-0
I20260529 18:31:07.857473 4116682 TableEventExecutor.java:443] 
16431b7fb1c71a99:2c87910c00000000] Cleared executor: 
DbEventExecutor-4.TableEventExecutor-1
I20260529 18:31:07.857487 4116682 TableEventExecutor.java:443] 
16431b7fb1c71a99:2c87910c00000000] Cleared executor: 
DbEventExecutor-4.TableEventExecutor-2
I20260529 18:31:07.857527 4114201 DbEventExecutor.java:760] Unassigned 
executor: DbEventExecutor-0.TableEventExecutor-1 for table: mydb.test2
I20260529 18:31:07.857579 4114201 DbEventExecutor.java:760] Unassigned 
executor: DbEventExecutor-0.TableEventExecutor-2 for table: Mydb.test1
I20260529 18:31:07.857611 4114204 TableEventExecutor.java:443] Cleared 
executor: DbEventExecutor-1.TableEventExecutor-0
I20260529 18:31:07.857647 4114204 TableEventExecutor.java:443] Cleared 
executor: DbEventExecutor-1.TableEventExecutor-1
I20260529 18:31:07.857669 4114204 TableEventExecutor.java:443] Cleared 
executor: DbEventExecutor-1.TableEventExecutor-2
I20260529 18:31:07.857702 4114201 DbEventExecutor.java:804] Unassigned 
executor: DbEventExecutor-0 for db: mydb
I20260529 18:31:07.857738 4116682 TableEventExecutor.java:443] 
16431b7fb1c71a99:2c87910c00000000] Cleared executor: 
DbEventExecutor-4.TableEventExecutor-3
I20260529 18:31:07.857751 4116682 TableEventExecutor.java:443] 
16431b7fb1c71a99:2c87910c00000000] Cleared executor: 
DbEventExecutor-4.TableEventExecutor-4
I20260529 18:31:07.857764 4116682 DbEventExecutor.java:622] 
16431b7fb1c71a99:2c87910c00000000] Cleared executor: DbEventExecutor-4
I20260529 18:31:07.857791 4114205 TableEventExecutor.java:443] Cleared 
executor: DbEventExecutor-3.TableEventExecutor-0
I20260529 18:31:07.857813 4114205 TableEventExecutor.java:443] Cleared 
executor: DbEventExecutor-3.TableEventExecutor-1
I20260529 18:31:07.857822 4114205 TableEventExecutor.java:443] Cleared 
executor: DbEventExecutor-3.TableEventExecutor-2
I20260529 18:31:07.857831 4114205 TableEventExecutor.java:443] Cleared 
executor: DbEventExecutor-3.TableEventExecutor-3
I20260529 18:31:07.857838 4114205 TableEventExecutor.java:443] Cleared 
executor: DbEventExecutor-3.TableEventExecutor-4
I20260529 18:31:07.857846 4114205 DbEventExecutor.java:622] Cleared executor: 
DbEventExecutor-3
I20260529 18:31:07.857874 4114204 TableEventExecutor.java:443] Cleared 
executor: DbEventExecutor-1.TableEventExecutor-3
I20260529 18:31:07.857908 4114204 TableEventExecutor.java:443] Cleared 
executor: DbEventExecutor-1.TableEventExecutor-4
I20260529 18:31:07.857950 4114204 DbEventExecutor.java:622] Cleared executor: 
DbEventExecutor-1
E20260529 18:31:07.858183 4116682 JniUtil.java:198] 
16431b7fb1c71a99:2c87910c00000000] Error in INVALIDATE ALL issued by 
kvenureddy. Time spent: 2ms
I20260529 18:31:07.858538 4116682 jni-util.cc:335] 
16431b7fb1c71a99:2c87910c00000000] 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 18:31:07.858549 4116682 status.cc:129] 
16431b7fb1c71a99:2c87910c00000000] IllegalStateException: 
java.lang.IllegalStateException
CAUSED BY: IllegalStateException: null
    @          0x1367653  impala::Status::Status()
    @          0x1ce0b89  impala::JniUtil::GetJniExceptionMsg()
    @          0x12e323f  impala::JniCall::Call<>()
    @          0x12b0da0  impala::Catalog::ResetMetadata()
    @          0x1329b9a  impala::CatalogServiceThriftIf::ResetMetadata()
    @          0x1271451  
impala::CatalogServiceProcessorT<>::process_ResetMetadata()
    @          0x129e163  impala::CatalogServiceProcessorT<>::dispatchCall()
    @          0x11e66c5  apache::thrift::TDispatchProcessor::process()
    @          0x16a7785  
apache::thrift::server::TAcceptQueueServer::Task::run()
    @          0x1693a35  impala::ThriftThread::RunRunnable()
    @          0x1694a6c  
boost::detail::function::void_function_obj_invoker0<>::invoke()
    @          0x1dc3b1a  boost::function0<>::operator()()
    @          0x1dc29f6  impala::Thread::SuperviseThread()
    @          0x1dc3457  boost::detail::thread_data<>::run()
    @          0x2921467  thread_proxy
    @     0x7f4577985609  start_thread
    @     0x7f457756a133  clone
    @              (nil)  (unknown)
E20260529 18:31:07.874303 4116682 catalog-server.cc:431] IllegalStateException: 
java.lang.IllegalStateException
CAUSED BY: IllegalStateException: null
W20260529 18:31:08.317953 4114257 MetastoreEventsProcessor.java:1348] Event 
processing is skipped since status is PAUSED. Last synced event id is 3609368
{code}
 

  was:
 

*[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]*
{code:java}
create database mydb;
use mydb;
create table test1(i int);
insert into test1 values(1),(2),(3);
alter table mydb.test1 rename to mydb.test2;
alter table mydb.test2 rename to Mydb.Test1;
invalidate metadata{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}
 


> 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]*
> {code:java}
> create database mydb;
> use mydb;
> create table test1(i int);
> insert into test1 values(1),(2),(3);
> alter table mydb.test1 rename to mydb.test2;
> alter table mydb.test2 rename to Mydb.Test1;
> invalidate metadata{code}
> *[Crash Logs]*
>  
> {code:java}
> I20260529 18:31:07.856305 4116682 JniUtil.java:181] 
> 16431b7fb1c71a99:2c87910c00000000] resetMetadata request: INVALIDATE ALL 
> issued by kvenureddy
> I20260529 18:31:07.856406 4116682 CatalogServiceCatalog.java:2450] 
> 16431b7fb1c71a99:2c87910c00000000] Invalidating all metadata. Version: 4319, 
> IsCatalogServerRequest: false
> I20260529 18:31:07.857302 4116682 MetastoreEventsProcessor.java:1050] 
> 16431b7fb1c71a99:2c87910c00000000] Event processing is paused. Greatest 
> synced event id is 3609368
> I20260529 18:31:07.857375 4116682 TableEventExecutor.java:443] 
> 16431b7fb1c71a99:2c87910c00000000] Cleared executor: 
> DbEventExecutor-2.TableEventExecutor-0
> I20260529 18:31:07.857390 4116682 TableEventExecutor.java:443] 
> 16431b7fb1c71a99:2c87910c00000000] Cleared executor: 
> DbEventExecutor-2.TableEventExecutor-1
> I20260529 18:31:07.857402 4116682 TableEventExecutor.java:443] 
> 16431b7fb1c71a99:2c87910c00000000] Cleared executor: 
> DbEventExecutor-2.TableEventExecutor-2
> I20260529 18:31:07.857414 4116682 TableEventExecutor.java:443] 
> 16431b7fb1c71a99:2c87910c00000000] Cleared executor: 
> DbEventExecutor-2.TableEventExecutor-3
> I20260529 18:31:07.857425 4116682 TableEventExecutor.java:443] 
> 16431b7fb1c71a99:2c87910c00000000] Cleared executor: 
> DbEventExecutor-2.TableEventExecutor-4
> I20260529 18:31:07.857436 4116682 DbEventExecutor.java:622] 
> 16431b7fb1c71a99:2c87910c00000000] Cleared executor: DbEventExecutor-2
> I20260529 18:31:07.857458 4116682 TableEventExecutor.java:443] 
> 16431b7fb1c71a99:2c87910c00000000] Cleared executor: 
> DbEventExecutor-4.TableEventExecutor-0
> I20260529 18:31:07.857473 4116682 TableEventExecutor.java:443] 
> 16431b7fb1c71a99:2c87910c00000000] Cleared executor: 
> DbEventExecutor-4.TableEventExecutor-1
> I20260529 18:31:07.857487 4116682 TableEventExecutor.java:443] 
> 16431b7fb1c71a99:2c87910c00000000] Cleared executor: 
> DbEventExecutor-4.TableEventExecutor-2
> I20260529 18:31:07.857527 4114201 DbEventExecutor.java:760] Unassigned 
> executor: DbEventExecutor-0.TableEventExecutor-1 for table: mydb.test2
> I20260529 18:31:07.857579 4114201 DbEventExecutor.java:760] Unassigned 
> executor: DbEventExecutor-0.TableEventExecutor-2 for table: Mydb.test1
> I20260529 18:31:07.857611 4114204 TableEventExecutor.java:443] Cleared 
> executor: DbEventExecutor-1.TableEventExecutor-0
> I20260529 18:31:07.857647 4114204 TableEventExecutor.java:443] Cleared 
> executor: DbEventExecutor-1.TableEventExecutor-1
> I20260529 18:31:07.857669 4114204 TableEventExecutor.java:443] Cleared 
> executor: DbEventExecutor-1.TableEventExecutor-2
> I20260529 18:31:07.857702 4114201 DbEventExecutor.java:804] Unassigned 
> executor: DbEventExecutor-0 for db: mydb
> I20260529 18:31:07.857738 4116682 TableEventExecutor.java:443] 
> 16431b7fb1c71a99:2c87910c00000000] Cleared executor: 
> DbEventExecutor-4.TableEventExecutor-3
> I20260529 18:31:07.857751 4116682 TableEventExecutor.java:443] 
> 16431b7fb1c71a99:2c87910c00000000] Cleared executor: 
> DbEventExecutor-4.TableEventExecutor-4
> I20260529 18:31:07.857764 4116682 DbEventExecutor.java:622] 
> 16431b7fb1c71a99:2c87910c00000000] Cleared executor: DbEventExecutor-4
> I20260529 18:31:07.857791 4114205 TableEventExecutor.java:443] Cleared 
> executor: DbEventExecutor-3.TableEventExecutor-0
> I20260529 18:31:07.857813 4114205 TableEventExecutor.java:443] Cleared 
> executor: DbEventExecutor-3.TableEventExecutor-1
> I20260529 18:31:07.857822 4114205 TableEventExecutor.java:443] Cleared 
> executor: DbEventExecutor-3.TableEventExecutor-2
> I20260529 18:31:07.857831 4114205 TableEventExecutor.java:443] Cleared 
> executor: DbEventExecutor-3.TableEventExecutor-3
> I20260529 18:31:07.857838 4114205 TableEventExecutor.java:443] Cleared 
> executor: DbEventExecutor-3.TableEventExecutor-4
> I20260529 18:31:07.857846 4114205 DbEventExecutor.java:622] Cleared executor: 
> DbEventExecutor-3
> I20260529 18:31:07.857874 4114204 TableEventExecutor.java:443] Cleared 
> executor: DbEventExecutor-1.TableEventExecutor-3
> I20260529 18:31:07.857908 4114204 TableEventExecutor.java:443] Cleared 
> executor: DbEventExecutor-1.TableEventExecutor-4
> I20260529 18:31:07.857950 4114204 DbEventExecutor.java:622] Cleared executor: 
> DbEventExecutor-1
> E20260529 18:31:07.858183 4116682 JniUtil.java:198] 
> 16431b7fb1c71a99:2c87910c00000000] Error in INVALIDATE ALL issued by 
> kvenureddy. Time spent: 2ms
> I20260529 18:31:07.858538 4116682 jni-util.cc:335] 
> 16431b7fb1c71a99:2c87910c00000000] 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 18:31:07.858549 4116682 status.cc:129] 
> 16431b7fb1c71a99:2c87910c00000000] IllegalStateException: 
> java.lang.IllegalStateException
> CAUSED BY: IllegalStateException: null
>     @          0x1367653  impala::Status::Status()
>     @          0x1ce0b89  impala::JniUtil::GetJniExceptionMsg()
>     @          0x12e323f  impala::JniCall::Call<>()
>     @          0x12b0da0  impala::Catalog::ResetMetadata()
>     @          0x1329b9a  impala::CatalogServiceThriftIf::ResetMetadata()
>     @          0x1271451  
> impala::CatalogServiceProcessorT<>::process_ResetMetadata()
>     @          0x129e163  impala::CatalogServiceProcessorT<>::dispatchCall()
>     @          0x11e66c5  apache::thrift::TDispatchProcessor::process()
>     @          0x16a7785  
> apache::thrift::server::TAcceptQueueServer::Task::run()
>     @          0x1693a35  impala::ThriftThread::RunRunnable()
>     @          0x1694a6c  
> boost::detail::function::void_function_obj_invoker0<>::invoke()
>     @          0x1dc3b1a  boost::function0<>::operator()()
>     @          0x1dc29f6  impala::Thread::SuperviseThread()
>     @          0x1dc3457  boost::detail::thread_data<>::run()
>     @          0x2921467  thread_proxy
>     @     0x7f4577985609  start_thread
>     @     0x7f457756a133  clone
>     @              (nil)  (unknown)
> E20260529 18:31:07.874303 4116682 catalog-server.cc:431] 
> IllegalStateException: java.lang.IllegalStateException
> CAUSED BY: IllegalStateException: null
> W20260529 18:31:08.317953 4114257 MetastoreEventsProcessor.java:1348] Event 
> processing is skipped since status is PAUSED. Last synced event id is 3609368
> {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