s3gw

command module
v0.0.0-...-6a2407b Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Apr 25, 2024 License: Apache-2.0 Imports: 17 Imported by: 0

README

s3gw

s3gw is a minimal gateway implementation for Ceph RGW API.

Environment variables

  • BUCKET_HOST: object bucket API endpoint host
  • BUCKET_PORT: object bucket API endpoint port
  • BUCKET_NAME: object bucket name
  • BUCKET_REGION: object bucket region
  • AWS_ACCESS_KEY_ID: access key ID
  • AWS_SECRET_ACCESS_KEY: access key secret

BUCKET_HOST, BUCKET_NAME, AWS_ACCESS_KEY_ID and AWS_SECRET_ACCESS_KEY are required. BUCKET_PORT and BUCKET_REGION are optional.

Options

  • --listen: addr:port to listen to (passed to http.Server.Addr)
  • --use-path-style: use path-style bucket name
  • --hosts-allow: subnets allowed to access to this gw, separated by comma
  • --hosts-deny: subnets denied to access to this gw, separated by comma
    • note: --hosts-allow and --hosts-deny control access to /bucket/ only. /health and /metrics accept access from everywhere.

Supported API

Unless otherwise stated, only GET method is supported. Other methods may return 405 Method not Allowed or work as of GET.

/health: health endpoint

It returns the health status of this GW.

note: it does not return the health status of the upstream S3 API.

/metrics: metrics endpoint

In addition to standard promhttp metrics which begin with go_ and promhttp_, it returns the following metrics:

  • s3gw_request_count_total counter
  • s3gw_request_duration_seconds histogram

both of those metrics have the following labels:

  • code: HTTP status code
  • method: HTTP request method
  • handler: request handler type. "list" for bucket objects listing requests or "object" for bucket objects operation.
/bucket/: bucket objects listing

It returns the list of objects stored in the bucket as the following JSON format:

{
    "objects": [
        {
            "key": "some_object",
            "size": 123,
            "last-modified": "2023-12-03T04:05:06.789Z",
            "etag": "\"0123456789abcdef-12\""
        },
        {
            "key": "another_object",
            "size": 789,
            "last-modified": "2023-09-08T07:06:05.432Z",
            "etag": "\"fedcba9876543210-98\""
        },
    ]
}

If there are no objects, objects is empty array [], not null.

/bucket/<object-key>: bucket objects operation

As with S3 API, <object-key> is not a path-style string. i.e. /bucket/foo and /bucket//foo represent different objects.

GET/PUT/DELETE methods

You can GET/PUT/DELETE objects.

In case of GET method, the following HTTP response header fields are returned:

  • Content-Length
  • ETag
  • Last-Modified

Restrictions

This software is originally designed to proxy requests to Ceph RGW. It may not work with real Amazon S3.

Documentation

The Go Gopher

There is no documentation for this package.

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL