minio/docs/zh_CN/shared-backend
Harshavardhana 76e2713ffe
fix: use buffers only when necessary for io.Copy() (#11229)
Use separate sync.Pool for writes/reads

Avoid passing buffers for io.CopyBuffer()
if the writer or reader implement io.WriteTo or io.ReadFrom
respectively then its useless for sync.Pool to allocate
buffers on its own since that will be completely ignored
by the io.CopyBuffer Go implementation.

Improve this wherever we see this to be optimal.

This allows us to be more efficient on memory usage.
```
   385  // copyBuffer is the actual implementation of Copy and CopyBuffer.
   386  // if buf is nil, one is allocated.
   387  func copyBuffer(dst Writer, src Reader, buf []byte) (written int64, err error) {
   388  	// If the reader has a WriteTo method, use it to do the copy.
   389  	// Avoids an allocation and a copy.
   390  	if wt, ok := src.(WriterTo); ok {
   391  		return wt.WriteTo(dst)
   392  	}
   393  	// Similarly, if the writer has a ReadFrom method, use it to do the copy.
   394  	if rt, ok := dst.(ReaderFrom); ok {
   395  		return rt.ReadFrom(src)
   396  	}
```

From readahead package
```
// WriteTo writes data to w until there's no more data to write or when an error occurs.
// The return value n is the number of bytes written.
// Any error encountered during the write is also returned.
func (a *reader) WriteTo(w io.Writer) (n int64, err error) {
	if a.err != nil {
		return 0, a.err
	}
	n = 0
	for {
		err = a.fill()
		if err != nil {
			return n, err
		}
		n2, err := w.Write(a.cur.buffer())
		a.cur.inc(n2)
		n += int64(n2)
		if err != nil {
			return n, err
		}
```
2021-01-06 09:36:55 -08:00
..

MinIO共享后端存储快速入门Slack Docker Pulls

MinIO共享模式可以让你使用一个NAS 做为多个MinIO服务的存储后端。我我们在设计时已经对多个MinIO服务之间的同步做了很多的处理。更多MinIO共享模式的设计文档请访问这里.

MinIO共享模式是为了解决在真实场景中存在的一些问题而且不需要做额外的配置。 如果你有下列需求则可以考虑MinIO共享模式

  • 你已经买了NAS设备并想在存储层使用MinIO来增加S3兼容。
  • 你的应用架构要求你使用带有S3接口的NAS。
  • 你的应用存在亚历山大的流量你想给你的NAS设备增加一个有负载均衡能力的S3兼容的服务。

在多个共享模式的MinIO服务前面加一层代理你很容易就能获得一个高可用负载均衡AWS S3兼容的存储系统。

开始

如果你知道怎么部署单机MinIO,共享模式的部署和运行也是一样一样的。

1. 前提条件

安装MinIO - MinIO快速入门.

2. 在共享后端存储上运行MinIO

为了让MinIO在共享后端上运行起来你需要启动多个MinIO服务这些服务指向同一个后端存储。下面我们就来讲解如何设置。

注意

  • 使用共享存储的所有MinIO节点需要有相同的access key和secret key。为了做到这一点我们在所有节点上将access key和secret key export成环境变量然后再去启动MinIO服务。
  • 下面出现的存储路径都是为了演示目的,在真实环境中使用时,你应该替换成你真实要用的路径。

MinIO shared mode on Ubuntu 16.04 LTS.

你需要将文件夹指向共享存储,比如/path/to/nfs-volume然后在所有MinIO节点上运行下面的命令。

export MINIO_ROOT_USER=<ACCESS_KEY>
export MINIO_ROOT_PASSWORD=<SECRET_KEY>
minio gateway nas /path/to/nfs-volume

MinIO shared mode on Windows 2012 Server

你需要将文件夹指向共享存储,比如\\remote-server\smb. 然后在所有MinIO节点上运行下面的命令。

set MINIO_ROOT_USER=my-username
set MINIO_ROOT_PASSWORD=my-password
minio.exe gateway nas \\remote-server\smb\export

Windows提示

如果一个远程的volume, 比如\\remote-server\smb挂载成一个硬盘, 比如M:\. 你可以使用net use命令将这块盘映射到一个文件夹。

set MINIO_ROOT_USER=my-username
set MINIO_ROOT_PASSWORD=my-password
net use m: \\remote-server\smb\export /P:Yes
minio.exe gateway nas M:\export

3. 验证

为了验证部署是否成功,可能通过浏览器或者mc访问MinIO。你应该可以从各个MinIO节点访问上传的文件。

了解更多