Data placement changes
이번 릴리즈는 더 좋은 다른 배포 방법을 이용하여 처리하기 위해 Swift 데이터 배치에 몇가지 중요한 변화가 있었습니다. 첫째, 균형이 깨진 ring
을 실패한 도메인에서 더 나은 분산 처리를위해 이동이 적은 파티션으로 이동시킵니다. 또 균형이 깨진 ring
이 있을때, 비어있는 (파티션 크기가 0인) 장치는 더이상 다시 균형을 맞춘후 파티션을 유지하지 않습니다.
This release has several major changes to data placement in Swift in order to better handle different deployment patterns. First, with an unbalance-able ring, less partitions will move if the movement doesn’t result in any better dispersion across failure domains. Also, empty (partition weight of zero) devices will no longer keep partitions after rebalancing when there is an unbalance-able ring.
둘째, “overload”라는 계념이 ring
에 추가되었습니다. 이것은 클러스터에 문제가 있을 경우, 서버, zone, region 사이서 적게 데이터가 움직인 균형이 깨진 클러스터와 (일반적인 장치 크기에 허용되는 것보다도 더) 작은 몇가지 추가 파티션에서 사용할 수 있습니다.
Second, the notion of “overload” has been added to Swfit’s rings. This allows devices to take some extra partitions (more than would normally be allowed by the device weight) so that smaller and unbalanced clusters will have less data movement between servers, zones, or regions if there is a failure in the cluster.
마지막으로 ring
에 “dispersion”라 불리우는 새로운 메트릭스를 가집니다. 이것은 동일 클러스터 안에 많은 복제본이 있거나 동일한 서버에 배치된 두 복재본의 링에대한 파티션의 비율입니다. 그 파티션은 분산 메트릭으로 계산됩니다. 작은 값일 수록 더 좋으며, 더 적절한 “overload” 값을 찾기 위해 사용될 수 있습니다.
Finally, rings have a new metric called “dispersion”. This is the percentage of partitions in the ring that have too many replicas in a cluster but two replicas for a partition get placed onto the same server, that partition will count towards the dispersion metric. A lower value is better, and the value can be used to find the proper value for “overload”.
overload
와 분산 메트릭스는 swift-ring-build
CLI 툴에서 사용할 수 있습니다.
The overload and dispersion metrics have been exposed in the swfit-ring-build CLI tools.
자세한 내용은 The Rings 에서 어떻게 데이터 배치 작업을 하는지 확인하십시오.
See The Rings for more info on how data placement works now.
out-of-sync
, out-of-date
콘태이너들의 복제애대한 기능을 향상시켰습니다.Improve replication of large out-of-sync, out-of-date contatiners.
log_to_console
구성 옵션(기본 값 False
)과 swift-drive-audit
의 콘솔 로깅을 추가하였습니다.Added console logging to swfit-drive-audit with a new log_to_console config option (default False).
Optimize replication when a device and/or partition is specified.
Fix dynamic large object manifests getting versioned. This was not intended and did not work. Now it is properly prevented.
Fix the GET’s response code when there is a missing segment in a large object manifest.
sysmeta
를 이용하여 ratelimit
미들웨어 내에서 블랙/화이트 리스트를 변경할 수 있습니다. 대신 구성 옵션을 이용하여, ratelimiting
에 대한 화이트 리스트 또는 블랙 리스트에 계정에서 “X-Account-Sysmeta-Global-Write-Ratelimit: WHITELIST” 또는 “X-Account-Sysmeta-Global-Write-Ratelimit: BLACKLIST” 오퍼레이터를 설정할 수 있습니다. 노트: 기존 구성 옵션은 계속 작동됩니다.Change black/white listing in retelimit middleware to use sysmeta. Instead of using the config option, operators can set “X-Account-Sysmeta-Global-Write-Ratelimit: WHITELIST” or “X-Account-Sysmeta-Global-Write-Ratelimit: BLACKLIST” on an account to whitelist or blacklist it for ratelimiting. Note: the existing config options continue to work.
TCP_NODELAY
를 사용합니다.Use TCP_NODELAY on outgoing connections.
object-replicator
시작 시간을 향상시켰습니다.Improve object-replicator startup time.
OPTIONS
항목을 제공합니다.Implement OPTIONS verb for storage nodes.
Various other minor bug fixs and improvements.