您现在的位置是:人工智能 >>正文
在Ansible中编写剧本实现批量服务器安全加固
人工智能6人已围观
简介在上一篇<<初步利用Ansible实现批量服务器自动化管理>>文章中, 我初步实现了通过编写清单和剧本来实现多台服务器的自动化管理,在本章节中, 我将利用Ansible的剧本来 ...
在上一篇<<初步利用Ansible实现批量服务器自动化管理>>文章中,编写 我初步实现了通过编写清单和剧本来实现多台服务器的自动化管理,在本章节中, 我将利用Ansible的剧本来实现更实用 、更复杂一点的剧本功能, 主要功能包括三个:
同时在三台服务器中增加IP访问控制,只允许192.168.201.202的IP登录,其它IP禁止其通过SSH登录 。修改SSH服务的实现默认22端口,修改为2222。启动防火墙,批量只允许2222端口访问, 不允许其它端口访问。
1.编写剧本
如果只讲原理,服务没有实践, 学习起来会比较枯燥, 所以我会在编写剧本的过程中边实践边讲解剧本的语法 。高防服务器
在上篇文章中,器安全加 我们已经知道剧本是一个YAML格式文件, 在开头,我们要加载所有的远程管理hosts,语法如下:
复制- hosts: all1.还记得在上一章编写的清单文件inventory.yaml吗,看看里面的内容:

hosts: all默认会加载这里的所有IP地址, 紧随其后的命令是:
复制become: yes1.该命令在Ansible中表示提权执行。
默认情况下,编写Ansible是以普通用户身份通过SSH连接到远程主机的 。源码库但有些任务需要 root 或 sudo 权限,剧本比如服务的重启,文件权限的修改等 。这时就需要使用become模块提权,实现 加上become:yes表示这个剧本中的所有任务都需要提权执行。Ansible会在执行任务时自动切换到root身份或目标用户身份,批量然后执行指定的任务 。
become模块非常强大,服务可以精细控制在剧本中的提权行为,包括:
- 以哪个身份提权(默认root,可以指定其他用户)- 提权使用的方法(sudo、su等)- 提权的源码下载器安全加密码- 仅在某些任务中提权
紧接着就是编写我们的任务了, 为了方便介绍, 我先给出一个完整的服务剧本,如图:
复制- hosts: all become: yes tasks: - name: 修改SSH端口 lineinfile: path: /etc/ssh/sshd_config regexp: ^Port line: Port 2222 - name: 默认开启防火墙 ufw: state: enabled - name: 在防火墙中开启2222端口 ufw: rule: allow port: 2222 - name: 防火墙拒绝其它端口连接 ufw: rule: deny direction: in delete: yes - name: 允许指定的IP访问 ufw: rule: allow src: 192.168.201.202 - name: 拒绝所有其它IP访问 ufw: rule: deny src: 0.0.0.0/0 - name: 重启ufw防火墙 service: name: ufw state: restarted - name: 重启SSH服务 service: name: sshd state: restarted1.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.可以看出, 任务tasks标签下面有8个子项, 每个子项都有一个name, 这个name表示每个子任务的名字, 方便我们区分子任务。
子任务1: 修改SSH端口该任务使用了lineinfile模块,编写 目的是在路径/etc/ssh/sshd_config文件中按行搜索, 通过正则regexp匹配Port, 然后将其修改为2222端口 。
我们可以打开/etc/ssh/sshd_config文件看一下,剧本 查找到该项:

在ubuntu系统中, Port一般在ssd_config文件的最后一行 。免费模板
子任务2:默认开启防火墙对于ubuntu系统来说,实现防火墙使用的是ufw, 这里将状态state始终置为:enabled, 因为大部分刚装完的系统默认没有开启ufw,因此这里需要提前设置状态, 否则会导致后面操作ufw不成功 。
子任务3: 在防火墙中开启2222端口在该任务中,我们将之前修改的SSH服务的2222端口添加到防火墙中, 允许外界通过2222端口访问本机 。
子任务4:防火墙拒绝其它端口连接在该任务中, 我们主要设置了拒绝规则, 在防火墙中,除了2222端口之外的其它所有端口全部删除屏蔽掉。
子任务5:允许指定的IP访问与上面的云计算端口相同,这里设置只允许某一个IP访问本机,这里是只允许192.168.201.202服务器访问 。
子任务6:拒绝所有其它IP访问同上面端口的拒绝规则, 拒绝除192.168.201.202的其它IP地址访问 。
子任务7:重启ufw防火墙这里主要使用restarted重启ufo防火墙,注意,这里不能用reload, 可能会导致防火墙重启失败, 用restart比较稳妥。
子任务8:重启SSH服务通过设置restarted状态重启SSH服务
2.多任务同步执行
编写完剧本内容之后, 输入以下命令执行即可:
复制# ansible-playbook -i inventory.yaml playbook.yaml1.如果不出意外, 会看到以下执行结果:

如果在执行过程中出现错误, 会看到很醒目的提示,并给出执行状态, 如图:

3.结果验证
首先我们看一下端口修改情况, 发现已经全部将SSH端口修改为2222端口,并可以全部以2222端口登录, 如图:

接着我们看一下IP限制情况, 上面登录的全部是在192.168.201.202机器上登录,而在我个人电脑上登录却失败,如图:

我们登录到三台机器上看一下防火墙规则, 已经按照剧本要求添加了对应规则,如图:
Tags:
转载:欢迎各位朋友分享到网络,但转载请说明文章出处“信息技术视野”。http://www.bziz.cn/news/132f599862.html
相关文章
2023年3.6亿人泄漏数据创历史新高,刺激数据加密需求
人工智能根据苹果公司近日发布的数据泄露报告,2023年全球数据泄漏规模将创下历史新高,前九个月有3.6亿人的敏感数据遭泄漏,比2022年全年高出20%。苹果公司在报告中强调了使用端到端加密来保护敏感数据的重要 ...
【人工智能】
阅读更多三星Note2(发挥Note2的优势,畅享游戏世界)
人工智能作为一款经典的智能手机,三星Note2在其发布之初就备受瞩目。其卓越的游戏性能和独特的大屏幕设计,使得Note2成为众多游戏爱好者的首选。本文将详细介绍如何利用三星Note2玩游戏,以及Note2在游 ...
【人工智能】
阅读更多数据中心结构化布线指南
人工智能随着数据流呈指数增长,数据中心空间和效率已成为企业的溢价因素。所有硬件和布线设计都必须是模块化和可扩展的,充分利用空间并考虑冷却和能源消耗问题。使用点对点布线和直接将设备相互连接的日子已经一去不复返了 ...
【人工智能】
阅读更多
热门文章
最新文章
友情链接
- 数据中心在冷却、成本和二氧化碳减排方面均未达到目标
- 苹果6s升级iOS11的体验(以苹果6s为例,探索iOS11的新特性和性能提升)
- Realtek 蓝牙安全连接配对漏洞可导致攻击者发起拒绝服务攻击
- 戴尔数据泄露事件:测试实验室平台遭 World Leaks 黑客组织入侵
- 探索2023年vivo最新款手机的革新之路(领先科技、卓越性能、引领未来)
- GitLab Duo AI 编程助手曝出提示注入漏洞 凸显AI助手的潜在风险
- 谷歌 Chrome 零日漏洞遭广泛利用,可执行任意代码
- 戴尔PowerEdge服务器 可轻松满足AI深度学习和高级计算等工作负载
- GitHub Actions漏洞攻击来袭,安全意识强的企业也难幸免 香港物理机b2b信息平台亿华云企业服务器云服务器网站建设源码库