mirror of
				https://github.com/seaweedfs/seaweedfs.git
				synced 2025-10-21 04:57:24 +08:00 
			
		
		
		
	locks for data racing
This commit is contained in:
		| @@ -29,7 +29,6 @@ var bufPool = sync.Pool{ | |||||||
| } | } | ||||||
|  |  | ||||||
| func (fs *FilerServer) uploadReaderToChunks(w http.ResponseWriter, r *http.Request, reader io.Reader, chunkSize int32, fileName, contentType string, contentLength int64, so *operation.StorageOption) ([]*filer_pb.FileChunk, hash.Hash, int64, error, []byte) { | func (fs *FilerServer) uploadReaderToChunks(w http.ResponseWriter, r *http.Request, reader io.Reader, chunkSize int32, fileName, contentType string, contentLength int64, so *operation.StorageOption) ([]*filer_pb.FileChunk, hash.Hash, int64, error, []byte) { | ||||||
| 	var fileChunks []*filer_pb.FileChunk |  | ||||||
|  |  | ||||||
| 	md5Hash := md5.New() | 	md5Hash := md5.New() | ||||||
| 	var partReader = ioutil.NopCloser(io.TeeReader(reader, md5Hash)) | 	var partReader = ioutil.NopCloser(io.TeeReader(reader, md5Hash)) | ||||||
| @@ -41,6 +40,8 @@ func (fs *FilerServer) uploadReaderToChunks(w http.ResponseWriter, r *http.Reque | |||||||
| 	var wg sync.WaitGroup | 	var wg sync.WaitGroup | ||||||
| 	var bytesBufferCounter int64 | 	var bytesBufferCounter int64 | ||||||
| 	bytesBufferLimitCond := sync.NewCond(new(sync.Mutex)) | 	bytesBufferLimitCond := sync.NewCond(new(sync.Mutex)) | ||||||
|  | 	var fileChunks []*filer_pb.FileChunk | ||||||
|  | 	var fileChunksLock sync.Mutex | ||||||
| 	for { | 	for { | ||||||
|  |  | ||||||
| 		// need to throttle used byte buffer | 		// need to throttle used byte buffer | ||||||
| @@ -94,7 +95,9 @@ func (fs *FilerServer) uploadReaderToChunks(w http.ResponseWriter, r *http.Reque | |||||||
| 				uploadErr = toChunkErr | 				uploadErr = toChunkErr | ||||||
| 			} | 			} | ||||||
| 			if chunk != nil { | 			if chunk != nil { | ||||||
|  | 				fileChunksLock.Lock() | ||||||
| 				fileChunks = append(fileChunks, chunk) | 				fileChunks = append(fileChunks, chunk) | ||||||
|  | 				fileChunksLock.Unlock() | ||||||
| 				glog.V(4).Infof("uploaded %s chunk %d to %s [%d,%d)", fileName, len(fileChunks), chunk.FileId, offset, offset+int64(chunk.Size)) | 				glog.V(4).Infof("uploaded %s chunk %d to %s [%d,%d)", fileName, len(fileChunks), chunk.FileId, offset, offset+int64(chunk.Size)) | ||||||
| 			} | 			} | ||||||
| 		}(chunkOffset) | 		}(chunkOffset) | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user
	 Chris Lu
					Chris Lu