Description: rados/cephadm/workunits/{0-distro/ubuntu_22.04 agent/off mon_election/classic task/test_host_drain}

Log: http://qa-proxy.ceph.com/teuthology/pdhange-2024-02-22_01:13:10-rados-wip-pdhange-testing1-distro-default-smithi/7570410/teuthology.log

  • log_href: http://qa-proxy.ceph.com/teuthology/pdhange-2024-02-22_01:13:10-rados-wip-pdhange-testing1-distro-default-smithi/7570410/teuthology.log
  • archive_path: /home/teuthworker/archive/pdhange-2024-02-22_01:13:10-rados-wip-pdhange-testing1-distro-default-smithi/7570410
  • description: rados/cephadm/workunits/{0-distro/ubuntu_22.04 agent/off mon_election/classic task/test_host_drain}
  • duration: 0:24:08
  • email:
  • failure_reason:
  • flavor: default
  • job_id: 7570410
  • kernel:
    • kdb: True
    • sha1: distro
  • last_in_suite: False
  • machine_type: smithi
  • name: pdhange-2024-02-22_01:13:10-rados-wip-pdhange-testing1-distro-default-smithi
  • nuke_on_error: True
  • os_type: ubuntu
  • os_version: 22.04
  • overrides:
    • admin_socket:
      • branch: wip-pdhange-testing1
    • ceph:
      • conf:
        • global:
          • mon election default strategy: 1
        • mgr:
          • debug mgr: 20
          • debug ms: 1
          • mgr/cephadm/use_agent: False
        • mon:
          • debug mon: 20
          • debug ms: 1
          • debug paxos: 20
        • osd:
          • debug ms: 1
          • debug osd: 20
      • flavor: default
      • log-ignorelist:
        • \(MDS_ALL_DOWN\)
        • \(MDS_UP_LESS_THAN_MAX\)
        • MON_DOWN
      • sha1: dbe7fcec16eddee6239e4dd68c4d0203c7df6461
    • ceph-deploy:
      • conf:
        • client:
          • log file: /var/log/ceph/ceph-$name.$pid.log
        • mon:
          • osd default pool size: 2
    • install:
      • ceph:
        • flavor: default
        • sha1: dbe7fcec16eddee6239e4dd68c4d0203c7df6461
    • workunit:
      • branch: wip-pdhange-testing1
      • sha1: dbe7fcec16eddee6239e4dd68c4d0203c7df6461
  • owner: scheduled_pdhange@teuthology
  • pid:
  • roles:
    • ['host.a', 'mon.a', 'mgr.a', 'osd.0', 'osd.1']
    • ['host.b', 'mon.b', 'mgr.b', 'osd.2', 'osd.3']
    • ['host.c', 'mon.c', 'osd.4', 'osd.5']
  • sentry_event:
  • status: pass
  • success: True
  • branch: wip-pdhange-testing1
  • seed:
  • sha1: dbe7fcec16eddee6239e4dd68c4d0203c7df6461
  • subset:
  • suite:
  • suite_branch: wip-pdhange-testing1
  • suite_path:
  • suite_relpath:
  • suite_repo:
  • suite_sha1: dbe7fcec16eddee6239e4dd68c4d0203c7df6461
  • targets:
    • smithi028.front.sepia.ceph.com: ecdsa-sha2-nistp256 AAAAE2VjZHNhLXNoYTItbmlzdHAyNTYAAAAIbmlzdHAyNTYAAABBBDQ4W5shKf1EBI3COfo0vcZBlQOHdvCV9hXd0mMKGuAhWirp7yrxmvOOY9fpv9pb3p1/d7xFYBs91nXrcc4zeS8=
    • smithi081.front.sepia.ceph.com: ecdsa-sha2-nistp256 AAAAE2VjZHNhLXNoYTItbmlzdHAyNTYAAAAIbmlzdHAyNTYAAABBBNIIXb06emzgEFo9Mg4sw5Nz5G75jiy2uT44huvv1GcD4iYtExpxe6EEsStWqlbC7AObZE9Bg2SYY0kG7jPsiuw=
    • smithi136.front.sepia.ceph.com: ecdsa-sha2-nistp256 AAAAE2VjZHNhLXNoYTItbmlzdHAyNTYAAAAIbmlzdHAyNTYAAABBBFYUJHLC+mylNR87VzvhHulZ/ZeK3OvREfTTRXHL1Y0hWYrWnwzS3KMmGW306OO3MfyuV3IGr7epv3TIY2hLLVA=
  • tasks:
    • internal.check_packages:
    • internal.buildpackages_prep:
    • internal.save_config:
    • internal.check_lock:
    • internal.add_remotes:
    • console_log:
    • internal.connect:
    • internal.push_inventory:
    • internal.serialize_remote_roles:
    • internal.check_conflict:
    • internal.check_ceph_data:
    • internal.vm_setup:
    • kernel:
      • kdb: True
      • sha1: distro
    • internal.base:
    • internal.archive_upload:
    • internal.archive:
    • internal.coredump:
    • internal.sudo:
    • internal.syslog:
    • internal.timer:
    • pcp:
    • selinux:
    • ansible.cephlab:
    • clock:
    • install:
    • cephadm:
    • cephadm.shell:
      • host.a:
        • set -ex HOSTNAMES=$(ceph orch host ls --format json | jq -r '.[] | .hostname') for host in $HOSTNAMES; do # find the hostname for "host.c" which will have no mgr HAS_MGRS=$(ceph orch ps --hostname ${host} --format json | jq 'any(.daemon_type == "mgr")') if [ "$HAS_MGRS" == "false" ]; then HOST_C="${host}" fi done # One last thing to worry about before draining the host # is that the teuthology test tends to put the explicit # hostnames in the placement for the mon service. # We want to make sure we can drain without providing # --force and there is a check for the host being removed # being listed explicitly in the placements. Therefore, # we should remove it from the mon placement. ceph orch ls mon --export > mon.yaml sed /"$HOST_C"/d mon.yaml > mon_adjusted.yaml ceph orch apply -i mon_adjusted.yaml # now drain that host ceph orch host drain $HOST_C --zap-osd-devices # wait for drain to complete HOST_C_DAEMONS=$(ceph orch ps --hostname $HOST_C) while [ "$HOST_C_DAEMONS" != "No daemons reported" ]; do sleep 15 HOST_C_DAEMONS=$(ceph orch ps --hostname $HOST_C) done # we want to check the ability to remove the host from # the CRUSH map, so we should first verify the host is in # the CRUSH map. ceph osd getcrushmap -o compiled-crushmap crushtool -d compiled-crushmap -o crushmap.txt CRUSH_MAP=$(cat crushmap.txt) if ! grep -q "$HOST_C" <<< "$CRUSH_MAP"; then printf "Expected to see $HOST_C in CRUSH map. Saw:\n\n$CRUSH_MAP" exit 1 fi # If the drain was successful, we should be able to remove the # host without force with no issues. If there are still daemons # we will get a response telling us to drain the host and a # non-zero return code ceph orch host rm $HOST_C --rm-crush-entry # verify we've successfully removed the host from the CRUSH map sleep 30 ceph osd getcrushmap -o compiled-crushmap crushtool -d compiled-crushmap -o crushmap.txt CRUSH_MAP=$(cat crushmap.txt) if grep -q "$HOST_C" <<< "$CRUSH_MAP"; then printf "Saw $HOST_C in CRUSH map after it should have been removed.\n\n$CRUSH_MAP" exit 1 fi
  • teuthology_branch: main
  • verbose: True
  • pcp_grafana_url:
  • priority:
  • user:
  • queue:
  • posted: 2024-02-22 01:15:01
  • started: 2024-02-22 01:47:44
  • updated: 2024-02-22 02:21:24
  • status_class: success
  • runtime: 0:33:40
  • wait_time: 0:09:32