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
160e55e1
Commit
160e55e1
authored
Feb 15, 2021
by
Craig Norris
Committed by
Evan Read
Feb 15, 2021
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Remove use of please
Remove "please" from page, and other edits.
parent
967540d9
Changes
1
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
18 additions
and
18 deletions
+18
-18
doc/administration/gitaly/index.md
doc/administration/gitaly/index.md
+18
-18
No files found.
doc/administration/gitaly/index.md
View file @
160e55e1
...
@@ -19,7 +19,7 @@ In the Gitaly documentation:
...
@@ -19,7 +19,7 @@ In the Gitaly documentation:
-
[
GitLab Shell
](
https://gitlab.com/gitlab-org/gitlab-shell
)
.
-
[
GitLab Shell
](
https://gitlab.com/gitlab-org/gitlab-shell
)
.
-
[
GitLab Workhorse
](
https://gitlab.com/gitlab-org/gitlab-workhorse
)
.
-
[
GitLab Workhorse
](
https://gitlab.com/gitlab-org/gitlab-workhorse
)
.
GitLab end users do not have direct access to Gitaly. Gitaly
only manages
Git
GitLab end users do not have direct access to Gitaly. Gitaly
manages only
Git
repository access for GitLab. Other types of GitLab data aren't accessed using Gitaly.
repository access for GitLab. Other types of GitLab data aren't accessed using Gitaly.
<!-- vale gitlab.FutureTense = NO -->
<!-- vale gitlab.FutureTense = NO -->
...
@@ -91,8 +91,8 @@ When running Gitaly on its own server, note the following regarding GitLab versi
...
@@ -91,8 +91,8 @@ When running Gitaly on its own server, note the following regarding GitLab versi
-
From GitLab 11.4, Gitaly was able to serve all Git requests without requiring a shared NFS mount
-
From GitLab 11.4, Gitaly was able to serve all Git requests without requiring a shared NFS mount
for Git repository data, except for the
for Git repository data, except for the
[
Elasticsearch indexer
](
https://gitlab.com/gitlab-org/gitlab-elasticsearch-indexer
)
.
[
Elasticsearch indexer
](
https://gitlab.com/gitlab-org/gitlab-elasticsearch-indexer
)
.
-
From GitLab 11.8, the Elasticsearch indexer
uses Gitaly for data access as well
. NFS can still be
-
From GitLab 11.8, the Elasticsearch indexer
also uses Gitaly for data access
. NFS can still be
leveraged for redundancy on block-level Git data, but
only has to be mounted
on the Gitaly
leveraged for redundancy on block-level Git data, but
should be mounted only
on the Gitaly
servers.
servers.
-
From GitLab 11.8 to 12.2, it is possible to use Elasticsearch in a Gitaly setup that doesn't use
-
From GitLab 11.8 to 12.2, it is possible to use Elasticsearch in a Gitaly setup that doesn't use
NFS. To use Elasticsearch in these versions, the
NFS. To use Elasticsearch in these versions, the
...
@@ -497,16 +497,16 @@ gitaly['certificate_path'] = "/etc/gitlab/ssl/cert.pem"
...
@@ -497,16 +497,16 @@ gitaly['certificate_path'] = "/etc/gitlab/ssl/cert.pem"
gitaly
[
'key_path'
]
=
"/etc/gitlab/ssl/key.pem"
gitaly
[
'key_path'
]
=
"/etc/gitlab/ssl/key.pem"
```
```
`path`
can
only be included
for storage shards on the local Gitaly server.
`path`
can
be included only
for storage shards on the local Gitaly server.
If it's excluded, default Git storage directory is used for that storage shard.
If it's excluded, default Git storage directory is used for that storage shard.
### Disable Gitaly where not required (optional)
### Disable Gitaly where not required (optional)
If you run Gitaly
[
as a remote service
](
#run-gitaly-on-its-own-server
)
, consider
If you run Gitaly
[
as a remote service
](
#run-gitaly-on-its-own-server
)
, consider
disabling the local Gitaly service that runs on your GitLab server by default, and
only
run it
disabling the local Gitaly service that runs on your GitLab server by default, and run it
where required.
only
where required.
Disabling Gitaly on the GitLab instance
only makes sense
when you run GitLab in a custom cluster configuration, where
Disabling Gitaly on the GitLab instance
makes sense only
when you run GitLab in a custom cluster configuration, where
Gitaly runs on a separate machine from the GitLab instance. Disabling Gitaly on all machines in the cluster is not
Gitaly runs on a separate machine from the GitLab instance. Disabling Gitaly on all machines in the cluster is not
a valid configuration (some machines much act as Gitaly servers).
a valid configuration (some machines much act as Gitaly servers).
...
@@ -724,7 +724,7 @@ Gitaly Go process. Some examples of things that are implemented in `gitaly-ruby`
...
@@ -724,7 +724,7 @@ Gitaly Go process. Some examples of things that are implemented in `gitaly-ruby`
We recommend:
We recommend:
-
At least 300MB memory per worker.
-
At least 300
MB memory per worker.
-
No more than one worker per core.
-
No more than one worker per core.
NOTE:
NOTE:
...
@@ -752,7 +752,7 @@ settings:
...
@@ -752,7 +752,7 @@ settings:
gitaly
[
'ruby_num_workers'
]
=
4
gitaly
[
'ruby_num_workers'
]
=
4
```
```
1.
Save the file
and
[
reconfigure GitLab
](
../restart_gitlab.md#omnibus-gitlab-reconfigure
)
.
1.
Save the file
, and then
[
reconfigure GitLab
](
../restart_gitlab.md#omnibus-gitlab-reconfigure
)
.
**For installations from source**
**For installations from source**
...
@@ -810,9 +810,9 @@ You can observe the behavior of this queue using the Gitaly logs and Prometheus:
...
@@ -810,9 +810,9 @@ You can observe the behavior of this queue using the Gitaly logs and Prometheus:
-
`gitaly_rate_limiting_seconds`
.
-
`gitaly_rate_limiting_seconds`
.
NOTE:
NOTE:
Though the name of the Prometheus metric contains
`rate_limiting`
, it i
s a concurrency limiter, not
Although the name of the Prometheus metric contains
`rate_limiting`
, it'
s a concurrency limiter, not
a rate limiter. If a Gitaly client makes 1
000 requests in a row very quickly, concurrency does no
t
a rate limiter. If a Gitaly client makes 1
,000 requests in a row very quickly, concurrency doesn'
t
exceed 1 and the concurrency limiter has no effect.
exceed 1
,
and the concurrency limiter has no effect.
## Background Repository Optimization
## Background Repository Optimization
...
@@ -880,7 +880,7 @@ see something like this:
...
@@ -880,7 +880,7 @@ see something like this:
{
enforced
=
"true"
,
status
=
"ok"
}
4424.985419441742
{
enforced
=
"true"
,
status
=
"ok"
}
4424.985419441742
```
```
There may also be other numbers with rate 0. We
only care
about the non-zero numbers.
There may also be other numbers with rate 0. We
care only
about the non-zero numbers.
The only non-zero number should have
`enforced="true",status="ok"`
. If you have other non-zero
The only non-zero number should have
`enforced="true",status="ok"`
. If you have other non-zero
numbers, something is wrong in your configuration.
numbers, something is wrong in your configuration.
...
@@ -939,7 +939,7 @@ After the new token is set, and all services involved have been restarted, you w
...
@@ -939,7 +939,7 @@ After the new token is set, and all services involved have been restarted, you w
-
`status="would be ok"`
.
-
`status="would be ok"`
.
-
`status="denied"`
.
-
`status="denied"`
.
After the new token
has been
picked up by all Gitaly clients and Gitaly servers, the
After the new token
is
picked up by all Gitaly clients and Gitaly servers, the
**only non-zero rate**
should be
`enforced="false",status="would be ok"`
.
**only non-zero rate**
should be
`enforced="false",status="would be ok"`
.
### Disable "auth transitioning" mode
### Disable "auth transitioning" mode
...
@@ -1145,7 +1145,7 @@ PID=<Git process ID>
...
@@ -1145,7 +1145,7 @@ PID=<Git process ID>
sudo cat
/proc/
$PID
/environ |
tr
'\0'
'\n'
|
grep
^CORRELATION_ID
=
sudo cat
/proc/
$PID
/environ |
tr
'\0'
'\n'
|
grep
^CORRELATION_ID
=
```
```
Please note that this method is not reliable for
`git cat-file`
processes
because Gitaly
This method isn't reliable for
`git cat-file`
processes,
because Gitaly
internally pools and re-uses those across RPCs.
internally pools and re-uses those across RPCs.
### Observing `gitaly-ruby` traffic
### Observing `gitaly-ruby` traffic
...
@@ -1161,7 +1161,7 @@ not differentiate between `gitaly-ruby` and other RPCs, but in practice
...
@@ -1161,7 +1161,7 @@ not differentiate between `gitaly-ruby` and other RPCs, but in practice
(as of GitLab 11.9), all gRPC calls made by Gitaly itself are internal
(as of GitLab 11.9), all gRPC calls made by Gitaly itself are internal
calls from the main Gitaly process to one of its
`gitaly-ruby`
sidecars.
calls from the main Gitaly process to one of its
`gitaly-ruby`
sidecars.
Assuming your
`grpc_client_handled_total`
counter o
nly observes
Gitaly,
Assuming your
`grpc_client_handled_total`
counter o
bserves only
Gitaly,
the following query shows you RPCs are (most likely) internally
the following query shows you RPCs are (most likely) internally
implemented as calls to
`gitaly-ruby`
:
implemented as calls to
`gitaly-ruby`
:
...
@@ -1306,8 +1306,8 @@ If this error occurs even though file permissions are correct, it's likely that
...
@@ -1306,8 +1306,8 @@ If this error occurs even though file permissions are correct, it's likely that
the Gitaly server is experiencing
the Gitaly server is experiencing
[
clock drift
](
https://en.wikipedia.org/wiki/Clock_drift
)
.
[
clock drift
](
https://en.wikipedia.org/wiki/Clock_drift
)
.
Please ensure that the Gitaly clients and servers are synchronized
and use an NTP time
Ensure the Gitaly clients and servers are synchronized,
and use an NTP time
server to keep them synchronized if possible.
server to keep them synchronized
,
if possible.
### Praefect
### Praefect
...
...
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