Hi,

I am getting some strange results in writing/reading with Threads using Cayenne and I'm sure it's something I'm not understanding about Cayenne's data caching.  I'm hoping to get a solution to force a direct read somehow but so far I haven't found anything with Mr. Google.

I'm using 4.1.B2.

The issue is that I believe that I am writing a value to the database and the database contents reflect the update but subsequent reads in other Threads are not picking up the new value.  Here's an example in my log file where I log the first Thread update to the object and a subsequent read from another Thread

2019-10-03,12:38:01:727,INFO ,[CAsteriskAMIMgrProxyRemoteIF-Thread-1570],ClientBase,::NotifyQueue - PostUpdate NotifyQueue=[Complete](125)Test call->Phone=416-712-2323::NotifyEvent=[Running](15)Test call 2019-10-03,12:38:01:728,INFO ,[NotifyTypeHandlerDialer-pool-449-thread-1],ClientBase,::NotifyQueue - PostLoad NotifyQueue=[Running](125)Test call->Phone=416-712-2323::NotifyEvent=[Running](15)Test call

  The first line PostUpdate shows that the NotifyQueue item (125) is Complete and when I check the database the value is definitely showing Complete.  However the next line from a different thread is reading the same NotifyQueue record (125) and it's displaying Running.   I don't understand how this is possible.  All indications show the PostUpdate is working but PostLoad is not picking up the changed value.

Here's a second example with another pair of NotifyQueue items (127,129).  The Web page picks up the correct status values (Complete) as indicated in the log below

2019-10-03,13:31:07:535,INFO ,[http-nio-8080-exec-126],ClientBase,::NotifyQueue - PostLoad NotifyQueue=[Complete](127)Test call->Phone=416-712-2323::NotifyEvent=[New](17)Test call 2019-10-03,13:31:07:535,INFO ,[http-nio-8080-exec-126],ClientBase,::NotifyQueue - PostLoad NotifyQueue=[Complete](129)Test call->Phone=416-712-2323::NotifyEvent=[New](19)Test call

And the background ThreadNotifyEventsForClient again does not pickup the updated Complete status (shows Running) more than a few seconds later (as opposed to the microseconds in the first logging example).  When I do a manual query on the DB, the status is definitely Complete.

2019-10-03,13:31:32:265,INFO ,[ThreadNotifyEventsForClient-pool-545-thread-1],NotifyEvent,ThreadNotifyEventsForClient::NotifyEvent=[Running](17)Test call::checkForCompletedQueueItems NotifyQueueCount=1 2019-10-03,13:31:32:265,DEBUG,[ThreadNotifyEventsForClient-pool-545-thread-1],NotifyEvent,ThreadNotifyEventsForClient::NotifyEvent=[Running](17)Test call::checkForCompletedQueueItems NotifyQueueItem=NotifyQueue=[Running](127)Test call->Phone=416-712-2323::NotifyEvent=[Running](17)Test call 2019-10-03,13:31:32:265,DEBUG,[ThreadNotifyEventsForClient-pool-545-thread-1],NotifyEvent,ThreadNotifyEventsForClient::NotifyEvent=[Running](17)Test call::checkForCompletedQueueItems INCOMPLETE->NotifyQueue=[Running](127)Test call->Phone=416-712-2323::NotifyEvent=[Running](17)Test call DEBUG UNCOMMITTED=0

2019-10-03,13:31:32:265,INFO ,[ThreadNotifyEventsForClient-pool-545-thread-1],NotifyEvent,ThreadNotifyEventsForClient::NotifyEvent=[Running](19)Test call::checkForCompletedQueueItems NotifyQueueCount=1 2019-10-03,13:31:32:265,DEBUG,[ThreadNotifyEventsForClient-pool-545-thread-1],NotifyEvent,ThreadNotifyEventsForClient::NotifyEvent=[Running](19)Test call::checkForCompletedQueueItems NotifyQueueItem=NotifyQueue=[Running](129)Test call->Phone=416-712-2323::NotifyEvent=[Running](19)Test call 2019-10-03,13:31:32:265,DEBUG,[ThreadNotifyEventsForClient-pool-545-thread-1],NotifyEvent,ThreadNotifyEventsForClient::NotifyEvent=[Running](19)Test call::checkForCompletedQueueItems INCOMPLETE->NotifyQueue=[Running](129)Test call->Phone=416-712-2323::NotifyEvent=[Running](19)Test call DEBUG UNCOMMITTED=0 2019-10-03,13:31:32:265,INFO ,[ThreadNotifyEventsForClient-pool-545-thread-1],NotifyEvent,ThreadNotifyEventsForClient::Callista Computer Telephony Inc.::checkForCompletedQueueItems Done


I have now made a change in my code for the background ThreadNotifyEventsForClient from

List<NotifyQueue> listQueue = notifyEvent.getListNotifyQueue();

to what should be the actual underlying transaction generated by Cayenne

            List<NotifyQueue> listQueue = ObjectSelect.query(NotifyQueue.class)
                .where(NotifyQueue.NOTIFY_EVENT.eq(notifyEvent))
                .select(ClientBaseAdmin.getObjectContext());

Here's the extract from the map.xml file for the relationship

    <db-relationship name="listNotifyQueue" source="NotifyEvent" target="NotifyQueue" toMany="true">
        <db-attribute-pair source="id" target="notifyEventID"/>

    <obj-relationship name="listNotifyQueue" source="NotifyEvent" target="NotifyQueue" deleteRule="Cascade" db-relationship-path="listNotifyQueue"/>


And guess what.  It works consistently with the explicit code change with a difference that I now get a PostLoad event now in the ThreadNotifyEventsForClient


2019-10-03,14:12:00:103,INFO ,[CAsteriskAMIMgrProxyRemoteIF-Thread-5291],ClientBase,::NotifyQueue - PostUpdateNotifyQueue=[Complete](133)Test call->Phone=416-712-2323::NotifyEvent=[Running](23)Test call

2019-10-03,14:12:00:107,INFO ,[ThreadNotifyEventsForClient-pool-758-thread-1],ClientBase,::NotifyQueue - PostLoad NotifyQueue=[Complete](133)Test call->Phone=416-712-2323::NotifyEvent=[Running](23)Test call 2019-10-03,14:12:00:107,INFO ,[ThreadNotifyEventsForClient-pool-758-thread-1],NotifyEvent,ThreadNotifyEventsForClient::NotifyEvent=[Running](23)Test call::checkForCompletedQueueItems NotifyQueueCount=1 2019-10-03,14:12:00:107,DEBUG,[ThreadNotifyEventsForClient-pool-758-thread-1],NotifyEvent,ThreadNotifyEventsForClient::NotifyEvent=[Running](23)Test call::checkForCompletedQueueItems NotifyQueueItem=NotifyQueue=[Complete](133)Test call->Phone=416-712-2323::NotifyEvent=[Running](23)Test call 2019-10-03,14:12:00:107,INFO ,[ThreadNotifyEventsForClient-pool-758-thread-1],NotifyEvent,ThreadNotifyEventsForClient::NotifyEvent=[Running](23)Test call::checkForCompletedQueueItems NotifyEvent has been completed 2019-10-03,14:12:00:107,DEBUG,[ThreadNotifyEventsForClient-pool-758-thread-1],NotifyEvent,ThreadNotifyEventsForClient::NotifyEvent=[Running](23)Test call::checkForCompletedQueueItems Generating NotifyLog for NotifyQueue->NotifyQueue=[Complete](133)Test call->Phone=416-712-2323::NotifyEvent=[Running](23)Test call


Can someone explain why this is the case and how I can "fix it" without the code change.


Thanks,

Andrew


Reply via email to