Hi Ahmed,

Thank you for your insights! I don't think the write rates are slow for the
tables I enable CDC on, otherwise, the commit log sizes won't go over the
cdc_total_space_in_mb (4096) quickly. I'll try to dig more into what
affects the speed of memtable flushes.

Bingqin Zhou

On Thu, Apr 29, 2021 at 1:11 AM Ahmed Eljami <ahmed.elj...@gmail.com> wrote:

> Hi  Bingqin,
>
> When cdc_raw directory is full, Cassandra rejects new writes on this node
> with the following message in the log:
>
> - Rejecting Mutation containing CDC-enabled table.....
>
> https://github.com/apache/cassandra/blob/cassandra-3.11.9/src/java/org/apache/cassandra/db/commitlog/CommitLogSegmentManagerCDC.java#L125
>
> So, I'm not sorry if WriteTimeoutException is related to cdc feature in
> your case.
>
> For your issue with no commitLog flushed/copied into cdc_raw directory,
> can you try with an explicit nodetool flush and see if commitLog will be
> transferred ? For tables with a "very low" write rates, memtable can take a
> lot of time before be flushed on disk.
>
> Cheers,
> Ahmed
>
>
> Le jeu. 29 avr. 2021 à 00:23, Bingqin Zhou <bingq...@wepay.com.invalid> a
> écrit :
>
>> Hi all,
>>
>> We're working on a Kafka connector to capture data changes in Cassandra by
>> processing commit log files in the cdc_raw directory. After we enabled CDC
>> on a few tables, we didn't observe any commit log files getting flushed
>> into cdc_raw directory as expected, but got WriteTimeoutException in
>> Cassandra DB.
>>
>> Here's how we reproduce the issue:
>>
>> 1. Our Cassandra Settings:
>>
>> - Cassandra Version: 3.11.9
>> - Related configs in Cassandra.yaml:
>>    - cdc_enabled: true
>>    - cdc_total_space_in_mb: 4096
>>    - commitlog_segment_size_in_mb: 32mb
>>    - commitlog_total_space_in_mb: 8192
>>    - commitlog_sync: periodic
>>    - commitlog_sync_period_in_ms: 10000
>>
>> 2. Enable CDC on a few tables by CQL:
>>   ALTER TABLE foo WITH cdc=true;
>>
>> 3. After a few days, we get *WriteTimeoutException* in Cassandra DB.
>> However at the same time, cdc_raw directory is still empty with no commit
>> log flushed/copied into it at all.
>>
>> I want to understand why there's no commit log file flushed into
>> cdc_raw directory at all even when the threshold cdc_total_space_in_mb has
>> been reached and write suspension has been triggered in Cassandra DB. This
>> sounds like a bug and currently makes the CDC feature useless.
>>
>> Thanks so much,
>> Bingqin Zhou
>>
>
>
> --
> Cordialement;
>
> Ahmed ELJAMI
>

Reply via email to