-
Notifications
You must be signed in to change notification settings - Fork 2
/
mount_sasdata_controller.yml
99 lines (87 loc) · 3.14 KB
/
mount_sasdata_controller.yml
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
# Purpose: Add storage to SAS CAS primary controller for SAS datasets or other flat files.
# Key Dependencies:
# - Become ROOT user (to install packages with yum)
# - SAS Viya deployment inventory file
# - Standard yum repositories available to download mdadm
# - Set YAML variable: "sasdata_owner" and "sasdata_group" for target filesystem permissions
# - Defined directory structure within conceptual SASDATA
---
- name: Setup SASDATA on programming environment server
hosts: programming
gather_facts: no
become: yes
become_user: root
vars:
sasdata_owner: sas
sasdata_group: sas
tasks:
- name: Install MDADM
yum:
name: mdadm
state: latest
# NOTE: Confirm RAID and device configuration for target environment.
- name: Configure RAID0
command: mdadm --create --verbose /dev/md0 --level=0 --name=SASDATA --raid-devices=4 /dev/nvme0n1 /dev/nvme1n1 /dev/nvme2n1 /dev/nvme3n1
- name: Reload info for kernel
shell: dracut -H -f /boot/initramfs-$(uname -r).img $(uname -r)
# NOTE: Confirm filesystem options for target environment
- name: Make XFS Filesystem for SASDATA
command: mkfs.xfs -L SASDATA -i size=512 -b size=4096 -d sunit=1024,swidth=4096 /dev/md0
- name: Mount Filesystem to SASDATA
mount:
path: /sasdata
src: /dev/md0
fstype: xfs
opts: noatime,nodiratime,nobarrier,nofail
state: mounted
- name: Update permissions and ownership for SASDATA
file:
path: /sasdata
owner: "{ sasdata_owner }"
group: "{ sasdata_group }"
mode: 0775
# NOTE: The next series of tasks setup a common directory structure for organizing files under a mock "project1".
- name: Setup project1 directory structure
file:
path: /sasdata/project1
state: directory
owner: "{ sasdata_owner }"
group: "{ sasdata_group }"
mode: 0775
- name: Setup project1 directory structure
file:
path: /sasdata/project1/dq_check
state: directory
owner: "{ sasdata_owner }"
group: "{ sasdata_group }"
mode: 0775
- name: Setup project1 directory structure
file:
path: /sasdata/project1/err
state: directory
owner: "{ sasdata_owner }"
group: "{ sasdata_group }"
mode: 0775
- name: Setup project1 directory structure
file:
path: /sasdata/project1/log
state: directory
owner: "{ sasdata_owner }"
group: "{ sasdata_group }"
mode: 0775
- name: Setup project1 directory structure
file:
path: /sasdata/project1/source
state: directory
owner: "{ sasdata_owner }"
group: "{ sasdata_group }"
mode: 0775
- name: Setup project1 directory structure
file:
path: /sasdata/project1/stage
state: directory
owner: "{ sasdata_owner }"
group: "{ sasdata_group }"
mode: 0775
- name: Reload Daemon to prevent creation refresh problems
command: systemctl daemon-reload