Add an index for lookup by account to log entries

Also fixes the query to require one less join
This commit is contained in:
Joseph Schorr 2016-08-12 16:53:17 -04:00
parent d9b65b88e9
commit 0f46230493
4 changed files with 36 additions and 14 deletions

View file

@ -730,10 +730,9 @@ class LogEntry(BaseModel):
database = db database = db
read_slaves = (read_slave,) read_slaves = (read_slave,)
indexes = ( indexes = (
# create an index on repository and date (('account', 'datetime'), False),
(('performer', 'datetime'), False),
(('repository', 'datetime'), False), (('repository', 'datetime'), False),
# create an index on repository, date and kind
(('repository', 'datetime', 'kind'), False), (('repository', 'datetime', 'kind'), False),
) )

View file

@ -0,0 +1,26 @@
"""Add logentry index for lookup by account
Revision ID: 8981dabd329f
Revises: 790d91952fa8
Create Date: 2016-08-12 16:50:15.816120
"""
# revision identifiers, used by Alembic.
revision = '8981dabd329f'
down_revision = '790d91952fa8'
from alembic import op
def upgrade(tables):
### commands auto generated by Alembic - please adjust! ###
op.create_index('logentry_account_id_datetime', 'logentry', ['account_id', 'datetime'], unique=False)
op.create_index('logentry_performer_id_datetime', 'logentry', ['performer_id', 'datetime'], unique=False)
### end Alembic commands ###
def downgrade(tables):
### commands auto generated by Alembic - please adjust! ###
op.drop_index('logentry_account_id_datetime', table_name='logentry')
op.drop_index('logentry_performer_id_datetime', table_name='logentry')
### end Alembic commands ###

View file

@ -1,12 +1,12 @@
import json import json
from calendar import timegm from calendar import timegm
from peewee import JOIN_LEFT_OUTER, SQL, fn from peewee import JOIN_LEFT_OUTER, fn
from datetime import datetime, timedelta, date from datetime import datetime, timedelta
from cachetools import lru_cache from cachetools import lru_cache
from data.database import LogEntry, LogEntryKind, User, RepositoryActionCount, db from data.database import LogEntry, LogEntryKind, User, RepositoryActionCount, db
from data.model import config from data.model import config, user, DataModelException
def _logs_query(selections, start_time, end_time, performer=None, repository=None, namespace=None, def _logs_query(selections, start_time, end_time, performer=None, repository=None, namespace=None,
ignore=None): ignore=None):
@ -22,7 +22,11 @@ def _logs_query(selections, start_time, end_time, performer=None, repository=Non
joined = joined.where(LogEntry.performer == performer) joined = joined.where(LogEntry.performer == performer)
if namespace: if namespace:
joined = joined.join(User, on=(User.username == namespace)) namespace_user = user.get_user_or_org(namespace)
if namespace_user is None:
raise DataModelException('Invalid namespace requested')
joined = joined.where(LogEntry.account == namespace_user.id)
if ignore: if ignore:
kind_map = get_log_entry_kinds() kind_map = get_log_entry_kinds()

View file

@ -13,7 +13,6 @@ angular.module('quay').directive('logsView', function () {
'user': '=user', 'user': '=user',
'makevisible': '=makevisible', 'makevisible': '=makevisible',
'repository': '=repository', 'repository': '=repository',
'performer': '=performer',
'allLogs': '@allLogs' 'allLogs': '@allLogs'
}, },
controller: function($scope, $element, $sce, Restangular, ApiService, TriggerService, controller: function($scope, $element, $sce, Restangular, ApiService, TriggerService,
@ -313,11 +312,6 @@ angular.module('quay').directive('logsView', function () {
url += '?starttime=' + encodeURIComponent(getDateString($scope.options.logStartDate)); url += '?starttime=' + encodeURIComponent(getDateString($scope.options.logStartDate));
url += '&endtime=' + encodeURIComponent(getDateString($scope.options.logEndDate)); url += '&endtime=' + encodeURIComponent(getDateString($scope.options.logEndDate));
if ($scope.performer) {
url += '&performer=' + encodeURIComponent($scope.performer.name);
}
return url; return url;
}; };
@ -397,7 +391,6 @@ angular.module('quay').directive('logsView', function () {
$scope.$watch('user', update); $scope.$watch('user', update);
$scope.$watch('repository', update); $scope.$watch('repository', update);
$scope.$watch('makevisible', update); $scope.$watch('makevisible', update);
$scope.$watch('performer', update);
$scope.$watch('options.logStartDate', update); $scope.$watch('options.logStartDate', update);
$scope.$watch('options.logEndDate', update); $scope.$watch('options.logEndDate', update);