Explorar o código

Improve wekan performance #837

maulal %!s(int64=8) %!d(string=hai) anos
pai
achega
cd6317cedb
Modificáronse 4 ficheiros con 9 adicións e 1 borrados
  1. 2 0
      models/activities.js
  2. 3 0
      models/boards.js
  3. 1 1
      models/cards.js
  4. 3 0
      models/unsavedEdits.js

+ 2 - 0
models/activities.js

@@ -52,6 +52,8 @@ if (Meteor.isServer) {
     Activities._collection._ensureIndex({ createdAt: -1 });
     Activities._collection._ensureIndex({ cardId: 1, createdAt: -1 });
     Activities._collection._ensureIndex({ boardId: 1, createdAt: -1 });
+    Activities._collection._ensureIndex({ commentId: 1 }, { partialFilterExpression: { commentId: { $exists: true } } });
+    Activities._collection._ensureIndex({ attachmentId: 1 }, { partialFilterExpression: { attachmentId: { $exists: true } } });
   });
 
   Activities.after.insert((userId, doc) => {

+ 3 - 0
models/boards.js

@@ -414,6 +414,9 @@ if (Meteor.isServer) {
       _id: 1,
       'members.userId': 1,
     }, { unique: true });
+    Boards._collection._ensureIndex({
+      'members.userId': 1,
+    }, { unique: true });
   });
 
   // Genesis: the first activity of the newly created board

+ 1 - 1
models/cards.js

@@ -267,7 +267,7 @@ if (Meteor.isServer) {
   // Cards are often fetched within a board, so we create an index to make these
   // queries more efficient.
   Meteor.startup(() => {
-    Cards._collection._ensureIndex({ boardId: 1 });
+    Cards._collection._ensureIndex({ boardId: 1, createdAt: -1 });
   });
 
   Cards.after.insert((userId, doc) => {

+ 3 - 0
models/unsavedEdits.js

@@ -26,6 +26,9 @@ if (Meteor.isServer) {
   function isAuthor(userId, doc, fieldNames = []) {
     return userId === doc.userId && fieldNames.indexOf('userId') === -1;
   }
+  Meteor.startup(() => {
+    UnsavedEditCollection._collection._ensureIndex({ userId: 1 });
+  });
   UnsavedEditCollection.allow({
     insert: isAuthor,
     update: isAuthor,