[Tarantool-patches] [PATCH 09/10] box/journal: journal_entry_new -- drop setting up callbacks

Cyrill Gorcunov gorcunov at gmail.com
Sat Mar 7 00:41:45 MSK 2020


On Sat, Mar 07, 2020 at 12:37:43AM +0300, Konstantin Osipov wrote:
> * Cyrill Gorcunov <gorcunov at gmail.com> [20/03/05 15:32]:
> > The callbacks gonna be different from sync and async
> > commits thus lets untangle it from journal_entry_new
> > interface but setup explicitly.
> > 
> > I think setting up NULLs for entry is a safe approach
> > so we can allow us to spend a few cycles.
> 
> This is a hot path. 

You mean to not setup NULL here? Maybe with Debug build only?

> I don't see much value in this patch, but I don't think it
> makes much of a difference either way.
> 
> My preference is to drop this patch, just pass different
> call backs from different call sites.

I don't mind to rework.

Kotya, there is a problem in this series. In one test case

[cyrill at uranus test] ./test-run.py replication/gc.test.lua
...
[002] replication/gc.test.lua                         memtx           [ pass ]
...

But vinyl test case fails

2020-03-07 00:35:51.116 [6494] main/136/applier/unix/:/home/cyrill/sda1 I> subscribed
2020-03-07 00:35:51.116 [6494] main/136/applier/unix/:/home/cyrill/sda1 I> remote vclock {1: 782} local vclock {1: 382}
tarantool: /home/cyrill/sda1/tarantool/tarantool.git/src/box/vy_tx.c:803: void vy_tx_commit(struct vy_tx *, int64_t): Assertion `xm->lsn <= lsn' failed.
[001] replication/gc.test.lua                         vinyl           
[001] 
[001] [Instance "replica" killed by signal: 6 (SIGABRT)]
[001] Found assertion fail in the results file [/home/cyrill/sda1/tarantool/tarantool.git/test/var/001_replication/replica.log]:
[001] [ fail ]
[Main process] Got failed test; gently terminate all workers...
---

Actually somtimes it pass, sometime fails. And I didn't find out why, yet. Investigating...


More information about the Tarantool-patches mailing list