diff options
| author | Troy Dawson <tdawson@redhat.com> | 2015-06-16 11:48:22 -0500 | 
|---|---|---|
| committer | Troy Dawson <tdawson@redhat.com> | 2015-06-24 09:19:34 -0500 | 
| commit | 97a8f95c750314087a2358059037f01b04da785a (patch) | |
| tree | e80839217ede1364642f5d215e41f7f1112ede05 /roles | |
| parent | a7ac3f7b513fe57ddccad15bdb6c7e9091f16bcd (diff) | |
| download | openshift-97a8f95c750314087a2358059037f01b04da785a.tar.gz openshift-97a8f95c750314087a2358059037f01b04da785a.tar.bz2 openshift-97a8f95c750314087a2358059037f01b04da785a.tar.xz openshift-97a8f95c750314087a2358059037f01b04da785a.zip | |
Create openshift_storage_nfs_lvm based off kube_nfs_volumes
initial import of openshift_storage_nfs from kube_nfs_volumes
reduce total size so we do not go over
Postpone making the mounts owned by nfsnobody
rename openshift_storage_nfs storage_nfs_pvs
Update README to latest settings
have json files go to /root/
change categories from cloud to openshift, cuz this can run on bare metal
storgae_nfs_lvm initial commit
fixing default
getting it working
check these in, just cuz
for lvm we do not need the library
Update README to match reality
adding recycle
make volume_group a variable
make volume_group a variable
fix typo
default should be /exports/openshift
set owner and permissions of mount point
update examples
cleanup cruft
fixup documentation
fixup documentation
rename storage_nfs_lvm to openshift_storage_nfs_lvm
rename storage_nfs_lvm to openshift_storage_nfs_lvm
use openshiftvg, not openshift3vg
use ansible file: to set owner and permissions of mount dir
change nfs_export_options to osnl_nfs_export_options
change mount_dir to osnl_mount_dir
change volume_group to osnl_volume_group
change volume_prefix to osnl_volume_prefix
change volume_size to osnl_volume_size
change volume_num_start to osnl_volume_num_start
change number_of_volumes to osnl_number_of_volumes
replace volume_size with osnl_volume_size
Diffstat (limited to 'roles')
| -rw-r--r-- | roles/openshift_storage_nfs_lvm/README.md | 108 | ||||
| -rw-r--r-- | roles/openshift_storage_nfs_lvm/defaults/main.yml | 10 | ||||
| -rw-r--r-- | roles/openshift_storage_nfs_lvm/handlers/main.yml | 3 | ||||
| -rw-r--r-- | roles/openshift_storage_nfs_lvm/meta/main.yml | 16 | ||||
| -rw-r--r-- | roles/openshift_storage_nfs_lvm/tasks/main.yml | 24 | ||||
| -rw-r--r-- | roles/openshift_storage_nfs_lvm/tasks/nfs.yml | 16 | ||||
| -rw-r--r-- | roles/openshift_storage_nfs_lvm/templates/nfs.json.j2 | 21 | 
7 files changed, 198 insertions, 0 deletions
| diff --git a/roles/openshift_storage_nfs_lvm/README.md b/roles/openshift_storage_nfs_lvm/README.md new file mode 100644 index 000000000..1ee02e18a --- /dev/null +++ b/roles/openshift_storage_nfs_lvm/README.md @@ -0,0 +1,108 @@ +# openshift_storage_nfs_lvm + +This role is useful to create and export nfs disks for openshift persistent volumes. +It does so by creating lvm partitions on an already setup pv/vg, creating xfs  +filesystem on each partition, mounting the partitions, exporting the mounts via NFS +and creating a json file for each mount that an openshift master can use to +create persistent volumes. + +## Requirements + +* NFS server with NFS, iptables, and everything setup. + +* A lvm volume group created on the nfs server (default: openshiftvg) + +* The lvm volume needs to have as much free space as you are allocating + +## Role Variables + +``` +# Options of NFS exports. +osnl_nfs_export_options: "*(rw,sync,all_squash)" + +# Directory, where the created partitions should be mounted. They will be +# mounted as <osnl_mount_dir>/<lvm volume name>  +osnl_mount_dir: /exports/openshift + +# Volume Group to use. +# This role always assumes that there is enough free space on the volume +#   group for all the partitions you will be making +osnl_volume_group: openshiftvg + +# volume names +# volume names are {{osnl_volume_prefix}}{{osnl_volume_size}}g{{volume number}} +#   example: stg5g0004 + +# osnl_volume_prefix +# Useful if you are using the nfs server for more than one cluster +osnl_volume_prefix: "stg" + +# osnl_volume_size +# Size of the volumes/partitions in Gigabytes. +osnl_volume_size: 5 + +# osnl_volume_num_start +# Where to start the volume number numbering. +osnl_volume_num_start: 3 + +# osnl_number_of_volumes +# How many volumes/partitions to build, with the size we stated. +osnl_number_of_volumes: 2 + +``` + +## Dependencies + +None + +## Example Playbook + +With this playbook, 2 5Gig lvm partitions are created, named stg5g0003 and stg5g0004 +Both of them are mounted into `/exports/openshift` directory.  Both directories are  +exported via NFS.  json files are created in /root. + +    - hosts: nfsservers +      sudo: no +      remote_user: root +      gather_facts: no +      roles: +        - role: openshift_storage_nfs_lvm +          osnl_mount_dir: /exports/openshift +          osnl_volume_prefix: "stg" +          osnl_volume_size: 5 +          osnl_volume_num_start: 3 +          osnl_number_of_volumes: 2 + + +## Full example + + +* Create an `inventory` file: +    ``` +    [nfsservers] +    10.0.0.1 +    10.0.0.2 +    ``` + +* Create an ansible playbook, say `setupnfs.yaml`: +    ``` +    - hosts: nfsservers +      sudo: no +      remote_user: root +      gather_facts: no +      roles: +        - role: openshift_storage_nfs_lvm +          osnl_mount_dir: /exports/stg +          osnl_volume_prefix: "stg" +          osnl_volume_size: 5 +          osnl_volume_num_start: 3 +          osnl_number_of_volumes: 2 + +* Run the playbook: +    ``` +    ansible-playbook -i inventory setupnfs.yml +    ``` + +## License + +Apache 2.0 diff --git a/roles/openshift_storage_nfs_lvm/defaults/main.yml b/roles/openshift_storage_nfs_lvm/defaults/main.yml new file mode 100644 index 000000000..f81cdc724 --- /dev/null +++ b/roles/openshift_storage_nfs_lvm/defaults/main.yml @@ -0,0 +1,10 @@ +--- +# Options of NFS exports. +osnl_nfs_export_options: "*(rw,sync,all_squash)" + +# Directory, where the created partitions should be mounted. They will be +# mounted as <osnl_mount_dir>/test1g0001 etc. +osnl_mount_dir: /exports/openshift + +# Volume Group to use. +osnl_volume_group: openshiftvg diff --git a/roles/openshift_storage_nfs_lvm/handlers/main.yml b/roles/openshift_storage_nfs_lvm/handlers/main.yml new file mode 100644 index 000000000..52f3ceffe --- /dev/null +++ b/roles/openshift_storage_nfs_lvm/handlers/main.yml @@ -0,0 +1,3 @@ +--- +- name: restart nfs +  service: name=nfs-server state=restarted diff --git a/roles/openshift_storage_nfs_lvm/meta/main.yml b/roles/openshift_storage_nfs_lvm/meta/main.yml new file mode 100644 index 000000000..44fee47ff --- /dev/null +++ b/roles/openshift_storage_nfs_lvm/meta/main.yml @@ -0,0 +1,16 @@ +--- +galaxy_info: +  author: Jan Safranek, Troy Dawson +  description: Create LVM volumes and use them as openshift persistent volumes. +  company: Red Hat, Inc. +  license: license (Apache) +  min_ansible_version: 1.4 +  platforms: +  - name: EL +    versions: +    - 7 +  - name: Fedora +    versions: +    - all +  categories: +    - openshift diff --git a/roles/openshift_storage_nfs_lvm/tasks/main.yml b/roles/openshift_storage_nfs_lvm/tasks/main.yml new file mode 100644 index 000000000..e9f5814bb --- /dev/null +++ b/roles/openshift_storage_nfs_lvm/tasks/main.yml @@ -0,0 +1,24 @@ +--- +- name: Create lvm volumes +  lvol: vg={{osnl_volume_group}} lv={{ item }} size={{osnl_volume_size}}G +  with_sequence: start={{osnl_volume_num_start}} count={{osnl_number_of_volumes}} format={{osnl_volume_prefix}}{{osnl_volume_size}}g%04d + +- name: create filesystem +  filesystem: fstype=xfs dev=/dev/{{osnl_volume_group}}/{{ item }} +  with_sequence: start={{osnl_volume_num_start}} count={{osnl_number_of_volumes}} format={{osnl_volume_prefix}}{{osnl_volume_size}}g%04d + +- name: mount volumes +  mount: name={{osnl_mount_dir}}/{{ item }} src=/dev/{{osnl_volume_group}}/{{ item }} state=mounted fstype=xfs passno=0 +  with_sequence: start={{osnl_volume_num_start}} count={{osnl_number_of_volumes}} format={{osnl_volume_prefix}}{{osnl_volume_size}}g%04d + +- name: Make mounts owned by nfsnobody +  file: path={{osnl_mount_dir}}/{{ item }} owner=nfsnobody group=nfsnobody mode=0700 +  with_sequence: start={{osnl_volume_num_start}} count={{osnl_number_of_volumes}} format={{osnl_volume_prefix}}{{osnl_volume_size}}g%04d + +- include: nfs.yml + +- name: Create volume json file +  template: src=../templates/nfs.json.j2 dest=/root/persistent-volume.{{ item }}.json +  with_sequence: start={{osnl_volume_num_start}} count={{osnl_number_of_volumes}} format={{osnl_volume_prefix}}{{osnl_volume_size}}g%04d + +# TODO - Get the json files to an openshift-master, and load them.
\ No newline at end of file diff --git a/roles/openshift_storage_nfs_lvm/tasks/nfs.yml b/roles/openshift_storage_nfs_lvm/tasks/nfs.yml new file mode 100644 index 000000000..65ae069df --- /dev/null +++ b/roles/openshift_storage_nfs_lvm/tasks/nfs.yml @@ -0,0 +1,16 @@ +--- +- name: Install NFS server +  yum: name=nfs-utils state=present + +- name: Start rpcbind +  service: name=rpcbind state=started enabled=yes + +- name: Start nfs +  service: name=nfs-server state=started enabled=yes + +- name: Export the directories +  lineinfile: dest=/etc/exports +              regexp="^{{ osnl_mount_dir }}/{{ item }} " +              line="{{ osnl_mount_dir }}/{{ item }} {{osnl_nfs_export_options}}" +  with_sequence: start={{osnl_volume_num_start}} count={{osnl_number_of_volumes}} format={{osnl_volume_prefix}}{{osnl_volume_size}}g%04d +  notify: restart nfs diff --git a/roles/openshift_storage_nfs_lvm/templates/nfs.json.j2 b/roles/openshift_storage_nfs_lvm/templates/nfs.json.j2 new file mode 100644 index 000000000..0f3d84e75 --- /dev/null +++ b/roles/openshift_storage_nfs_lvm/templates/nfs.json.j2 @@ -0,0 +1,21 @@ +{ +  "apiVersion": "v1", +  "kind": "PersistentVolume", +  "metadata": { +    "name": "pv-{{ inventory_hostname | regex_replace("\.", "-")  }}-{{ item }}", +    "labels": { +      "type": "nfs" +    } +  }, +  "spec": { +    "capacity": { +      "storage": "{{ osnl_volume_size }}Gi" +    }, +    "accessModes": [ "ReadWriteMany" ], +    "persistentVolumeReclaimPolicy": "Recycle", +    "nfs": { +      "Server": "{{ inventory_hostname }}", +      "Path": "{{ osnl_mount_dir }}/{{ item }}" +    } +  } +} | 
