فهرست منبع

Improve wekan performance #837

maulal 8 سال پیش
والد
کامیت
cd6317cedb
4فایلهای تغییر یافته به همراه9 افزوده شده و 1 حذف شده
  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({ createdAt: -1 });
     Activities._collection._ensureIndex({ cardId: 1, createdAt: -1 });
     Activities._collection._ensureIndex({ cardId: 1, createdAt: -1 });
     Activities._collection._ensureIndex({ boardId: 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) => {
   Activities.after.insert((userId, doc) => {

+ 3 - 0
models/boards.js

@@ -414,6 +414,9 @@ if (Meteor.isServer) {
       _id: 1,
       _id: 1,
       'members.userId': 1,
       'members.userId': 1,
     }, { unique: true });
     }, { unique: true });
+    Boards._collection._ensureIndex({
+      'members.userId': 1,
+    }, { unique: true });
   });
   });
 
 
   // Genesis: the first activity of the newly created board
   // 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
   // Cards are often fetched within a board, so we create an index to make these
   // queries more efficient.
   // queries more efficient.
   Meteor.startup(() => {
   Meteor.startup(() => {
-    Cards._collection._ensureIndex({ boardId: 1 });
+    Cards._collection._ensureIndex({ boardId: 1, createdAt: -1 });
   });
   });
 
 
   Cards.after.insert((userId, doc) => {
   Cards.after.insert((userId, doc) => {

+ 3 - 0
models/unsavedEdits.js

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