|
| 1 | +#!/bin/bash |
| 2 | + |
| 3 | +# script description: Script to create cephfs cleint auth file on proxmox and and mount cephfs on a remote server. |
| 4 | + |
| 5 | +# Ceph FS variables |
| 6 | +CEPHFS_NAME="cephfs" |
| 7 | +CEPHFS_SUBDIRECTORY="docker-shared-prod" |
| 8 | +MNT_DIR_NAME="$CEPHFS_NAME/$CEPHFS_SUBDIRECTORY" |
| 9 | +CEPH_CONF="" |
| 10 | +CLIENT_KEYRING="" |
| 11 | +CLIENT_KEY="" |
| 12 | +SSH_USER="serveradmin" |
| 13 | +SERVERS_IPS=("192.168.80.248" "192.168.80.136" "192.168.80.123" "192.168.80.182" "192.168.80.76" "192.168.80.110") |
| 14 | + |
| 15 | +SSH_CERTIFICATE="/root/.ssh/id_rsa" |
| 16 | + |
| 17 | +# Function to add host keys to known_hosts file |
| 18 | +add_host_keys() { |
| 19 | + if [ ! -f ~/.ssh/known_hosts ]; then |
| 20 | + touch ~/.ssh/known_hosts |
| 21 | + fi |
| 22 | + for ip in "${SERVERS_IPS[@]}"; do |
| 23 | + if ! grep -q "$ip" ~/.ssh/known_hosts; then |
| 24 | + echo "Adding host key for $ip to known_hosts file..." |
| 25 | + ssh-keyscan -H "$ip" >> ~/.ssh/known_hosts |
| 26 | + fi |
| 27 | + done |
| 28 | +} |
| 29 | + |
| 30 | +# Function to install ceph-common on all servers |
| 31 | +install_ceph_common() { |
| 32 | + for ip in "${SERVERS_IPS[@]}"; do |
| 33 | + echo "Installing ceph-common on $ip..." |
| 34 | + ssh -i $SSH_CERTIFICATE $SSH_USER@"$ip" 'sudo apt install -y ceph-common' |
| 35 | + done |
| 36 | +} |
| 37 | + |
| 38 | +# Function to create directories on all servers |
| 39 | +create_directories() { |
| 40 | + for ip in "${SERVERS_IPS[@]}"; do |
| 41 | + echo "Creating directories on $ip..." |
| 42 | + ssh -i $SSH_CERTIFICATE $SSH_USER@"$ip" 'sudo mkdir -p /etc/ceph && sudo mkdir -p /mnt/'"$MNT_DIR_NAME" |
| 43 | + done |
| 44 | +} |
| 45 | + |
| 46 | +# Function to generate ceph config file and copy to all servers |
| 47 | +generate_ceph_config() { |
| 48 | + CEPH_CONF=$(sudo ceph config generate-minimal-conf) |
| 49 | + for ip in "${SERVERS_IPS[@]}"; do |
| 50 | + echo "Copying ceph config file to $ip..." |
| 51 | + echo "$CEPH_CONF" | ssh -i $SSH_CERTIFICATE $SSH_USER@"$ip" 'sudo tee /etc/ceph/ceph.conf > /dev/null' |
| 52 | + ssh -i $SSH_CERTIFICATE $SSH_USER@"$ip" 'sudo chmod 644 /etc/ceph/ceph.conf' |
| 53 | + done |
| 54 | +} |
| 55 | + |
| 56 | +# Function to authorize client and mount ceph fs on all servers |
| 57 | +authorize_and_mount_cephfs() { |
| 58 | + for ip in "${SERVERS_IPS[@]}"; do |
| 59 | + echo "Authorizing client and mounting ceph fs on $ip..." |
| 60 | + SERVERS_HOSTNAME=$(ssh -i $SSH_CERTIFICATE $SSH_USER@"$ip" hostname) |
| 61 | + # CLIENT_KEYRING=$(sudo ceph fs authorize $CEPHFS_NAME client.$SERVERS_HOSTNAME /$CEPHFS_SUBDIRECTORY rw) |
| 62 | + CLIENT_KEYRING=$(sudo ceph fs authorize $CEPHFS_NAME client."$SERVERS_HOSTNAME" / rw) |
| 63 | + echo "$CLIENT_KEYRING" | ssh -i $SSH_CERTIFICATE $SSH_USER@"$ip" 'sudo tee /etc/ceph/ceph.client.'"$SERVERS_HOSTNAME"'.keyring > /dev/null' |
| 64 | + ssh -i $SSH_CERTIFICATE $SSH_USER@"$ip" 'sudo chmod 600 /etc/ceph/ceph.client.'"$SERVERS_HOSTNAME"'.keyring' |
| 65 | + CLIENT_KEY=$(sudo ceph auth get-key client."$SERVERS_HOSTNAME") |
| 66 | + echo "$CLIENT_KEY" | ssh -i $SSH_CERTIFICATE $SSH_USER@"$ip" 'sudo tee /etc/ceph/ceph.client.'"$SERVERS_HOSTNAME"'.key > /dev/null' |
| 67 | + ssh -i $SSH_CERTIFICATE $SSH_USER@"$ip" "sudo chmod 600 /etc/ceph/ceph.client.$SERVERS_HOSTNAME.key" |
| 68 | + ssh -i $SSH_CERTIFICATE $SSH_USER@"$ip" "sudo mount -t ceph $SERVERS_HOSTNAME@.$CEPHFS_NAME=/$CEPHFS_SUBDIRECTORY /mnt/$MNT_DIR_NAME -o secretfile=/etc/ceph/ceph.client.$SERVERS_HOSTNAME.key" |
| 69 | + echo "Setting up persistent mount on $SERVERS_HOSTNAME - $ip..." |
| 70 | + echo "$SERVERS_HOSTNAME@.$CEPHFS_NAME=/$CEPHFS_SUBDIRECTORY /mnt/$MNT_DIR_NAME ceph secretfile=/etc/ceph/ceph.client.$SERVERS_HOSTNAME.key,noatime,_netdev 0 0" | ssh -i $SSH_CERTIFICATE $SSH_USER@"$ip" 'sudo tee -a /etc/fstab > /dev/null' |
| 71 | + echo "Changing ownership /mnt/$MNT_DIR_NAME to root:docker" |
| 72 | + ssh -i $SSH_CERTIFICATE $SSH_USER@"$ip" "sudo chown -R root:docker /mnt/$MNT_DIR_NAME" |
| 73 | + echo "Initiating server reboot on $SERVERS_HOSTNAME - $ip..." |
| 74 | + ssh -i $SSH_CERTIFICATE $SSH_USER@"$ip" "sudo reboot" |
| 75 | + done |
| 76 | +} |
| 77 | + |
| 78 | + |
| 79 | +# Main function |
| 80 | +main() { |
| 81 | + #add_host_keys |
| 82 | + install_ceph_common |
| 83 | + create_directories |
| 84 | + generate_ceph_config |
| 85 | + authorize_and_mount_cephfs |
| 86 | +} |
| 87 | + |
| 88 | +# Call main function |
| 89 | +main |
0 commit comments