1.原理:通过limit的参数,限制新定义的服务器。即可给新买的服务器初始化优化。(如下图所示)

首先我们编写一个总入口的palybook脚本: init.yml

---
- hosts: all
user: root
gather_facts: true
roles:
- ../../init

第二步:创建相对应的目录。这些目录都有各自的功能。

mkdir {file,tasks,vars}                // 具体的目录和功能,可以上网查一下。

第三步:进入到vars目录下定义hosts的内置变量

vim main.yml
---
HOSTNAME: "{{ inventory_hostname }}"
IP: "{{ ansible_eth0['ipv4']['address'] }}"

第四步:进入到tasks目录下,创建任务的脚本。

main.yml作为整个tasks目录的总入口,是必须有这个配置

vim main.yml
---
- name: 复制 PS1 变量
copy:
src: ps1.sh
dest: /etc/profile.d/
- shell: source /etc/profile
- include_tasks: init_hostname.yml # include类似于子配置脚本。
- include_tasks: init_user.yml
- include_tasks: init_tools.yml

子脚本1

vim init_user.yml
---
# 创建用户。generate_ssh_key参数是生成公钥和私钥。我这里主要是生成.ssh目录,然后推送authorized_key
- name: create user
user: name="{{ item}}" append=yes generate_ssh_key=yes
with_items:
- ops
- dev
# 推送用到authorized_key模块
- name:
authorized_key: user={{ item }} key={{ lookup('file', '/home/{{ item }}/.ssh/id_rsa.pub') }}
with_items:
- ops
- dev

子脚本2

vim init_tools.yml
---
- name: 安装基本命令
yum: name={{ item }}
with_items:
- epel-release
- telnet
- vim
- unzip
- tree
- net-tools
- git
- screen

子脚本3

vim init_hostname.yml
---
- name: update file (/etc/sysconfig/network)
lineinfile:
dest: /etc/sysconfig/network
regexp: '^HOSTNAME'
line: 'HOSTNAME={{ HOSTNAME }}'
when: ansible_distribution == 'CentOS' and ansible_distribution_major_version == "" - name: execute hostname command
shell: hostname {{ HOSTNAME }}
when: ansible_distribution == 'CentOS' and ansible_distribution_major_version == "" - name: set hostname for centos7
shell: hostnamectl set-hostname "{{ HOSTNAME }}"
when: ansible_distribution == 'CentOS' and ansible_distribution_major_version == ""

上面还定义了一个拷贝文件的任务。所以我们在要files的目录下,放上你要用到的文件

vim ps1.sh
# 更改 PS1 显示
export PS1='[\[\e[36m\]\u\[\e[33m\]@\[\e[34m\]\H\[\e[33m\]:\[\e[32m\]\w\[\e[0m\]]\$ '
# 历史命令
HISTSIZE=

这样,一个简单的role角本就写好了。下面我们来创建新的虚拟机,添加hosts文件。验证一下结果吧

添加hosts文件

验证结果

这样,通过ansible的playbook,就可以对新的服务器进行初始化了。

ansible-playbook编写服务器初始化脚本的更多相关文章

  1. ansible roles实践——服务器初始化

    1.服务器初始化可以做哪些工作 关闭selinux ntp同步时间 修改dns为自建dns 配置ssh互信 修改yum源 设置主机名 内核参数优化 安装jdk 2.roles编写

  2. Ansible playbook编写Apache角色

    编写Apache角色:使用源码安装 在files中下载扩展包和安装包 [root@localhost project]# ls roles/httpd/files/ apr-1.6.5.tar.gz ...

  3. Ansible playbook 批量修改服务器密码 先普通后root用户

    fsckzy   Ansible playbook 批量修改服务器密码 客户的需求:修改所有服务器密码,密码规则为Rfv5%+主机名后3位 背景:服务器有CentOS6.7,SuSE9.10.11,r ...

  4. Ubuntu 系统服务器初始化配置、安全加固、内核优化和常用软件安装的Shell脚本分享

    转载自:https://www.bilibili.com/read/cv13875402?spm_id_from=333.999.0.0 描述: 适用于企业内部 Ubuntu 操作服务器初始化.系统安 ...

  5. CentOS7 系统服务器初始化配置、安全加固、内核升级优化常用软件安装的Shell脚本分享

    转载自:https://www.bilibili.com/read/cv13875630?spm_id_from=333.999.0.0 描述: 适用于企业内部 CentOS7 系列操作服务器初始化. ...

  6. linux软件管理之------编译安装nginx服务器并手动编写自动化运行脚本

    红帽系列的 linux软件管理分为三类:1. rpm 安装软件.2. yum 安装软件.3. 源码包编译安装.前面两种会在相关专题给出详细讲解.源码包的编译安装是非常关键的,我们知道linux的相关版 ...

  7. ansible笔记(10):初识ansible playbook

    ansible笔记():初识ansible playbook 假设,我们想要在test70主机上安装nginx并启动,我们可以在ansible主机中执行如下3条命令 ansible test70 -m ...

  8. 2.Ansible Playbook剧本

    1.playbook?playbook翻译过来就是"剧本",那playbook组成如下 play: 定义的是主机的角色 task: 定义的是具体执行的任务 playbook: 由一 ...

  9. Ansible-playbook服务器初始化

    一.什么是Playbook playbook可以理解为ansible的shell脚本,它是一个编排工具,作用是使用编排出能够重复利用的ansible脚本,并并发处理多台服务器. 二.playbook使 ...

随机推荐

  1. [Mathematics][MIT 18.03] Detailed Explanation of the Frequency Problems in Second-Order Differential Equation of Oscillation System

    Well, to begin with, I'd like to say thank you to MIT open courses twice. It's their generosity that ...

  2. GitHub Token for composer

    a2248520cdd2b1d27c2c70741003b9078530d81c

  3. json解析精度问题

    由于后台传过来的值是float或者double类型,解析之后作为对象放到字典或数组里面,被转成nsstring或者nsnumber会有一定的误差,很正常 解决办法,通过NSNumberFormatte ...

  4. ACM&OI 基础数论算法专题

    ACM&OI 基础数学算法专题 一.数论基础 质数及其判法 (已完结) 质数的两种筛法 (已完结) 算数基本定理与质因数分解 (已完结) 约数与整除 (已完结) 整除分块 (已完结) 最大公约 ...

  5. python numpy 矩阵左右翻转/上下翻转

    numpy API: flattened flip() (in module numpy) fliplr() (in module numpy) flipud() (in module numpy) ...

  6. FFmpeg的基本使用

    1.FFmpeg理解 (1)FFmpeg是一个视屏.音频编码工具 (2)x项目名称mpeg来源mpeg编码标准,但不局限只能使用mpeg编码标准.FF 表示fast forward (3)被广泛使用. ...

  7. java AES加解密

    AES加解密工具类 package com.yan.demo; import org.apache.commons.lang3.StringUtils; import sun.misc.BASE64D ...

  8. 基因调控网络 (Gene Regulatory Network) 01

    本文为入门级的基因调控网络文章,主要介绍一些基本概念及常见的GRN模型. 概念:基因调控网络 (Gene Regulatory Network, GRN),简称调控网络,指细胞内或一个基因组内基因和基 ...

  9. 如何实现MVC ActionResult 返回类型为JavaScriptResult

    必需的js引用文件 <script src="~/Scripts/jquery.unobtrusive-ajax.js"></script>@Scripts ...

  10. CI项目设计Redis队列

    项目开发过程中需要设计提供可平衡的处理多个用户请求的队列. 需求: 当用户登录后,查看系统中已经登录的管理员队列,然后查看后台管理员的处理能力,如果已经不能处理新的请求,则把该管理员从处理队列中删除, ...