User Tools

Site Tools


devplayground

Differences

This shows you the differences between two versions of the page.

Link to this comparison view

Both sides previous revision Previous revision
Next revision
Previous revision
devplayground [2025/06/10 16:25]
pdonnell [Configuring CephFS Mounts]
devplayground [2025/12/17 22:16] (current)
pdonnell [Configuring CephFS Mounts]
Line 52: Line 52:
 ==== Configuring CephFS Mounts ==== ==== Configuring CephFS Mounts ====
  
-The following ​script ​can be run to setup CephFS mounts on a new developer playground machines:+The following ​ansible playbook ​can be run to setup CephFS mounts on a new developer playground machines:
  
 <​code>​ <​code>​
-#!/bin/bash+--- 
 +- name: Configure Ceph Client and Mounts 
 +  hosts: all 
 +  become: true 
 +  vars: 
 +    admin_node: "​doli01.front.sepia.ceph.com"​ 
 +    ceph_conf_path:​ "/etc/ceph/​ceph.conf"​ 
 +    keyring_path:​ "/​etc/​ceph/​client.sepian.keyring"​ 
 +    client_keyring_path:​ "/​etc/​ceph/​keyring"​ 
 +    secret_path:​ "/​etc/​ceph/​client.sepian.secret"​ 
 +    mounts: 
 +      - { path: "/​teuthology",​ fstype: "​ceph",​ src: "/​teuthology-archive",​ mds_namespace:​ "​teuthology",​ opts: "​_netdev,​ro"​ } 
 +      - { path: "/​scratch",​ fstype: "​ceph",​ src: "/",​ mds_namespace:​ "​scratch",​ opts: "​_netdev"​ }
  
-HOST="$1"+  tasks: 
 +    - name: "1. Gather Ceph configuration using raw commands" 
 +      delegate_to:​ "{{ admin_node }}" 
 +      block: 
 +        - name: "​▶️ Get LRC fsid"​ 
 +          ansible.builtin.raw:​ > 
 +            env CEPH_KEYRING={{ keyring_path }} ceph --id sepian fsid 
 +          register: ceph_fsid 
 +          changed_when:​ false
  
-function run { +        - name: "▶️ Generate minimal ceph.conf (raw)" 
-  printf '​%s\n' ​"$*" >&2 +          ansible.builtin.raw: ​
-  "​$@"​ +            env CEPH_KEYRING={{ keyring_path ​}} ceph --id sepian config generate-minimal-conf 
-}+          register: ceph_conf_content 
 +          changed_when:​ false
  
-function mssh { +        ​name: "▶️ Fetch Ceph keyring (raw)
-  run ssh "​$HOST"​ -- "$*+          ​ansible.builtin.raw:​ > 
-}+            cat {{ keyring_path ​}
 +          register: keyring_content 
 +          changed_when:​ false
  
-ADMIN_NODE=reesi003.front.sepia.ceph.com+        - name: "​▶️ Generate client secret (raw)"​ 
 +          ansible.builtin.raw: > 
 +            ​ceph-authtool {{ keyring_path }} -n client.sepian -p 
 +          register: secret_content 
 +          changed_when:​ false
  
-mssh echo hi || exit 1+        - name: "​▶️ Get Ceph monitor list (raw)"​ 
 +          ansible.builtin.raw:​ > 
 +            env CEPH_KEYRING={{ keyring_path }} ceph --id sepian mon dump --format json 2>/​dev/​null ​jq -r '​[.mons[] ​.public_addrs.addrvec[] | select(.type=="​v1"​).addr] | join(","​)'​ 
 +          register: mon_hosts 
 +          changed_when:​ false
  
-mssh sudo mkdir -p -m 755 /etc/ceph +    ​name: "2. Configure Ceph client files
-ssh "$ADMIN_NODE" ​'env CEPH_KEYRING=/​etc/​ceph/​client.sepian.keyring ceph --id sepian config generate-minimal-conf'​ | mssh sudo tee /​etc/​ceph/​ceph.conf +      ​block:​ 
-mssh sudo chmod 644 /​etc/​ceph/​ceph.conf +        - name: "▶️ Ensure ​/​etc/​ceph ​directory exists"​ 
-ssh "$ADMIN_NODE"​ '​cat ​/etc/ceph/​client.sepian.keyring'​ | mssh sudo tee /​etc/​ceph/​client.sepian.keyring +          ​ansible.builtin.file: 
-mssh sudo chmod 644 /​etc/​ceph/​client.sepian.keyring +            ​path: ​"/​etc/​ceph
-ssh "$ADMIN_NODE"​ '​ceph-authtool ​/etc/ceph/​client.sepian.keyring -n client.sepian -p' ​| mssh sudo tee /​etc/​ceph/​client.sepian.secret +            state: directory 
-mssh sudo chmod 600 /​etc/​ceph/​client.sepian.secret+            mode: '0755'
  
-MONS=$(ssh ​"$ADMIN_NODE"​ 'env CEPH_KEYRING=/​etc/​ceph/client.sepian.keyring ceph --id sepian mon dump --format json | jq -r '​\''​[.mons[] | .public_addrs.addrvec[] | select(.type=="v1"​).addr] | join(",")'\')+        - name: "▶️ Deploy ​ceph.conf"​ 
 +          ansible.builtin.copy: 
 +            content: "{{ ceph_conf_content.stdout }}" 
 +            dest: "{{ ceph_conf_path }}" 
 +            mode: '0644'
  
-function genmount { +        - name: "​▶️ Create temporary file for keyring import"​ 
-  local secret=$(mssh sudo cat /​etc/​ceph/​client.sepian.secret) +          ​ansible.builtin.tempfile: 
-  mssh '​D="'"​$2"'";​ if ! [ -d "​$D"​ ]; then sudo mkdir -p -- "​$D"​ ; sudo chmod 000 -- "​$D"​ ; sudo chattr +i -- "​$D"​ ; fi' +            ​state:​ file 
-  mssh sudo sed -i "/​mds_namespace=$3/​d"​ /etc/fstab +            ​suffix:​ .keyring 
-  ​printf '%s:%s\t%s\tceph\tname=sepian,​secret=%s,​mds_namespace=%s,​_netdev%s\t0\t2\n'​ "​$MONS"​ "​$1"​ "​$2"​ "​$secret"​ "​$3"​ "​$4"​ | mssh sudo tee -a /​etc/​fstab +          ​registertmp_keyring
-}+
  
-mssh sudo umount ​-l /teuthology +        ​name: "​▶️ Write keyring content to temporary file" 
-mssh sudo umount -l /scratch +          ​ansible.builtin.copy:​ 
-mssh sudo umount -l /postfile+            ​content:​ "{{ keyring_content.stdout }}" 
 +            dest: "{{ tmp_keyring.path }}" 
 +            mode: '​0600'​
  
-genmount /teuthology-archive /teuthology teuthology ',​ro'​ +        ​name: "​▶️ Deploy client keyring"​ 
-genmount / /scratch scratch ''​ +          ​ansible.builtin.raw:​ > 
-genmount / /postfile postfile ',​ro'​+            ​ceph-authtool {{ client_keyring_path }} --create-keyring --import-keyring {{ tmp_keyring.path }}
  
-mssh sudo cat /etc/fstab +        - name: "​▶️ Clean up temporary keyring file"​ 
-mssh sudo systemctl daemon-reload +          ansible.builtin.file:​ 
-mssh sudo mount /teuthology +            path: "{{ tmp_keyring.path }}" 
-mssh sudo mount /scratch +            state: absent 
-mssh sudo mount /postfile + 
-mssh sudo ln -sfT /teuthology /a+        - name: "​▶️ Deploy client secret file (for other tools)"​ 
 +          ansible.builtin.copy:​ 
 +            content: "{{ secret_content.stdout }}" 
 +            dest: "{{ secret_path }}" 
 +            mode: '​0600'​ 
 + 
 +    - name: "3. Set up CephFS mounts"​ 
 +      block: 
 +        - name: "​▶️ Install ceph-common on Ubuntu/Debian"​ 
 +          ansible.builtin.apt:​ 
 +            name: ceph-common 
 +            ​state:​ present 
 +            update_cache:​ yes 
 +          when: ansible_facts['​os_family'​] == "​Debian"​ 
 + 
 +        - name: "​▶️ Install Ceph Squid repo on RHEL derivatives"​ 
 +          ansible.builtin.dnf:​ 
 +            name: centos-release-ceph-squid.noarch 
 +            state: present 
 +          when: ansible_facts['​os_family'​] == "​RedHat"​ 
 + 
 +        - name: "​▶️ Install ceph-common on RHEL derivatives"​ 
 +          ansible.builtin.dnf:​ 
 +            name: ceph-common 
 +            state: present 
 +          when: ansible_facts['​os_family'​] == "​RedHat"​ 
 + 
 +        - name: "​▶️ Unmount filesystems if they currently exist"​ 
 +          ansible.posix.mount: 
 +            path: "{{ item.path }}" 
 +            state: unmounted 
 +          loop: "{{ mounts }}" 
 + 
 +        - name: "​▶️ Create ​mount point directories"​ 
 +          ​ansible.builtin.file:​ 
 +            path: "{{ item.path }}" 
 +            state: directory 
 +            mode: '​000'​ 
 +          loop: "{{ mounts }}" 
 + 
 +        - name: "​▶️ Set immutable attribute on mount points"​ 
 +          ansible.builtin.file:​ 
 +            path: "{{ item.path }}" 
 +            attr: +i 
 +          loop: "{{ mounts }}" 
 + 
 +        - name: "​▶️ Configure CephFS mounts in /etc/​fstab"​ 
 +          ​ansible.posix.mount:​ 
 +            path: "{{ item.path }}" 
 +            src: "​sepian@{{ ceph_fsid.stdout | trim }}.{{ item.mds_namespace }}={{ item.src }}" 
 +            fstype: "{{ item.fstype }}" 
 +            opts: "{{ item.opts }}" 
 +            state: mounted 
 +            dump: 0 
 +            passno: 0 
 +          loop: "{{ mounts }}" 
 +          notify: Reload Systemd 
 + 
 +        - name: "​▶️ Create symlink for /a -/teuthology
 +          ansible.builtin.file:​ 
 +            src: "/​teuthology"​ 
 +            dest: "/a
 +            state: link 
 +            force: true 
 + 
 +    - name: "Force handlers to run before mounting"​ 
 +      ansible.builtin.meta:​ flush_handlers 
 + 
 +  handlers: 
 +    - name: Reload Systemd 
 +      listen: Reload Systemd 
 +      ansible.builtin.systemd:​ 
 +        daemon_reload:​ true
 </​code>​ </​code>​
 ==== Teuthology scheduling ==== ==== Teuthology scheduling ====
devplayground.1749572734.txt.gz · Last modified: 2025/06/10 16:25 by pdonnell