Description:
Hello, I found a hang bug in 8.0.35-cluster version of MYSQL cluster. 
The detail is as follow.
OS version and name:
Ubuntu 22.04.3 LTS (Jammy Jellyfish)
Linux eb1f47b08982 6.5.11-8-pve #1 SMP PREEMPT_DYNAMIC PMX 6.5.11-8 (2024-01-30T12:27Z) x86_64 x86_64 x86_64 GNU/Linux
PoC:
'''
select  
  (select Managed_name from mysql.replication_asynchronous_connection_failover limit 1 offset 6)
     as c0
from
  (select
            ref_0.column1 as c0,
            ref_0.column1 as c1,
            ref_0.column2 as c2,
            ref_0.column6 as c3
          from
            mytest90.test8 as ref_0
          where ref_0.column1 is not NULL
          limit 125) as subq_0
      left join mytest90.test7 as ref_1
      on (false)
    right join mytest90.test6 as ref_2
    on (subq_0.c1 is NULL),
  lateral (select
        case when ref_2.column1 is NULL then ref_1.column2 else ref_1.column2 end
           as c0,
        ref_1.column7 as c1,
        subq_0.c3 as c2,
        subq_0.c0 as c3,
        subq_0.c1 as c4,
        ref_2.column1 as c5,
        subq_1.c6 as c6,
        ref_2.column1 as c7,
        ref_3.column7 as c8
      from
        mytest90.test0 as ref_3,
        lateral (select
              ref_3.column9 as c0,
              ref_2.column1 as c1,
              ref_1.column5 as c2,
              ref_2.column1 as c3,
              ref_1.column1 as c4,
              ref_2.column1 as c5,
              ref_1.column5 as c6,
              subq_0.c0 as c7,
              ref_4.column7 as c8,
              subq_0.c2 as c9,
              ref_2.column1 as c10,
              ref_4.column5 as c11
            from
              mytest90.test7 as ref_4
            where true) as subq_1
      where ref_2.column1 is NULL
      limit 61) as subq_2
where (EXISTS (
    select
        subq_3.c0 as c0,
        ref_2.column1 as c1,
        ref_2.column1 as c2,
        case when (false)
            or ((true)
              or (false)) then subq_0.c0 else subq_0.c0 end
           as c3,
        93 as c4,
        7 as c5,
        subq_2.c6 as c6
      from
        mytest90.test1 as ref_5,
        lateral (select
              ref_5.column3 as c0
            from
              mytest90.test3 as ref_6
            where false
            limit 105) as subq_3
      where (false)
        and ((ref_5.column1 is not NULL)
          or (false))
      limit 83))
  or (cast(coalesce(subq_0.c1,
      subq_2.c4) as float) is NULL)
limit 55;
'''
Architecture Information:
'''
[NDBD DEFAULT]
NoOfReplicas =2
DataMemory = 512M
IndexMemory = 64M
[NDB_MGMD]
NodeId=1
hostname =192.172.10.8
datadir =/var/lib/mysql-cluster
[NDBD]
NodeId =2
hostname =192.172.10.9
datadir =/usr/local/mysql-cluster/data
NodeGroup=0
[NDBD]
NodeId =3
hostname =192.172.10.10
datadir =/usr/local/mysql-cluster/data
NodeGroup=1
[NDBD]
NodeId =4
hostname =192.172.10.11
datadir =/usr/local/mysql-cluster/data
NodeGroup=0
[NDBD]
NodeId =5
hostname =192.172.10.12
datadir =/usr/local/mysql-cluster/data
NodeGroup=1
[mysqld]
NodeId =6
hostname =192.172.10.9
[mysqld]
NodeId =7
hostname =192.172.10.10
[mysqld]
NodeId =8
hostname =192.172.10.11
[mysqld]
NodeId =9
hostname =192.172.10.12
'''
Attempted and successfully reproduced!
How to repeat:
Simply execute that PoC to repeat it.
Suggested fix:
seems like a dead loop
  
 
 
Description: Hello, I found a hang bug in 8.0.35-cluster version of MYSQL cluster. The detail is as follow. OS version and name: Ubuntu 22.04.3 LTS (Jammy Jellyfish) Linux eb1f47b08982 6.5.11-8-pve #1 SMP PREEMPT_DYNAMIC PMX 6.5.11-8 (2024-01-30T12:27Z) x86_64 x86_64 x86_64 GNU/Linux PoC: ''' select (select Managed_name from mysql.replication_asynchronous_connection_failover limit 1 offset 6) as c0 from (select ref_0.column1 as c0, ref_0.column1 as c1, ref_0.column2 as c2, ref_0.column6 as c3 from mytest90.test8 as ref_0 where ref_0.column1 is not NULL limit 125) as subq_0 left join mytest90.test7 as ref_1 on (false) right join mytest90.test6 as ref_2 on (subq_0.c1 is NULL), lateral (select case when ref_2.column1 is NULL then ref_1.column2 else ref_1.column2 end as c0, ref_1.column7 as c1, subq_0.c3 as c2, subq_0.c0 as c3, subq_0.c1 as c4, ref_2.column1 as c5, subq_1.c6 as c6, ref_2.column1 as c7, ref_3.column7 as c8 from mytest90.test0 as ref_3, lateral (select ref_3.column9 as c0, ref_2.column1 as c1, ref_1.column5 as c2, ref_2.column1 as c3, ref_1.column1 as c4, ref_2.column1 as c5, ref_1.column5 as c6, subq_0.c0 as c7, ref_4.column7 as c8, subq_0.c2 as c9, ref_2.column1 as c10, ref_4.column5 as c11 from mytest90.test7 as ref_4 where true) as subq_1 where ref_2.column1 is NULL limit 61) as subq_2 where (EXISTS ( select subq_3.c0 as c0, ref_2.column1 as c1, ref_2.column1 as c2, case when (false) or ((true) or (false)) then subq_0.c0 else subq_0.c0 end as c3, 93 as c4, 7 as c5, subq_2.c6 as c6 from mytest90.test1 as ref_5, lateral (select ref_5.column3 as c0 from mytest90.test3 as ref_6 where false limit 105) as subq_3 where (false) and ((ref_5.column1 is not NULL) or (false)) limit 83)) or (cast(coalesce(subq_0.c1, subq_2.c4) as float) is NULL) limit 55; ''' Architecture Information: ''' [NDBD DEFAULT] NoOfReplicas =2 DataMemory = 512M IndexMemory = 64M [NDB_MGMD] NodeId=1 hostname =192.172.10.8 datadir =/var/lib/mysql-cluster [NDBD] NodeId =2 hostname =192.172.10.9 datadir =/usr/local/mysql-cluster/data NodeGroup=0 [NDBD] NodeId =3 hostname =192.172.10.10 datadir =/usr/local/mysql-cluster/data NodeGroup=1 [NDBD] NodeId =4 hostname =192.172.10.11 datadir =/usr/local/mysql-cluster/data NodeGroup=0 [NDBD] NodeId =5 hostname =192.172.10.12 datadir =/usr/local/mysql-cluster/data NodeGroup=1 [mysqld] NodeId =6 hostname =192.172.10.9 [mysqld] NodeId =7 hostname =192.172.10.10 [mysqld] NodeId =8 hostname =192.172.10.11 [mysqld] NodeId =9 hostname =192.172.10.12 ''' Attempted and successfully reproduced! How to repeat: Simply execute that PoC to repeat it. Suggested fix: seems like a dead loop