update ELK (日志采集、分析、报警) update knockd (解决动态IP防火墙设定)update smokeping(网络质量监控)update vagrant(虚拟机外挂) TCPcopy这个神器,貌似很多人都还在用着ab模拟测压力,TCPcopy能直接导入线上流量供上线前的风险测试。
下面对使用过的工具会简单进行功能及使用场景介绍,并提及一些所了解的工具。统一帐号管理你还在自己写脚本批量增加机器的用户、分组和修改密码或者同步主机的/etc/passwd吗?你还在使用脚本批量对用户设置权限吗?如果有一台帐号主机能够提供所有服务器的帐号、密码、权限控制,如此一来,如果想要增加、修改、刪除用户,只要到这台服务器上面处理即可,这样是不是很方便?1. LDAP统一管理各种平台帐号和密码,包括但不限于各种操作系统(Windows、Linux)认证,Linux系统sudo集成(限制用户的sudo权限以及使用sudo的主机),用户可主机登入限制等可与Apache,HTTP,FTP,SAMBA,ZABBIX,Jenkins等集成实现多个平台用同一套帐号密码支持密码策略定制(限制用户密码强度、密码过期时间、强制修改、超过验证错误次数锁定帐号)等支持插件式鉴别模块PAM不同平台权限的设定、划分2. jumpserver一款国内开源的由python编写开源的跳板机(堡垒机)系统,能够实现操作审计(包括文本命令,实时、事后用户操作录像回放),利用ansible批量对机器进行操作。
基于ssh协议来管理,客户端无需安装agent,能够让用户通过网页端或者shell操作有权限的机器。自动化部署1. Fabric优点:小巧,无需装agent,基于SSH,可以在本地、远程主机上运行所有的shell命令和python函数。主要提供运行本地、远程命令,上传、下载文件功能。适合用来写不常用、碎片化的工具缺点:内置模块较少,很多东西要自己编写命令实现。
2. Ansible优点:基于ssh实现,无需agent日常部署需要的功能基本上有模块支持,比如git、打包解压、copy文件、yum安装等等都已经集成到了核心模块里面,alternatives、xattr等模块也有,当然,理论上所有操作都能用命令模块来完成。缺点:比较依赖网络的健壮性,网络不好的话经常会有失败的现象运行ansible的主机需要能与远程主机ssh直连,不过可以用Proxycommand或者sshuttle来解决其他的还有SaltStack、Puppet、Chef、func等。
DNS1. dnsmasq 提供 DNS 缓存,DNS重定向、记录转发,DNS反向解析, DHCP 服务功能,配置简单 可以配置对上层DNS轮询请求记录 配置支持通配符,不用批量修改hosts2. pdnsd 提供DNS缓存服务 设置向上级DNS请求方式(TCP、UDP,Both) 设置多个上级DNS并设置请求规则 配置缓存保留时间3. namebench Google自行研发的一款DNS测速工具压力测试1. ApacheBench 创建多并发线程模拟多用户对URL访问进行压力测试 Apache中有个自带的,名为ab的程序,ab可以创建很多的并发访问线程,模拟多个访问者同时对某一URL地址进行访问。
2. TCPcopy、UDPcopy实时将TCP/UDP数据包copy到另一机器进行压力测试提到压力测试,可能大多数人首先想到的就是ApacheBench,但ab是模拟访问,模拟毕竟是模拟,然而线上会遇到的错误可能往往无法预知,其实国内已经有人开发了一款线上流量copy的工具,就是TCPcopy、UDPcopy,能够之间copy线上流量到测试环境,大大减少了上线前的风险。
支持设置copy流量倍数放大、缩小,修改流量的客户端IP源地址。3. TCPburn类似ApacheBenchtcpburn是由网易自主研发的能够模拟千万级别并发用户的一个软件,目的是能够用较少的资源来模拟出大量并发用户,并且能够更加真实地进行压力测试, 以解决网络消息推送服务方面的压力测试的问题和传统压力测试的问题。
4. goreplay用于对HTTP压力测试的实时流量复制安全1. PortSentry对端口扫描的机器做防御策略特点:给出虚假的路由信息,把所有的信息流都重定向到一个不存在的主机;自动将对服务器进行端口扫描的主机加到TCP-Wrappers的/etc/hosts.deny文件中利用Netfilter机制、包过滤程序,比如iptables和ipchain等,把所有非法数据包(来自对服务器进行端口扫描的主机)都过滤掉;通过syslog()函数给出一个目志消息,甚至可以返回给扫描者一段警告信息。
2.fail2ban对SSH密码暴力破解的机器做防御策略防御 SSH 服务器的暴力破解攻击,对安全性要求过高的服务器还是建议禁止密码登入,使用密钥或者密钥 密码验证。3. Google Authenticator可以将第二部验证设置为通过短信或语音电话接收验证码,同时也支持 Android、iPhone 或 BlackBerry 设备来生成验证码。