Skip to content
Snippets Groups Projects
Select Git revision
  • ag-test
  • rs-test
  • master default protected
  • test-me-pa
  • mksionek-master-patch-52381
  • new-branch-10
  • test-conflicts
  • test-suggestions
  • alejandro-test
  • patch-25
  • winh-test-image-doscussion
  • stg-lfs-image-test-2
  • stg-lfs-image-test
  • test42016
  • issue_42016
  • issue-32709
  • add-codeowners
  • ClemMakesApps-master-patch-62759
  • bvl-staging-test
  • bvl-merge-base-api
  • v9.2.0-rc6 protected
  • v9.2.0-rc5 protected
  • v9.2.0-rc4 protected
  • v9.2.0-rc3 protected
  • v9.1.4 protected
  • v9.2.0-rc2 protected
  • v9.2.0-rc1 protected
  • v9.1.3 protected
  • v8.17.6 protected
  • v9.0.7 protected
  • v9.1.2 protected
  • v9.1.1 protected
  • v9.2.0.pre protected
  • v9.1.0 protected
  • v9.1.0-rc7 protected
  • v9.1.0-rc6 protected
  • v9.0.6 protected
  • v9.1.0-rc5 protected
  • v9.1.0-rc4 protected
  • v9.1.0-rc3 protected
40 results

db

  • Clone with SSH
  • Clone with HTTPS
  • user avatar
    Yorick Peterse authored
    This commit introduces a Sidekiq worker that precalculates the list of
    trending projects on a daily basis. The resulting set is stored in a
    database table that is then queried by Project.trending.
    
    This setup means that Unicorn workers no longer _may_ have to calculate
    the list of trending projects. Furthermore it supports filtering without
    any complex caching mechanisms.
    
    The data in the "trending_projects" table is inserted in the same order
    as the project ranking. This means that getting the projects in the
    correct order is simply a matter of:
    
        SELECT projects.*
        FROM projects
        INNER JOIN trending_projects ON trending_projects.project_id = projects.id
        ORDER BY trending_projects.id ASC;
    
    Such a query will only take a few milliseconds at most (as measured on
    GitLab.com), opposed to a few seconds for the query used for calculating
    the project ranks.
    
    The migration in this commit does not require downtime and takes care of
    populating an initial list of trending projects.
    237c8f66
    History
    Code owners
    Assign users and groups as approvers for specific file changes. Learn more.
    Name Last commit Last update
    ..
    fixtures
    migrate
    schema.rb
    seeds.rb