Ansible自动运维————实验

news2024/11/26 10:29:36

0、创建新的虚拟机,使用镜像RHEL8.5,要求/boot目录为512N,/home目录为1Gb,交换空间为2Gb,其他空间给)目录。

1、将该主机作为 Ansible 控制节点,克隆该虚拟机,将克隆的虚拟机作为受控节点,Ansible 仓库路径为 http://47.108.86.156/rhel8/ansible29/ansible-2.9-for-rhel-8-x86_64-rpms/

2、在控制节点上创建角色exam,该角色将在受控节点上完成以下任务∶

2.1,创建本地共享目录/home/materials,其所属组为sysadms, sysadms组成员对目录有修改目录里文件内容、长列表查看内容和进入该目录的权限,除此之外其它用户没有任何权限。
2.2.将系统光盘挂在载/mnt目录下,并且开机自动挂载,将控制节点本地的 rpm. repo 文件作为受控节点的yum源配置文件内容,该仓库无需开后gpg检查,配置完成后,安装httpd软件包,后动该服务并让该服务开机自启动。
2.3,创建一个sysadms组,创建两个用户 natasha和 harry 以该组为附属组,创建用户sarah,并且 sarah使用非交互式shell,该用户也不属于sysadms组,三个用户的密码都是compedel。
2.4.在根目录下创建一个目录test,在该目录中每个用户创建的文件只能自己有权限删除,其他用户没有权限删除,但是该目录对于hehe用户用所有的权限,该目录当中有一个可执行程序configtest.sh,该文件是系统/usr/bin/touch。
可执行程序的副本,该程序任何人都可以执行,但是每个人通过该程序创建的文件所有者都为redhat。
2.5、给受控节点添加sata接口、大小为10Gb大小和nvme接口、大小为20Gb大小的两块磁盘,完成以下需求∶

〉使用这两块磁盘创建卷组名称为testgroup 的卷组,使用该卷组创建testlv名称的逻辑卷,该逻辑卷大小为25Gb,并将该逻辑卷格式化为xfs格式,开机自动挂载到/exam目录。

〉使用testgroup卷组创建swaplv逻辑卷,大小为1Gb,作为交换空间并开机自动启用。

解题

0、创建新的虚拟机,使用镜像RHEL8.5,要求/boot目录为512N,/home 目录为 1Gb,交换空间为26b,其他空间给╱目录。

1、将该主机作为 Ansible控制节点,克隆该虚拟机,将克隆的虚拟机作为受控节点,Ansible 仓库路怪为 httpd://47.108.86.156/rhel8/ansible29/ansible-2.9-for-rhel-8-x86_64-rpms/

先挂载仓库下载dnf ,再挂载ansible仓库下载ansible

[root@localhost ansible]# yum install dnf

[root@localhost ansible]# dnf install ansible

2、在控制节点上创建角色exam,该角色将在受控节点上完成以下任务:

[root@localhost ansible]# ansible-galaxy init exam //创建exam角色

2.1,创建本地共享目录/home/materials,其所属组为sysadms, sysadms组成员对目录有修改目录里文件内容、长列表查看内容和进入该目录的权限,除此之外其它用户没有任何权限。

- name: exam  #创建组
  group:                
    name: sysadms
    state: present     #创建

- name: file #设置组权限
  file:
    group: sysadms
    path: /home/materials
    mode: '2770'
    state: directory   

2.2.将系统光盘挂在载/mnt目录下,并且开机自动挂载,将控制节点本地的rpm.repo文件作为受控节点的 yum源配置文件内容,该仓库无需开启gpg检查,配置完成后,安装httpd软件包,后动该服务并让该服务开机自启动。

- name:  mount and turn on auto mount
  mount:
      src: /dev/sr0       #挂载设备
      path: /mnt          #挂载点
      fstype: iso9660   #文件系统类型
      state: present
- name: install yum repo
  copy:
      src: /dev/yum.repos.d/rpm.repo
      dest: /etc/yum.repos.d/
- name: httpd installd      #安装httpd软件包
  yum:
      name: httpd
      state: latest          #最新版本

- name: start httpd service
  service:
      name: httpd
      enabled: true        #开机自启动  
      state: started

2.3,创建一个sysadms组,创建两个用户 natasha和 harry 以该组为附属组,创建用户 sarah,并且 sarah使用非交互式shell,该用户也不属于sysadms组,三个用户的密码都是compede

- name: create group sysadms    #创建sysadms组
  group:
    name: sysadms
    state: present

- name: create user natesha and harry #创建两个用户,为sysadms组附属组并设置密码
  user:
    name: "{{item.user}}"
    group: sysadms
    password: "{{'compedel'}}"
  loop:
    - {user: natasha}
    - {user: harry}    //会出现警告,但不是错误,不要紧

- name: create user sarah  #创建用户 sarah,并且 sarah使用非交互式shell,该用户也不属于sysadms组,并设置密码
  user:
    name: sarah
    shell: /user/bin/false
    password: "{{'compedel'}}"

2.4,在根目录下创建一个目录 test,在该目录中每个用户创建的文件只能自己有权限删除,其他用户没有权限删除,但是该目录对于hehe用户用所有的权限,该目录当中有一个可执行程序configtest.sh ,该文件是系统/usr/bin/touch 可执行程序的副本,该程序任何人都可以执行,但是每个人通过该程序创建的文件所有者都为redhat。

- name: create directory test     #创建目录test并设置权限
  file:
    path: /test
    state: directory
    mode: '1777'

- name: set permissions        #设置hehe用户的权限
  acl:
    path: /test
    entity: hehe
    etype: user
    permissions: rwx
    state: present

- name: user hehe #创建用户hehe
  user:
    name: hehe

- name: owner  #创建所有者
  user:
    name: redhat

- name: configtest.sh
  copy:
    src: /usr/bin/touch
    dest: /test/configtest.sh
    owner: redhat
    mode: '4777'

copy模块的作用就是拷贝文件,将ansible主机上的文件拷贝到远程主机中。

src参数 :用于指定需要copy的文件或目录

dest参数 :用于指定文件将被拷贝到远程主机的哪个目录中,dest为必须参数

content参数 :当不使用src指定拷贝的文件时,可以使用content直接指定文件内容,src与content两个参数必有其一,否则会报错。

force参数 : 当远程主机的目标路径中已经存在同名文件,并且与ansible主机中的文件内容不同时,是否强制覆盖,可选值有yes和no,默认值为yes,表示覆盖,如果设置为no,则不会执行覆盖拷贝操作,远程主机中的文件保持不变。

backup参数 : 当远程主机的目标路径中已经存在同名文件,并且与ansible主机中的文件内容不同时,是否对远程主机的文件进行备份,可选值有yes和no,当设置为yes时,会先备份远程主机中的文件,然后再将ansible主机中的文件拷贝到远程主机。

owner参数 : 指定文件拷贝到远程主机后的属主,但是远程主机上必须有对应的用户,否则会报错。

group参数 : 指定文件拷贝到远程主机后的属组,但是远程主机上必须有对应的组,否则会报错。

mode参数 : 指定文件拷贝到远程主机后的权限,如果你想将权限设置为"rw-r--r--",则可以使用mode=0644表示,如果你想要在user对应的权限位上添加执行权限,则可以使用mode=u+x表示。

2.5、给受控节点添加sata接口、大小为10Gb大小和nvme接口、大小为20Gb大小的两块磁盘,完成以下需求∶

注意:在虚拟机在关机状态下设置

〉使用这两块磁盘创建卷组名称为testgroup 的卷组,使用该卷组创建testlv 名称的逻辑卷,该运辑卷大小为25Gb,并将该逻辑卷格式化为xfs格式,开机自动挂载到/exam目录。

- name: create lvg testgroup #使用这两块磁盘创建卷组名称为testgroup
  lvg:
    vg: testgroup
    pvs: /dev/nvme0n2,/dev/sda
    state: present  #可不写,默认是present

- name: create lvol testlv #使用testgroup卷组创建testlv名称的逻辑卷,并设置大小
  lvol:
    vg: testgroup
    lv: testlv
    size: 25G
    state: present  #可不写,默认是present

- name: filesystem xfs  #逻辑卷格式化为xfs
  filesystem:
    fstype: xfs
    dev: /dev/mapper/testgroup-testlv

- name: mkdir /exam
  file:
    path: /exam
    state: directory

- name: mount  #自动挂载到/exam目录
  mount:
    src: /dev/mapper/testgroup-testlv
    path: /exam
    fstype: xfs
    state: present

〉使用testgroup卷组创建swaplv逻辑卷,大小为 1Gb,作为交换空间并开机自动后用。

- name: create lvol swaplv  #使用testgroup卷组创建testlv名称的逻辑卷,并设置大小
  lvol:
    vg: testgroup
    lv: swaplv
    size: 1G

- name: filesystem swap  #逻辑卷格式化为swap
  filesystem:
    fstype: swap
    dev: /dev/mapper/testgroup-swaplv

- name: mount
  mount:
    src: /dev/mapper/testgroup-swaplv
    path: /exam
    fstypy: swap
    state: present

lvg模块 创建卷组

vg 定义卷组名

state {present 创建,absent 删除}

pvs 指定物理卷

pesize 定义pe大小

lvol模块 创建逻辑卷

lv 定义逻辑卷名

size 定义逻辑卷大小

vg 空间来自哪个卷组

state{present 创建,absent 删除}

force=yes 强制执行

filesystem模块

• 用于格式化,也就是创建文件系统

• 常用选项:

– fstype:指定文件系统类型

– dev:指定要格式化的设备,可以是分区,可以是逻辑卷

mount模块

• 用于挂载文件系统

• 常用选项:

– path:挂载点。如果挂载点不存在,自动创建。

– src:待挂载的设备

– fstype:文件系统类型,

– state:mounted表示永久挂载 ,设备将被主动安装,并在fstab中适当配置。如果挂载点不存在,则将创建挂载点。

unmounted 设备将卸载而不更改fstab。

present仅指定设备将在fstab中配置﹐不会触发或要求挂载。

absent表示设备支架的条目将从fstab中删除还将卸载设备并删除挂载点。

remounted指定当您想强制刷新挂载本身时,设备将被重新安装。

看案例:

运行playbook:

验证语法是否有误: ansible-playbook --syntax-check playbook的名称

运行playbook: ansible-playbook playbook的名称

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/403077.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Koa源码学习

前言 koa是一个非常流行的Node.js http框架。本文我们来学习下它的使用和相关源码 来自官网的介绍: Koa 是一个新的 web 框架,由 Express 幕后的原班人马打造, 致力于成为 web 应用和 API 开发领域中的一个更小、更富有表现力、更健壮的基石。…

【数据分析】Excel必备函数汇总

文章目录求和单条件求和SUMIF多条件求和SUMIFS求平均AVERAGE单条件多条件查找纵向VLOOKUP函数eg1已知身份证查姓名eg2已知身份证查地区Find函数FindB函数SEARCH函数SEARCHBMATCH函数Subtotal函数最值小数点去小数点TRUNC四舍五入ROUND随机数求余奇偶统计条件多条件时间当前日期…

LearnOpenGL-光照-5.投光物

本人刚学OpenGL不久且自学,文中定有代码、术语等错误,欢迎指正 我写的项目地址:https://github.com/liujianjie/LearnOpenGLProject 文章目录投光物平行光点光源聚光不平滑的例子平滑例子投光物 前面几节使用的光照都来自于空间中的一个点 即…

IR 808 Alkyne,IR-808 alkyne,IR 808炔烃,近红外吲哚类花菁染料

【产品理化指标】:中文名:IR-808炔烃英文名:IR-808 alkyne,Alkyne 808-IR CAS号:N/AIR-808结构式:规格包装:10mg,25mg,50mg,接受各种复杂PEGS定制服务&#x…

Git的下载、安装、配置、使用、卸载

前言 我是跟着狂神老师学的。该博客仅用于笔记所用。 下面是老师的B站和笔记 B站:https://www.bilibili.com/video/BV1FE411P7B3?p1&vd_source9266cf72b1f398b63abe0aefe358d7d6 笔记:https://mp.weixin.qq.com/s/Bf7uVhGiu47uOELjmC5uXQ 一、准备工…

【18】组合逻辑 - VL18 实现3-8译码器①

VL18 实现3-8译码器① 1 题目 【这题我的思路非常绝境】奈斯 !! 看真值表的思路:Yi所在列【0仅一个其余全1】,故【以0为对象求解】 观察发现:E3 E2_n E1_n = 100 时 是 译码的使能信号 ; 并且E3 E2_n E1_n为其他值时,都不使能译码 然后就很简单,没有仿真就成功了 2 代…

Linux:文件流指针 与 文件描述符

目录一、文件描述符二、文件流指针三、缓冲区之前讲解过了IO库函数和IO接口,库函数是对系统调用接口的封装,也就是说实际上在库函数内部是通过调用系统调用接口来完成最终功能的。 库函数通过文件流指针操作文件,系统调用接口通过文件描述符操…

在一个web应用中应该如何完成资源的跳转

在一个web应用中通过两种方式,可以完成资源的跳转: 第一种方式:请求转发 第二种方式:重定向 转发和重定向的区别: 代码上的区别: 请求转发 // 获取请求转发器对象 RequestDispatcher dispatcher request.…

3-1 SpringCloud快速开发入门: Ribbon 是什么

接上一章节Eureka 服务注册中心自我保护机制,这里讲讲Ribbon 是什么 Ribbon 是什么 通常说的负载均衡是指将一个请求均匀地分摊到不同的节点单元上执行,负载均和分为硬件负载均衡和软件负载均衡: **硬件负载均衡:**比如 F5、深信…

C# 实现 key-value 结构自定义缓存 CustomCache

功能需求 使用 C# 编写一个 key-value 结构进程内缓存,实现数据的缓存操作,此处所用到的知识点如下: 线程安全的字典 ConcurrentDictionary;设计模式之单例模式(Singleton);缓存数据【主动 &a…

3.10多线程

一.常见锁策略1.悲观锁 vs乐观锁体现在处理锁冲突的态度①悲观锁:预期锁冲突的概率高所以做的工作更多,付出的成本更多,更低效②乐观锁:预期锁冲突的概率低所以做的工作少,付出的成本更低,更搞笑2.读写锁 vs 普通的互斥锁①普通的互斥锁,只有两个操作 加锁和解锁只有两个线程针…

HT32合泰单片机开发环境搭建和配置教程

HT32合泰(Holtek)单片机开发环境搭建安装教程 前言 最近在准备合泰杯的比赛,在看合泰官方的PPT和数据手册学习,顺便做个合泰单片机的开发环境搭建教程。 合泰杯比赛发放的开发板是ESK32-30501,用的单片机是HT32F52352。 合泰杯官网地址&a…

【C++】vector的使用及其模拟实现

这里写目录标题一、vector的介绍及使用1. vector的介绍2. 构造函数3. 遍历方式4. 容量操作及空间增长问题5. 增删查改6. vector二维数组二、vector的模拟实现1. 构造函数2. 迭代器和基本接口3. reserve和resize4. push_back和pop_back5. insert和erase5. 迭代器失效问题5. 浅拷…

Java中的 this 和 super

1 this 关键字 1.1 this 访问本类属性 this 代表对当前对象的一个引用 所谓当前对象,指的是调用当前类中方法或属性的那个对象this只能在方法内部使用,表示对“调用方法的那个对象”的引用this.属性名,表示本对象自己的属性 当对象的属性和…

IntelliJ IDEA 编码设置

1.场景 适用于配置idea文件编码 2.配置 对已经存在的项目设置文件编码 可以设置全局的编码 以及 项目的编码 一般没啥特殊要求 都建议设置为 UTF-8 以及 配置项目的目录的单独编码 也建议UTF-8 idea可以单独设置properties的编码 也建议改为 UTF-8,其中有一个重点…

HCIP --- GRE和MGRE

VPN----虚拟私有网络:依靠ISP或者其他网络管理机构在公有网络基础上构建的专用的安全数据通信网络,只不过该网络是逻辑上的而非物理的。 虚拟:用户不再需要拥有实际的长途数据线路,而是使用公共网络资源建立的属于自己的私有网络…

[论文笔记]Transformer-XL: Attentive Language Models Beyond a Fixed-Length Context

引言 我们知道Transformer很好用,但它设定的最长长度是512。像一篇文章超过512个token是很容易的,那么我们在处理这种长文本的情况下也想利用Transformer的强大表达能力需要怎么做呢? 本文就带来一种处理长文本的Transformer变种——Transf…

SQS (Simple Queue Service)简介

mazon Simple Queue Service (SQS)是一种完全托管的消息队列服务,可以让你分离和扩展微服务、分布式系统和无服务应用程序。 在讲解SQS之前,首先让我们了解一下什么是消息队列。 消息队列 还是举一个电商的例子,一个用户在电商网站下单后付…

【LeetCode每日一题:[面试题 17.05] 字母与数字-前缀和+Hash表】

题目描述 给定一个放有字母和数字的数组,找到最长的子数组,且包含的字母和数字的个数相同。 返回该子数组,若存在多个最长子数组,返回左端点下标值最小的子数组。若不存在这样的数组,返回一个空数组。 示例 1: 输入…

LDGRB-01 3AFE61320954P0001

LDGRB-01 3AFE61320954P0001变频器的作用_变频器工作原理变频器是把工频电源(50Hz或60Hz)变换成各种频率的交流电源,以实现电机的变速运行的设备,其中控制电路完成对主电路的控制,整流电路将交流电变换成直流电&#x…