Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
G
gitlab-ce
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
1
Merge Requests
1
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
nexedi
gitlab-ce
Commits
d57d8a03
Commit
d57d8a03
authored
Feb 25, 2016
by
Valery Sizov
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
ES indexer as a subprocess
parent
4985e69f
Changes
5
Show whitespace changes
Inline
Side-by-side
Showing
5 changed files
with
101 additions
and
6 deletions
+101
-6
app/services/git_push_service.rb
app/services/git_push_service.rb
+7
-2
bin/elastic_repo_indexer
bin/elastic_repo_indexer
+52
-0
lib/elastic/indexer.rb
lib/elastic/indexer.rb
+32
-0
lib/gitlab/popen.rb
lib/gitlab/popen.rb
+3
-2
lib/tasks/gitlab/elastic.rake
lib/tasks/gitlab/elastic.rake
+7
-2
No files found.
app/services/git_push_service.rb
View file @
d57d8a03
...
...
@@ -64,8 +64,13 @@ class GitPushService < BaseService
end
def
index_commits_blobs
@project
.
repository
.
index_commits
(
from_rev:
params
[
:oldrev
],
to_rev:
params
[
:newrev
])
@project
.
repository
.
index_blobs
(
from_rev:
params
[
:oldrev
],
to_rev:
params
[
:newrev
])
indexer
=
Elastic
::
Indexer
.
new
indexer
.
run
(
@project
.
id
,
project
.
repository
.
path_to_repo
,
params
[
:oldrev
],
params
[
:newrev
]
)
end
def
process_default_branch
...
...
bin/elastic_repo_indexer
0 → 100755
View file @
d57d8a03
#!/usr/bin/env ruby
require
'rubygems'
require
'bundler/setup'
require
'json'
require
'elasticsearch/git'
require
'active_support'
require
'active_support/core_ext'
PROJECT_ID
=
ARGV
.
shift
REPO_PATH
=
ARGV
.
shift
FROM_SHA
=
ENV
[
'FROM_SHA'
]
TO_SHA
=
ENV
[
'TO_SHA'
]
RAILS_ENV
=
ENV
[
'RAILS_ENV'
]
elastic_connection_info
=
JSON
.
parse
ENV
[
'ELASTIC_CONNECTION_INFO'
]
ELASTIC_HOST
=
elastic_connection_info
[
:host
]
ELASTIC_PORT
=
elastic_connection_info
[
:port
]
class
Repository
include
Elasticsearch
::
Git
::
Repository
index_name
[
'repository'
,
'index'
,
RAILS_ENV
].
compact
.
join
(
'-'
)
self
.
__elasticsearch__
.
client
=
Elasticsearch
::
Client
.
new
(
host:
ELASTIC_HOST
,
port:
ELASTIC_PORT
)
def
repository_id
PROJECT_ID
end
def
path_to_repo
REPO_PATH
end
end
Repository
.
__elasticsearch__
.
create_index!
repo
=
Repository
.
new
params
=
{
from_rev:
FROM_SHA
,
to_rev:
TO_SHA
}.
compact
print
"Indexing commits..."
repo
.
index_commits
(
params
)
puts
"Done"
print
"Indexing blobs..."
repo
.
index_blobs
(
params
)
puts
"Done"
\ No newline at end of file
lib/elastic/indexer.rb
0 → 100644
View file @
d57d8a03
module
Elastic
class
Indexer
Error
=
Class
.
new
(
StandardError
)
def
initialize
# We accept any form of settings, including string and array
# This is why JSON is needed
@vars
=
{
'ELASTIC_CONNECTION_INFO'
=>
{
host:
Gitlab
.
config
.
elasticsearch
.
host
,
port:
Gitlab
.
config
.
elasticsearch
.
port
}.
to_json
,
'RAILS_ENV'
=>
Rails
.
env
}
end
def
run
(
project_id
,
repo_path
,
from_sha
=
nil
,
to_sha
=
nil
)
vars
=
@vars
.
merge
({
'FROM_SHA'
=>
from_sha
,
'TO_SHA'
=>
to_sha
})
command
=
[
'bin/elastic_repo_indexer'
,
project_id
.
to_s
,
repo_path
]
output
,
status
=
Gitlab
::
Popen
.
popen
(
command
,
nil
,
vars
)
raise
Error
,
output
.
join
(
"
\n
"
)
unless
status
.
zero?
true
end
end
end
\ No newline at end of file
lib/gitlab/popen.rb
View file @
d57d8a03
...
...
@@ -5,13 +5,13 @@ module Gitlab
module
Popen
extend
self
def
popen
(
cmd
,
path
=
nil
)
def
popen
(
cmd
,
path
=
nil
,
vars
=
{}
)
unless
cmd
.
is_a?
(
Array
)
raise
"System commands must be given as an array of strings"
end
path
||=
Dir
.
pwd
vars
=
{
"PWD"
=>
path
}
vars
[
'PWD'
]
=
path
options
=
{
chdir:
path
}
unless
File
.
directory?
(
path
)
...
...
@@ -20,6 +20,7 @@ module Gitlab
@cmd_output
=
""
@cmd_status
=
0
Open3
.
popen3
(
vars
,
*
cmd
,
options
)
do
|
stdin
,
stdout
,
stderr
,
wait_thr
|
# We are not using stdin so we should close it, in case the command we
# are running waits for input.
...
...
lib/tasks/gitlab/elastic.rake
View file @
d57d8a03
...
...
@@ -14,6 +14,8 @@ namespace :gitlab do
projects
=
apply_project_filters
(
projects
)
indexer
=
Elastic
::
Indexer
.
new
projects
.
find_each
do
|
project
|
if
project
.
repository
.
exists?
&&
!
project
.
repository
.
empty?
puts
"Indexing
#{
project
.
name_with_namespace
}
(ID=
#{
project
.
id
}
)..."
...
...
@@ -28,8 +30,11 @@ namespace :gitlab do
next
end
project
.
repository
.
index_commits
(
from_rev:
project
.
index_status
.
last_commit
)
project
.
repository
.
index_blobs
(
from_rev:
project
.
index_status
.
last_commit
)
indexer
.
run
(
project
.
id
,
project
.
repository
.
path_to_repo
,
project
.
index_status
.
last_commit
)
# During indexing the new commits can be pushed,
# the last_commit parameter only indicates that at least this commit is in index
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment