Uploaded image for project: 'Confluence Data Center'
  1. Confluence Data Center
  2. CONFSERVER-55506

Deleting repeating Events in Team Calendar causes duplicates in database and java.lang.OutOfMemoryError

XMLWordPrintable

      Summary

      Deleting Events in Team Calendar that are part of a repeating Event cause duplicates in the database, which causes performance issues and java.lang.OutOfMemoryError when viewing Team Calendars as the duplicates are loaded back into memory when re-loading the Calendar.

      Environment

      • Confluence 6.9.0
      • Team Calendar 6.0.0 or 5.5.4

      Steps to Reproduce

      This is quite tricky to reproduce with clear, concise steps. It may differ but in general

      1. In Team Calendars, create an all day Event that repeats every day and never ends
      2. Delete one event, at least a week after the first one
      3. Check the Team Calendar Exclusion table for duplicates (this is for Postgres, adjust as necessary)
        select "EXCLUSION", count(*) from "AO_950DC3_TC_EVENTS_EXCL" group by "EXCLUSION";
        

        There should be one event listed, the deleted one

      1. Click on a date before the deleted event, and select All Future Events
      2. Check the Team Calendar Exclusion table for all duplicates (this is for Postgres, adjust as necessary)
        select "EXCLUSION", count(*) from "AO_950DC3_TC_EVENTS_EXCL" group by "EXCLUSION";
        

        The Events are not removed.

      Diagnosis

      Run the following query to see if you may be affected by this issue (this is for Postgres, adjust as necessary):

      select "ALL_DAY", "EVENT_ID", "EXCLUSION", count(*) from "AO_950DC3_TC_EVENTS_EXCL" group by "ALL_DAY", "EVENT_ID", "EXCLUSION" having count(*) > 1;

      If there are rows returned, it's possible you are experiencing this issue, especially if the count for any row is high.

      Expected Results

      There should be only be two rows in AO_950DC3_TC_EVENTS_EXCL and the Events should be removed.

      Actual Results

      The below exception is thrown in the atlassian-confluence.log file:

      atlassian-confluence.log
      2018-05-09 16:55:31,339 ERROR [http-nio-8090-exec-7] [common.error.jersey.ThrowableExceptionMapper] toResponse Uncaught exception thrown by REST service: Java heap space
       -- referer: http://confluence.mycompany.com:8090/calendar/mycalendar.action | url: /rest/calendar-services/1.0/calendar/events.json | traceId: b85eaf70252053ab | userName: admin
      java.lang.OutOfMemoryError: Java heap space
      

      Resolution

      Upgrade to Team Calendars 6.0.12 which contains a fix for this issue.

      Notes

      Reviewing the heap dump from the java.lang.OutOfMemory error we can see that there are a few very large threads loaded with duplicates of the data, for example

      object cause size
      com.mysql.jdbc.JDBC42ResultSet AO_950DC3_TC_EVENTS_EXCL 946M
      http-nio-8090-exec-2 /rest/calendar-services/1.0/calendar/events.json 716M

      The com.mysql.jdbc.JDBC42ResultSet is pulling all the data from AO_950DC3_TC_EVENTS_EXCL. http-nio-8090-exec-2 is the associated user thread.

      The URL in the HAR fill shows it as

      And this returns all the data, or generates the java.lang.OutOfMemoryError.

      The error is caused by this code

      com.atlassian.confluence.extra.calendar3.DefaultCalendarManager#excludeEvent
                  excludeRecurrence(
                          baseEvent,
                          !(baseEvent.getStartDate().getDate() instanceof net.fortuna.ical4j.model.DateTime || baseEvent.getEndDate().getDate() instanceof net.fortuna.ical4j.model.DateTime)
                                  ? excludeDate.withZoneRetainFields(DateTimeZone.forID(srcSubCalendar.getTimeZoneId()))
                                  : excludeDate.withZone(DateTimeZone.forID(srcSubCalendar.getTimeZoneId()))
                  );
      
                  calendarDataStore.updateEvent(srcSubCalendar, baseEvent);
      

      Workaround

      The only option is to delete the duplicates in the AO_950DC3_TC_EVENTS_EXCL table and informing users to not delete All Future Events.

      IMPORTANT

      Always back up your data before performing any modifications to the database. If possible, test any alter, insert, update, or delete SQL commands on a staging server first.

      MySQL

      You can remove the duplicates by adding then removing this index

      MySQL 5.6 and below
      ALTER IGNORE TABLE AO_950DC3_TC_EVENTS_EXCL ADD UNIQUE INDEX AO_950DC3_TC_EVENTS_EXCL_TEMP_INDEX (ALL_DAY, EVENT_ID, EXCLUSION);
      ALTER TABLE AO_950DC3_TC_EVENTS_EXCL DROP INDEX AO_950DC3_TC_EVENTS_EXCL_TEMP_INDEX;
      
      MySQL 5.7 and above
      CREATE TABLE AO_950DC3_TC_EVENTS_EXCL_NEW LIKE AO_950DC3_TC_EVENTS_EXCL;
      ALTER TABLE AO_950DC3_TC_EVENTS_EXCL_NEW ADD UNIQUE INDEX (EVENT_ID);
      INSERT IGNORE INTO AO_950DC3_TC_EVENTS_EXCL_NEW SELECT * FROM AO_950DC3_TC_EVENTS_EXCL;
      DROP TABLE AO_950DC3_TC_EVENTS_EXCL;
      RENAME TABLE AO_950DC3_TC_EVENTS_EXCL_NEW TO AO_950DC3_TC_EVENTS_EXCL;
      

      PostgreSQL

      Delete the duplicates with (this may take some time)

      PostgreSQL
      delete from "AO_950DC3_TC_EVENTS_EXCL" where "ID" in (select "ID" from (select "ID", row_number() over (partition BY "EXCLUSION" order by "ID") from "AO_950DC3_TC_EVENTS_EXCL") excl_table WHERE excl_table.row_number > 1);
      

            dluong Duy Truong Luong
            jrichards@atlassian.com James Richards
            Votes:
            9 Vote for this issue
            Watchers:
            23 Start watching this issue

              Created:
              Updated:
              Resolved: