Compare commits
2 Commits
main
...
better-doc
Author | SHA1 | Date |
---|---|---|
Marius | 8abe05cebf | |
Marius | 2bbea6f91f |
|
@ -1,5 +1,17 @@
|
||||||
# Running tusd
|
# Running tusd
|
||||||
|
|
||||||
|
Using tusd is as simple as invoked a single command. This guide walks you through the most important configuration options that are necessary for most applications. To see all options, simply inspect the output of `tusd --help`.
|
||||||
|
|
||||||
|
## General configuration
|
||||||
|
|
||||||
|
### Host and port
|
||||||
|
|
||||||
|
### Uploads
|
||||||
|
|
||||||
|
## Storage configuration
|
||||||
|
|
||||||
|
### Local disk
|
||||||
|
|
||||||
Starting the tusd upload server is as simple as invoking a single command. For example, following
|
Starting the tusd upload server is as simple as invoking a single command. For example, following
|
||||||
snippet demonstrates how to start a tusd process which accepts tus uploads at
|
snippet demonstrates how to start a tusd process which accepts tus uploads at
|
||||||
`http://localhost:1080/files/` (notice the trailing slash) and stores them locally in the `./data` directory:
|
`http://localhost:1080/files/` (notice the trailing slash) and stores them locally in the `./data` directory:
|
||||||
|
@ -14,6 +26,7 @@ $ tusd -upload-dir=./data
|
||||||
[tusd] 2019/09/29 21:10:50 Supported tus extensions: creation,creation-with-upload,termination,concatenation,creation-defer-length
|
[tusd] 2019/09/29 21:10:50 Supported tus extensions: creation,creation-with-upload,termination,concatenation,creation-defer-length
|
||||||
[tusd] 2019/09/29 21:10:50 You can now upload files to: http://0.0.0.0:1080/files/
|
[tusd] 2019/09/29 21:10:50 You can now upload files to: http://0.0.0.0:1080/files/
|
||||||
```
|
```
|
||||||
|
### AWS S3
|
||||||
|
|
||||||
Alternatively, if you want to store the uploads on an AWS S3 bucket, you only have to specify
|
Alternatively, if you want to store the uploads on an AWS S3 bucket, you only have to specify
|
||||||
the bucket and provide the corresponding access credentials and region information using
|
the bucket and provide the corresponding access credentials and region information using
|
||||||
|
@ -55,6 +68,8 @@ $ tusd -s3-bucket=my-test-bucket.com -s3-transfer-acceleration
|
||||||
tusd is also able to read the credentials automatically from a shared credentials file (~/.aws/credentials) as described in https://github.com/aws/aws-sdk-go#configuring-credentials.
|
tusd is also able to read the credentials automatically from a shared credentials file (~/.aws/credentials) as described in https://github.com/aws/aws-sdk-go#configuring-credentials.
|
||||||
But be mindful of the need to declare the AWS_REGION value which isn't conventionally associated with credentials.
|
But be mindful of the need to declare the AWS_REGION value which isn't conventionally associated with credentials.
|
||||||
|
|
||||||
|
### Google Cloud Storage
|
||||||
|
|
||||||
Furthermore, tusd also has support for storing uploads on Google Cloud Storage. In order to enable this feature, supply the path to your account file containing the necessary credentials:
|
Furthermore, tusd also has support for storing uploads on Google Cloud Storage. In order to enable this feature, supply the path to your account file containing the necessary credentials:
|
||||||
|
|
||||||
```
|
```
|
||||||
|
@ -66,6 +81,7 @@ $ tusd -gcs-bucket=my-test-bucket.com
|
||||||
[tusd] Using /files/ as the base path.
|
[tusd] Using /files/ as the base path.
|
||||||
[tusd] Using /metrics as the metrics path.
|
[tusd] Using /metrics as the metrics path.
|
||||||
```
|
```
|
||||||
|
### Azure Blob
|
||||||
|
|
||||||
Tusd also supports storing uploads on Microsoft Azure Blob Storage. In order to enable this feature, provide the
|
Tusd also supports storing uploads on Microsoft Azure Blob Storage. In order to enable this feature, provide the
|
||||||
corresponding access credentials using environment variables.
|
corresponding access credentials using environment variables.
|
||||||
|
@ -111,6 +127,10 @@ Using endpoint https://xxxxx.blob.core.windows.net
|
||||||
[tusd] Using /metrics as the metrics path.
|
[tusd] Using /metrics as the metrics path.
|
||||||
```
|
```
|
||||||
|
|
||||||
|
## Proxy configuration
|
||||||
|
|
||||||
|
## TLS configuration
|
||||||
|
|
||||||
TLS support for HTTPS connections can be enabled by supplying a certificate and private key. Note that the certificate file must include the entire chain of certificates up to the CA certificate. The default configuration supports TLSv1.2 and TLSv1.3. It is possible to use only TLSv1.3 with `-tls-mode=tls13`; alternately, it is possible to disable TLSv1.3 and use only 256-bit AES ciphersuites with `-tls-mode=tls12-strong`. The following example generates a self-signed certificate for `localhost` and then uses it to serve files on the loopback address; that this certificate is not appropriate for production use. Note also that the key file must not be encrypted/require a passphrase.
|
TLS support for HTTPS connections can be enabled by supplying a certificate and private key. Note that the certificate file must include the entire chain of certificates up to the CA certificate. The default configuration supports TLSv1.2 and TLSv1.3. It is possible to use only TLSv1.3 with `-tls-mode=tls13`; alternately, it is possible to disable TLSv1.3 and use only 256-bit AES ciphersuites with `-tls-mode=tls12-strong`. The following example generates a self-signed certificate for `localhost` and then uses it to serve files on the loopback address; that this certificate is not appropriate for production use. Note also that the key file must not be encrypted/require a passphrase.
|
||||||
|
|
||||||
```
|
```
|
||||||
|
@ -130,95 +150,4 @@ $ tusd -upload-dir=./data -host=127.0.0.1 -port=8443 -tls-certificate=localhost.
|
||||||
[tusd] You can now upload files to: https://127.0.0.1:8443/files/
|
[tusd] You can now upload files to: https://127.0.0.1:8443/files/
|
||||||
```
|
```
|
||||||
|
|
||||||
|
## Hooks configuration
|
||||||
Besides these simple examples, tusd can be easily configured using a variety of command line
|
|
||||||
options:
|
|
||||||
|
|
||||||
```
|
|
||||||
$ tusd -help
|
|
||||||
-azure-blob-access-tier string
|
|
||||||
Blob access tier when uploading new files (possible values: archive, cool, hot, '')
|
|
||||||
-azure-container-access-type string
|
|
||||||
Access type when creating a new container if it does not exist (possible values: blob, container, '')
|
|
||||||
-azure-endpoint string
|
|
||||||
Custom Endpoint to use for Azure BlockBlob Storage (requires azure-storage to be pass)
|
|
||||||
-azure-object-prefix string
|
|
||||||
Prefix for Azure object names
|
|
||||||
-azure-storage string
|
|
||||||
Use Azure BlockBlob Storage with this container name as a storage backend (requires the AZURE_STORAGE_ACCOUNT and AZURE_STORAGE_KEY environment variable to be set)
|
|
||||||
-base-path string
|
|
||||||
Basepath of the HTTP server (default "/files/")
|
|
||||||
-behind-proxy
|
|
||||||
Respect X-Forwarded-* and similar headers which may be set by proxies
|
|
||||||
-cpuprofile string
|
|
||||||
write cpu profile to file
|
|
||||||
-expose-metrics
|
|
||||||
Expose metrics about tusd usage (default true)
|
|
||||||
-gcs-bucket string
|
|
||||||
Use Google Cloud Storage with this bucket as storage backend (requires the GCS_SERVICE_ACCOUNT_FILE environment variable to be set)
|
|
||||||
-gcs-object-prefix string
|
|
||||||
Prefix for GCS object names
|
|
||||||
-hooks-dir string
|
|
||||||
Directory to search for available hooks scripts
|
|
||||||
-hooks-enabled-events string
|
|
||||||
Comma separated list of enabled hook events (e.g. post-create,post-finish). Leave empty to enable default events (default "pre-create,post-create,post-receive,post-terminate,post-finish")
|
|
||||||
-hooks-grpc string
|
|
||||||
An gRPC endpoint to which hook events will be sent to
|
|
||||||
-hooks-grpc-backoff int
|
|
||||||
Number of seconds to wait before retrying each retry (default 1)
|
|
||||||
-hooks-grpc-retry int
|
|
||||||
Number of times to retry on a server error or network timeout (default 3)
|
|
||||||
-hooks-http string
|
|
||||||
An HTTP endpoint to which hook events will be sent to
|
|
||||||
-hooks-http-backoff int
|
|
||||||
Number of seconds to wait before retrying each retry (default 1)
|
|
||||||
-hooks-http-forward-headers string
|
|
||||||
List of HTTP request headers to be forwarded from the client request to the hook endpoint
|
|
||||||
-hooks-http-retry int
|
|
||||||
Number of times to retry on a 500 or network timeout (default 3)
|
|
||||||
-hooks-plugin string
|
|
||||||
Path to a Go plugin for loading hook functions (only supported on Linux and macOS; highly EXPERIMENTAL and may BREAK in the future)
|
|
||||||
-hooks-stop-code int
|
|
||||||
Return code from post-receive hook which causes tusd to stop and delete the current upload. A zero value means that no uploads will be stopped
|
|
||||||
-host string
|
|
||||||
Host to bind HTTP server to (default "0.0.0.0")
|
|
||||||
-max-size int
|
|
||||||
Maximum size of a single upload in bytes
|
|
||||||
-metrics-path string
|
|
||||||
Path under which the metrics endpoint will be accessible (default "/metrics")
|
|
||||||
-port string
|
|
||||||
Port to bind HTTP server to (default "1080")
|
|
||||||
-s3-bucket string
|
|
||||||
Use AWS S3 with this bucket as storage backend (requires the AWS_ACCESS_KEY_ID, AWS_SECRET_ACCESS_KEY and AWS_REGION environment variables to be set)
|
|
||||||
-s3-disable-content-hashes
|
|
||||||
Disable the calculation of MD5 and SHA256 hashes for the content that gets uploaded to S3 for minimized CPU usage (experimental and may be removed in the future)
|
|
||||||
-s3-disable-ssl
|
|
||||||
Disable SSL and only use HTTP for communication with S3 (experimental and may be removed in the future)
|
|
||||||
-s3-endpoint string
|
|
||||||
Endpoint to use S3 compatible implementations like minio (requires s3-bucket to be pass)
|
|
||||||
-s3-object-prefix string
|
|
||||||
Prefix for S3 object names
|
|
||||||
-s3-part-size int
|
|
||||||
Size in bytes of the individual upload requests made to the S3 API. Defaults to 50MiB (experimental and may be removed in the future) (default 52428800)
|
|
||||||
-s3-transfer-acceleration
|
|
||||||
Use AWS S3 transfer acceleration endpoint (requires -s3-bucket option and Transfer Acceleration property on S3 bucket to be set)
|
|
||||||
-show-greeting
|
|
||||||
Show the greeting message (default true)
|
|
||||||
-timeout int
|
|
||||||
Read timeout for connections in milliseconds. A zero value means that reads will not timeout (default 6000)
|
|
||||||
-tls-certificate string
|
|
||||||
Path to the file containing the x509 TLS certificate to be used. The file should also contain any intermediate certificates and the CA certificate.
|
|
||||||
-tls-key string
|
|
||||||
Path to the file containing the key for the TLS certificate.
|
|
||||||
-tls-mode string
|
|
||||||
Specify which TLS mode to use; valid modes are tls13, tls12, and tls12-strong. (default "tls12")
|
|
||||||
-unix-sock string
|
|
||||||
If set, will listen to a UNIX socket at this location instead of a TCP socket
|
|
||||||
-upload-dir string
|
|
||||||
Directory to store uploads in (default "./data")
|
|
||||||
-verbose
|
|
||||||
Enable verbose logging output (default true)
|
|
||||||
-version
|
|
||||||
Print tusd version information
|
|
||||||
|
|
||||||
```
|
|
||||||
|
|
Loading…
Reference in New Issue