Popularity
4.2
Growing
Activity
8.4
Growing
89
5
9
Description
An application-oriented unified storage layer for Golang.
Programming language: Go
License: Apache License 2.0
Latest version: v2.0.0
go-storage alternatives and similar packages
Based on the "Files" category.
Alternatively, view storage alternatives based on common mentions on social networks and blogs.
-
vfs
A pluggable, extensible, and opinionated set of filesystem functionality for Go across a number of filesystem types such as os, S3, and GCS. -
go-exiftool
Go bindings for ExifTool, the well-known library used to extract as much metadata as possible (EXIF, IPTC, ...) from files (pictures, PDF, office, ...). -
gut/yos
Simple and reliable package for file operations like copy/move/diff/list on files, directories and symbolic links. -
fileconversion
A Go library to convert various file formats to plaintext and provide related functions -
go-staticfiles
Collects assets (css, js, images...) from a different locations, tags file names with a hash for easy versioning and aggressive caching.
Scout APM: A developer's best friend. Try free for 14-days
Scout APM uses tracing logic that ties bottlenecks to source code so you know the exact line of code causing performance issues and can get back to building a great product faster.
Sponsored
scoutapm.com
Do you think we are missing an alternative of go-storage or a related project?
README
storage
An application-oriented unified storage layer for Golang.
Goal
- Production ready
- High performance
- Vendor agnostic
Features
Widely services support
- [azblob](./services/azblob/): Azure Blob storage
- [cos](./services/cos/): Tencent Cloud Object Storage
- [dropbox](./services/dropbox/): Dropbox
- [fs](./services/fs/): Local file system
- [gcs](./services/gcs/): Google Cloud Storage
- [kodo](./services/kodo/): qiniu kodo
- [oss](./services/oss/): Aliyun Object Storage
- [qingstor](./services/qingstor/): QingStor Object Storage
- [s3](./services/s3/): Amazon S3
- [uss](./services/uss/): UPYUN Storage Service
Servicer operation support
- List: list all Storager in service
- Get: get a Storager via name
- Create: create a Storager
- Delete: delete a Storager
Storager operation support
Basic operations
- Metadata: get storager's metadata
- Read: read file content
- Write: write content into file
- Stat: get file's metadata
- Delete: delete a file or directory
Extended operations
- Copy: copy a file inside storager
- Move: move a file inside storager
- Reach: generate a public accessible url
- Statistical: get storage service's statistics
Multiple list style support
- ListDir: list files and directories under a directory
- ListPrefix: list files under a prefix
Segment/Multipart support
- ListPrefixSegment: list segments under a prefix
- InitIndexSegment: initiate an index type segment
- WriteIndexSegment: write content into an index type segment
- CompleteSegment: complete a segment to create a file
- AbortSegment: abort a segment
File metadata support
Required metadata
id
: unique key in servicename
: relative path towards service's work dirsize
: size of this objectupdated_at
: last update time of this object
Optional metadata
content-md5
: md5 digest as defined in rfc2616content-type
: media type as defined in rfc2616etag
: entity tag as defined in rfc2616storage-class
: object's storage class as defined in [storage proposal](./docs/design/8-normalize-metadata-storage-class.md)
Quick Start
import (
"log"
"github.com/Xuanwo/storage"
"github.com/Xuanwo/storage/coreutils"
"github.com/Xuanwo/storage/types/pairs"
)
// Init a service.
store, err := coreutils.OpenStorager("fs", pairs.WithWorkDir("/tmp"))
if err != nil {
log.Fatalf("service init failed: %v", err)
}
// Use Storager API to maintain data.
r, err := store.Read("path/to/file")
if err != nil {
log.Printf("storager read: %v", err)
}
*Note that all licence references and agreements mentioned in the go-storage README section above
are relevant to that project's source code only.