diff --git a/ceph-osd/Chart.yaml b/ceph-osd/Chart.yaml index 997c495fb..adf2b2ac5 100644 --- a/ceph-osd/Chart.yaml +++ b/ceph-osd/Chart.yaml @@ -15,6 +15,6 @@ apiVersion: v1 appVersion: v1.0.0 description: OpenStack-Helm Ceph OSD name: ceph-osd -version: 0.1.8 +version: 0.1.9 home: https://github.com/ceph/ceph ... diff --git a/ceph-osd/templates/bin/_post-apply.sh.tpl b/ceph-osd/templates/bin/_post-apply.sh.tpl index e47c041bf..b832f8b51 100644 --- a/ceph-osd/templates/bin/_post-apply.sh.tpl +++ b/ceph-osd/templates/bin/_post-apply.sh.tpl @@ -86,6 +86,7 @@ function wait_for_pgs () { echo "#### Start: Checking pgs ####" pgs_ready=0 + pgs_inactive=0 query='map({state: .state}) | group_by(.state) | map({state: .[0].state, count: length}) | .[] | select(.state | contains("active") | not)' if [[ $(ceph tell mon.* version | egrep -q "nautilus"; echo $?) -eq 0 ]]; then @@ -96,9 +97,14 @@ function wait_for_pgs () { while [[ $pgs_ready -lt 3 ]]; do pgs_state=$(ceph --cluster ${CLUSTER} pg ls -f json | jq -c "${query}") if [[ $(jq -c '. | select(.state | contains("peering") | not)' <<< "${pgs_state}") ]]; then - # If inactive PGs aren't peering, fail - echo "Failure, found inactive PGs that aren't peering" - exit 1 + if [[ pgs_inactive -gt 10 ]]; then + # If inactive PGs aren't peering, fail + echo "Failure, found inactive PGs that aren't peering" + exit 1 + fi + (( pgs_inactive+=1 )) + else + pgs_inactive=0 fi if [[ "${pgs_state}" ]]; then pgs_ready=0