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
c59a4eea
Commit
c59a4eea
authored
Jul 24, 2019
by
GitLab Bot
Browse files
Options
Browse Files
Download
Plain Diff
Automatic merge of gitlab-org/gitlab-ce master
parents
35a8650a
5c69b781
Changes
2
Show whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
9 additions
and
10 deletions
+9
-10
doc/development/chaos_endpoints.md
doc/development/chaos_endpoints.md
+4
-4
doc/development/reusing_abstractions.md
doc/development/reusing_abstractions.md
+5
-6
No files found.
doc/development/chaos_endpoints.md
View file @
c59a4eea
...
@@ -69,7 +69,7 @@ curl http://localhost:3000/-/chaos/leakmem?memory_mb=1024&duration_s=10&token=se
...
@@ -69,7 +69,7 @@ curl http://localhost:3000/-/chaos/leakmem?memory_mb=1024&duration_s=10&token=se
This endpoint attempts to fully utilise a single core, at 100%, for the given period.
This endpoint attempts to fully utilise a single core, at 100%, for the given period.
Depending on your rack server setup, your request may timeout after a predermined period (normally 60 seconds).
Depending on your rack server setup, your request may timeout after a prede
te
rmined period (normally 60 seconds).
If you're using Unicorn, this is done by killing the worker process.
If you're using Unicorn, this is done by killing the worker process.
```
```
...
@@ -80,7 +80,7 @@ GET /-/chaos/cpu_spin?duration_s=50&async=true
...
@@ -80,7 +80,7 @@ GET /-/chaos/cpu_spin?duration_s=50&async=true
| Attribute | Type | Required | Description |
| Attribute | Type | Required | Description |
| ------------ | ------- | -------- | --------------------------------------------------------------------- |
| ------------ | ------- | -------- | --------------------------------------------------------------------- |
|
`duration_s`
| integer | no | Duration, in seconds, that the core will be utili
s
ed. Defaults to 30s |
|
`duration_s`
| integer | no | Duration, in seconds, that the core will be utili
z
ed. Defaults to 30s |
|
`async`
| boolean | no | Set to true to consume CPU in a Sidekiq background worker process |
|
`async`
| boolean | no | Set to true to consume CPU in a Sidekiq background worker process |
```
bash
```
bash
...
@@ -93,7 +93,7 @@ curl http://localhost:3000/-/chaos/cpu_spin?duration_s=60&token=secret
...
@@ -93,7 +93,7 @@ curl http://localhost:3000/-/chaos/cpu_spin?duration_s=60&token=secret
This endpoint attempts to fully utilise a single core, and interleave it with DB request, for the given period.
This endpoint attempts to fully utilise a single core, and interleave it with DB request, for the given period.
This endpoint can be used to model yielding execution to another threads when running concurrently.
This endpoint can be used to model yielding execution to another threads when running concurrently.
Depending on your rack server setup, your request may timeout after a predermined period (normally 60 seconds).
Depending on your rack server setup, your request may timeout after a prede
te
rmined period (normally 60 seconds).
If you're using Unicorn, this is done by killing the worker process.
If you're using Unicorn, this is done by killing the worker process.
```
```
...
@@ -105,7 +105,7 @@ GET /-/chaos/db_spin?duration_s=50&async=true
...
@@ -105,7 +105,7 @@ GET /-/chaos/db_spin?duration_s=50&async=true
| Attribute | Type | Required | Description |
| Attribute | Type | Required | Description |
| ------------ | ------- | -------- | --------------------------------------------------------------------------- |
| ------------ | ------- | -------- | --------------------------------------------------------------------------- |
|
`interval_s`
| float | no | Interval, in seconds, for every DB request. Defaults to 1s |
|
`interval_s`
| float | no | Interval, in seconds, for every DB request. Defaults to 1s |
|
`duration_s`
| integer | no | Duration, in seconds, that the core will be utili
s
ed. Defaults to 30s |
|
`duration_s`
| integer | no | Duration, in seconds, that the core will be utili
z
ed. Defaults to 30s |
|
`async`
| boolean | no | Set to true to perform the operation in a Sidekiq background worker process |
|
`async`
| boolean | no | Set to true to perform the operation in a Sidekiq background worker process |
```
bash
```
bash
...
...
doc/development/reusing_abstractions.md
View file @
c59a4eea
...
@@ -14,13 +14,13 @@ on maintainability, the ability to easily debug problems, or even performance.
...
@@ -14,13 +14,13 @@ on maintainability, the ability to easily debug problems, or even performance.
An example would be to use
`ProjectsFinder`
in
`IssuesFinder`
to limit issues to
An example would be to use
`ProjectsFinder`
in
`IssuesFinder`
to limit issues to
those belonging to a set of projects. While initially this may seem like a good
those belonging to a set of projects. While initially this may seem like a good
idea, both classes provide a very high level interface with very little control.
idea, both classes provide a very high level interface with very little control.
This means that
`IssuesFinder`
may not be able to produce a better optimi
s
ed
This means that
`IssuesFinder`
may not be able to produce a better optimi
z
ed
database query, as a large portion of the query is controlled by the internals
database query, as a large portion of the query is controlled by the internals
of
`ProjectsFinder`
.
of
`ProjectsFinder`
.
To work around this problem, you would use the same code used by
To work around this problem, you would use the same code used by
`ProjectsFinder`
, instead of using
`ProjectsFinder`
itself directly. This allows
`ProjectsFinder`
, instead of using
`ProjectsFinder`
itself directly. This allows
you to compose your behavio
ur better, giving you more control over the behaviou
r
you to compose your behavio
r better, giving you more control over the behavio
r
of the code.
of the code.
To illustrate, consider the following code from
`IssuableFinder#projects`
:
To illustrate, consider the following code from
`IssuableFinder#projects`
:
...
@@ -52,7 +52,7 @@ functionality is added to this (high level) interface. Instead of _only_
...
@@ -52,7 +52,7 @@ functionality is added to this (high level) interface. Instead of _only_
affecting the cases where this is necessary, it may also start affecting
affecting the cases where this is necessary, it may also start affecting
`IssuableFinder`
in a negative way. For example, the query produced by
`IssuableFinder`
in a negative way. For example, the query produced by
`GroupProjectsFinder`
may include unnecessary conditions. Since we're using a
`GroupProjectsFinder`
may include unnecessary conditions. Since we're using a
finder here, we can't easily opt-out of that behavio
u
r. We could add options to
finder here, we can't easily opt-out of that behavior. We could add options to
do so, but then we'd need as many options as we have features. Every option adds
do so, but then we'd need as many options as we have features. Every option adds
two code paths, which means that for four features we have to cover 8 different
two code paths, which means that for four features we have to cover 8 different
code paths.
code paths.
...
@@ -213,6 +213,5 @@ The API provided by Active Record itself, such as the `where` method, `save`,
...
@@ -213,6 +213,5 @@ The API provided by Active Record itself, such as the `where` method, `save`,
Everything in
`app/workers`
.
Everything in
`app/workers`
.
The scheduling of Sidekiq jobs using
`SomeWorker.perform_async`
,
`perform_in`
,
Use
`SomeWorker.perform_async`
or
`SomeWorker.perform_in`
to schedule Sidekiq
etc. Directly invoking a worker using
`SomeWorker.new.perform`
should be avoided
jobs. Never directly invoke a worker using
`SomeWorker.new.perform`
.
at all times in application code, though this is fine to use in tests.
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