English ▾
Localized versions of git-upload-pack manual
  1. English
  2. Português (Brasil)
  3. українська мова
  4. 简体中文
Topics ▾ Latest version ▾ git-upload-pack last updated in 2.52.0
Changes in the git-upload-pack manual
  1. 2.52.0 2025年11月17日
  2. 2.45.2 → 2.51.2 no changes
  3. 2.45.1 2024年04月29日
  4. 2.45.0 no changes
  5. 2.44.2 → 2.44.4 no changes
  6. 2.44.1 2024年04月19日
  7. 2.44.0 no changes
  8. 2.43.5 → 2.43.7 no changes
  9. 2.43.4 2024年04月19日
  10. 2.43.1 → 2.43.3 no changes
  11. 2.43.0 no changes
  12. 2.42.3 → 2.42.4 no changes
  13. 2.42.2 2024年04月19日
  14. 2.42.1 no changes
  15. 2.42.0 no changes
  16. 2.41.2 → 2.41.3 no changes
  17. 2.41.1 2024年04月19日
  18. 2.41.0 no changes
  19. 2.40.3 → 2.40.4 no changes
  20. 2.40.2 2024年04月19日
  21. 2.40.1 no changes
  22. 2.40.0 no changes
  23. 2.39.5 no changes
  24. 2.39.4 2024年04月19日
  25. 2.38.1 → 2.39.3 no changes
  26. 2.38.0 2022年10月02日
  27. 2.34.1 → 2.37.7 no changes
  28. 2.34.0 2021年11月15日
  29. 2.21.1 → 2.33.8 no changes
  30. 2.21.0 no changes
  31. 2.19.3 → 2.20.5 no changes
  32. 2.19.2 2018年11月21日
  33. 2.11.4 → 2.19.1 no changes
  34. 2.10.5 2017年09月22日
  35. 2.1.4 → 2.9.5 no changes
  36. 2.0.5 2014年12月17日

Check your version of git by running

git --version

NAME

git-upload-pack - Send objects packed back to git-fetch-pack

SYNOPSIS

git-upload-pack [--[no-]strict] [--timeout=<n>] [--stateless-rpc]
		 [--advertise-refs] <directory>

DESCRIPTION

Invoked by git fetch-pack, learns what objects the other side is missing, and sends them after packing.

This command is usually not invoked directly by the end user. The UI for the protocol is on the git fetch-pack side, and the program pair is meant to be used to pull updates from a remote repository. For push operations, see git send-pack.

OPTIONS

--strict
--no-strict

Do not try <directory>/.git/ if <directory> is not a Git directory.

--timeout=<n>

Interrupt transfer after <n> seconds of inactivity.

--stateless-rpc

Perform only a single read-write cycle with stdin and stdout. This fits with the HTTP POST request processing model where a program may read the request, write a response, and must exit.

--http-backend-info-refs

Used by git-http-backend[1] to serve up $GIT_URL/info/refs?service=git-upload-pack requests. See "Smart Clients" in gitprotocol-http[5] and "HTTP Transport" in the gitprotocol-v2[5] documentation. Also understood by git-receive-pack[1].

<directory>

The repository to sync from.

ENVIRONMENT

GIT_PROTOCOL

Internal variable used for handshaking the wire protocol. Server admins may need to configure some transports to allow this variable to be passed. See the discussion in git[1].

GIT_NO_LAZY_FETCH

When cloning or fetching from a partial repository (i.e., one itself cloned with --filter), the server-side upload-pack may need to fetch extra objects from its upstream in order to complete the request. By default, upload-pack will refuse to perform such a lazy fetch, because git fetch may run arbitrary commands specified in configuration and hooks of the source repository (and upload-pack tries to be safe to run even in untrusted .git directories).

This is implemented by having upload-pack internally set the GIT_NO_LAZY_FETCH variable to 1. If you want to override it (because you are fetching from a partial clone, and you are sure you trust it), you can explicitly set GIT_NO_LAZY_FETCH to 0.

SECURITY

Most Git commands should not be run in an untrusted .git directory (see the section SECURITY in git[1]). upload-pack tries to avoid any dangerous configuration options or hooks from the repository it’s serving, making it safe to clone an untrusted directory and run commands on the resulting clone.

For an extra level of safety, you may be able to run upload-pack as an alternate user. The details will be platform dependent, but on many systems you can run:

git clone --no-local --upload-pack='sudo -u nobody git-upload-pack' ...

SEE ALSO

GIT

Part of the git[1] suite

AltStyle によって変換されたページ (->オリジナル) /