To learn more about this project, read the wiki.
README.md 2.13 KB

logo

Ansible의 mount 모듈을 이용한 NFS 마운트

NFS Client가 NFS Server의 파일시스템을 마운트를 자동화 할 수 있다.

주요 기능

  • Mount 시 rsize(read), wsize(write) 사이즈를 변수로 지정한다.
  • hard 옵션의 무한정 대기를 방지하기 위해 timeout 설정을 추가한다.
  • NFS-Client의 필수 패키지인 nfs-common 패키지를 설치한다.

Inventory 설정

# cat hosts
[ALL_HOSTS]
172.16.0.100 managed_ip=172.16.0.100 des="2020-12-03"

[ALL_HOSTS_OK]

대상 호스트는 172.16.0.100이며, 추가는 2020-12-03에 수행한다. 참고적으로 ALL_HOSTS_OK 호스트 그룹은 작업이 완료된 호스트의 history를 위한 그룹이다.

Host Variables 설정

# cat host_vars/172.16.0.100
ansible_ssh_host: 172.16.0.100
ansible_ssh_port: SSH_포트번호
ansible_ssh_user: 사용자 아이디
ansible_ssh_pass: "사용자 패스워드"
ansible_become: yes
ansible_become_method: su
ansible_become_user: root
ansible_become_pass: "!root_패스워드"
ansible_python_interpreter: python2.7

Playbook 설정

---
- name: nfs client install
  hosts: ALL_HOSTS
  vars:
    nfs_version: 4
    nfs_mount_opts: rsize=16384,wsize=16384,timeo=300,intr
  tasks:
   - name: Install a list of packages
     apt:
       pkg:
         - nfs-common
       update_cache: yes

   - name: set mountpoints
     mount:
       fstype: nfs
       opts: "{{ nfs_mount_opts }}"
       src: "{{ item.src }}"
       path: "{{ item.path }}"
       state: mounted
     with_items:
        - { path: "/BACKUP", src: "172.16.0.12:/NFS/BACKUP" }
        - { path: "/BACKUP2", src: "172.16.0.12:/NFS/BACKUP2" }

NFS 원격 마운트에 대한 Playbook 분석

  • NFS 서버의 172.16.0.12:/NFS/BACKUP exports 파티션을 원격서버의 /BACKUP으로 마운트 한다.
  • NFS 서버의 172.16.0.12:/NFS/BACKUP2 exports 파티션을 원격서버의 /BACKUP2으로 마운트 한다.
  • NFS Version은 4로 지정한다.

playbook 실행

# ansible-playbook -i hosts nfs_client_mount.yml