Linux系统部署规范v1.0
- Linux系统部署规范v1.0
- 目的:
- 1、尽可能减少线上操作;
- 2、尽可能实现自动化部署;
- 3、尽可能减少安装服务和启动的服务;
- 4、尽可能使用安全协议提供服务;
- 5、尽可能让业务系统单一;
- 6、尽可能监控可监控的一切信息;
- 7、尽可能控制一切可控制的安全策略;
- 8、尽可能定期更新补丁修补漏洞;
- 具体规范:
- A、 帐户和口令
- 帐户:
- 1.为每个系统维护人员建立一个独立的普通权限帐号,为监控机建立监控帐号,分别用于日常系统维护和系统监控;
- 2.FTP 服务器配置虚拟帐号;
- 3.禁止除root 帐号, 系统维护人员帐号和监控机帐号之外所有帐号使用SHELL的权限;
- 4.锁定所有在安装系统时自动建立的帐号;
- 口令:
- 1.强度:15位以上;包含了字母(大写字母和小写字母),数字和特殊符号;不允许包含英文单词;
- 2.更改频率:120天;
- 3.推荐的选择口令的方法:想出一个句子,用其中每个单词的首字母及其包含的符合,并将字母替换为跟其相似的数字或符号来生成口令,但依据第一条而定;
- B、 程序部署
- 1、 部署前注意检查是否有冲突业务端口以及程序;
- 2、 采用自动化安装脚本部署至约定目录;
- 3、 部署完成后删除临时文件以及具有保密约束的信息文件;
- 4、 命令操作时不要直接带密码操作;如:mysql –uroot –p123456
- 5、 服务部署完成后,轻易不要更改系统环境,以免引起业务故障;
- C、 系统优化
- 调整如下内核参数,以提高系统防止IP欺骗及DOS攻击的能力:
- 范例:
- net.ipv4.ip_forward = 0 # 对于LVS,网关或VPN服务器,要设置为1
- net.ipv4.tcp_syncookies = 1
- net.ipv4.conf.all.accept_source_route = 0
- net.ipv4.conf.all.accept_redirects = 0
- net.ipv4.conf.all.rp_filter = 1 # 对于LVS 后端服务器,要设置为0
- net.ipv4.icmp_echo_ignore_broadcasts = 1
- net.ipv4.icmp_ignore_bogus_error_responses = 1
- net.ipv4.conf.all.log_martians = 1
- kernel.sysrq = 0
- kernel.core_uses_pid = 1
- D、服务优化和安全
- 1、具体性能优化,依据硬件而定,一般需要修改的较少,视情况而定;
- 2、服务安全
- 仅供参考:
- Apache
- 1、 隐藏版本号
- ServerTokens ProductOnly
- ServerSignature Off
- 或
- ServerTokens Prod
- ServerSignature Off
- 2、 禁用符号链接
- 3、 使用特定用户运行nobody
- 4、 指定监听的端口和ip(如不需多ip提供服务)
- 5、 根目录权限
- 6、 mod_security是一个集入侵检测和防御引擎功能的开源web应用安全程序(或web应用程序防火墙).它以Apache Web服务器的模块方式运行, 目标是增强web应用程序的安全性, 防止web应用程序受到已知或未知的攻击.
- 7、 mod_evasive 是Apache(httpd)服务器的防DDOS的一个模块
- 8、 mod_cband模块,可以限制用户和虚拟主机带宽。包括:带宽限额,最高下载速度,每秒访问请求速度和最高并发访问ip连接数
- PHP
- 1、隐藏版本号
- 2、禁止远程文件功能
- 3、提升程序安全性
- 4、不显示错误信息,需要查错时开启
- 5、禁止全局变量(视情况而定)
- sed -i ‘s/expose_php = On/expose_php = Off/g’ /home/system/php/lib/php.ini
- sed -i ‘s/allow_url_fopen = On/allow_url_fopen = Off/g’ /home/system/php/lib/php.ini
- sed -i ‘s/magic_quotes_gpc = Off/magic_quotes_gpc = On/g’ /home/system/php/lib/php.ini
- sed -i ‘s/display_errors = On/display_errors = Off/g’ /home/system/php/lib/php.ini
- sed -i ‘s/ register_globals= On/ register_globals= Off/g’ /home/system/php/lib/php.ini
- 5、php-ids
- 6、用Suhosin加强PHP脚本语言安全性
- Mysql
- 1.修改root用户口令,删除空口令
- 2.删除默认test数据库
- 3.使用独立用户运行msyql
- 4.禁止远程连接数据库(根据需要开通特定IP)
- 5.限制连接用户的数量
- 6、严格控制用户权限:仅给予用户完成其工作所需的最小的权限;禁止授予PROCESS, SUPER, FILE 权限给非管理帐户;
- 7、禁止将MySQL数据目录的读写权限授予给mysql用户外的其它OS 用户;
- E、系统安全
- 安全措施仅供参考,因软件实现的基本只对小量攻击有效,遇到大量攻击交由硬件防火墙处理。
- 针对Centos系统的安全措施
- 1、 开启iptables
- 限制端口扫描;
- 针对业务开启相应端口;
- 针对来源ip限制不对外的端口访问;
- 2、 安装ossec-hids入侵检测程序
- OSSEC是一款开源的入侵检测系统,包括了日志分析,全面检测,rook-kit检测。
- 3、 针对攻击的防护
- 针对少量syn-flood攻击的防护
- echo “1″ > /proc/sys/net/ipv4/tcp_syn_retries
- echo “1″ > /proc/sys/net/ipv4/tcp_synack_retries
- echo “1″ > /proc/sys/net/ipv4/tcp_syncookies
- echo “4096″ > /proc/sys/net/ipv4/tcp_max_syn_backlog
- 针对少量ddos攻击的防护
- 第一种方法:
- Installation
- wget http://www.inetbase.com/scripts/ddos/install.sh
- chmod 0700 install.sh
- ./install.sh
- Uninstallation
- wget http://www.inetbase.com/scripts/ddos/uninstall.ddos
- chmod 0700 uninstall.ddos
- ./uninstall.ddos
- 第二种方法:
- [root@ddos]# cat ddos.sh
- #!/bin/bash
- /bin/netstat -na|grep ESTABLISHED|awk ‘{print $5}’|awk -F: ‘{print $1}’|sort|uniq -c|sort -rn|head -10|grep -v -E ’192.168|127.0′|awk ‘{if ($2!=null && $1>4) {print $2}}’>/tmp/dropip
- for i in $(cat /tmp/dropip)
- do
- /sbin/iptables -I INPUT -s $i -j DROP
- /sbin/iptables -D INPUT -s 122.228.193.245 -j DROP
- echo “$i kill at `date`”>>/var/log/ddos
- done
- [root@ ddos]#
- 针对ARP攻击的防护
- 在硬件设备上对IP+MAC绑定
- 交由机房做双向绑定(付费)
- 针对CC攻击的防护
- 限制单位时间内的连接数:
- Windows Server的防护
- (1)、安装[赛门铁克终端保护12.小企业版].ENDPOINT_12,对病毒以及端口扫描等做防护;
- (2)、开启防火墙、ipsec。
- F、安全审计
- 审计对象 工具 频次
- Linux系统 nmap 1个月
- nessus 3个月
- 口令文件 John the ripper 3个月
- Web业务 Nikto 1个月
- appscan 1个月
- Zed Attack Proxy 1个月
- Skipfish 1个月
- 注:新安装的服务器必须经过安全审计才允许投入产品环境;
- 新发布了应用后,必须立即进行安全审计;
- G、监控和报警
- 1、采用nagios针对不同硬件不同业务进行监控,给予相应的阈值,提供报警;
- 2、采用cacti针对系统历史数据生成性能图表,便于故障处理和预防;
- 总结:
- 以上规范只限于了解系统部署实施需要注意的事项,可以理解为,安装部署,性能安全,故障报警等各阶段性的工作内容,每一项都需要具体实施操作,虽不严格要求按照文档说明一项项完成,但必须在每一阶段都做相应的处理,以保障业务系统的
http://www.brentron.com/xitong/linux/6344.html
Linux系统部署规范v1.0的更多相关文章
- Linux系统部署体验中心
Linux系统部署体验中心 安装Linux虚拟机 1. 下载安装VMware,安装64位Linux系统(Ubuntu),要求:CPU双核,2G内存,60G硬盘 2. 安装系统时,选择安装ssh服务 ...
- Linux系统部署JavaWeb项目(超详细tomcat,nginx,mysql)
转载自:Linux系统部署JavaWeb项目(超详细tomcat,nginx,mysql) 我的系统是阿里云的,香港的系统,本人选择的是系统镜像:CentOS 7.3 64位. 具体步骤: 配置Jav ...
- Linux系统部署WEB项目(2020最新最详细)
2020最新Linux系统发行版ContOS7演示部署WEB项目 为防止操作权限不足,建议切换root用户,当然如果你对Linux命令熟悉,能够自主完成权限更新操作,可以不考虑此推荐. 更多命令学习推 ...
- 腾讯云linux系统部署项目无法通过外网访问
最近尝试使用了一下腾讯去的linux系统服务器,但是却遇到各种问题,下面记录的问题是项目部署完成后却无法通过外网访问. 服务器:腾讯云 系统 :CentOS 8.0 64位 处理思路:通过度娘百般摸索 ...
- Linux系统部署Web项目
首先,需要有java环境和tomcat服务器,至于这个怎么安装,可以参考:云服务器 java+tomcat 部署与配置 项目部署 有两个大步骤: Step1 将已经写好的web项目打包成war包,在I ...
- 基于阿里云服务器Linux系统部署JavaWeb项目
前段时间刚完成一个JavaWeb项目,想着怎么部署到服务器上,边学边做,花了点时间终于成功部署了,这里总结记录一下过程中所遇到的问题及解决方法.之所以选择阿里云,考虑到它是使用用户最多也是最广泛的云服 ...
- Demo客户端相关规范 v1.0
目录 开发环境 开发工具 代码管理 项目代码 分支管理 名称管理 打包管理 存储路径 存储结构 测试包 正式包 名称管理 依赖组件 内部组件 外部组件 解决方案结构 解决方案命名 解决方案文件夹 项目 ...
- linux系统部署安装过程
1. 虚拟环境安装 1.新建虚拟机 2.虚拟机设置 2.系统历程 1.进入系统引导界面进行配置 引导项说明: 1.安装centos 系统 ...
- linux系统中实现mongodb3.0.5数据库自动备份
最近两天,因公司业务需要,要定期备份mongodb数据库中的数据. 查了很多资料后,发现mongodb似乎并没有自带的定时备份功能,于是只好转移目标到linux系统的定时任务上,于是学习并使用了cro ...
随机推荐
- eval 捕获dbi错误
[root@dr-mysql01 ~]# cat t2.pl use DBI; my $dbUser='zabbix'; my $user="root"; my $passwd=& ...
- PLSQL数据导入
导入数据 (1) 首先以管理员身份登录plsql; (2) 新建命令窗口 (3) 创建用户,设置帐号,密码 创建语句:create user usernameidenti ...
- 【Unity3D】【NGUI】UILabel
原文:http://www.tasharen.com/forum/index.php?topic=6706.0 NGUI讨论群:333417608 概述 UILabel是用来显示文本的脚本,继承自UI ...
- TPL异步并行编程之简单使用
并行编程一直是一个老生常谈的话题 在这里记录一下TPL编程,这在net4.0 微软就已经提供了多核时代下的并行库,其中最核心的最常用的也就是Task 一 Task是什么 Task可以简单的理解为一个线 ...
- SetFocus、SetCapture和SetActiveView的区别
1. SetActiveView是MFC框架内的一个函数, 而不是SDK中的函数, 也就是说SDK中没有ActiveView这个概念, 只有在MFC中才有2. SetFocus是SDK中的函数(当然M ...
- 怎样使用jsp实现header和footer与网页内容的分离
好多显示层框架都自带这样的功能JSF,Wicket,页面布局取决于项目使用的显示层框架. 前台即客户端的布局,通常用在无需跳转的页面.比如同样是用户管理页面,增删改查的操作都希望停留在同一个页面.这时 ...
- Nancy.Host的Web应用
Nancy.Host实现脱离iis的Web应用 本篇将介绍如何使用Nancy.Host实现脱离iis的Web应用,在开源任务管理平台TaskManagerV2.0代码里面已经使用了Nancy.Host ...
- jQuery EasyUI API 中文文档 - 菜单按钮(menubutton)
<html> <head> <script src="jquery-easyui/jquery.min.js"></script> ...
- opencv中的meanshift图像切割
Meanshift(均值漂移)是一种在一组数据的密度分布中寻找局部极值的稳定的方法.Meanshift不仅能够用于图像滤波,视频跟踪,还能够用于图像切割. 通过给出一组多维数据点,其维数是(x,y,r ...
- Android资源管理框架(Asset Manager)简介和学习计划
Android该应用程序包括两个部分组成的:代码和资源. 资源主要是与UI相关的东西,例如UI布局.和其他字符串和照片.代码和资源可以使独立的应用程序来组织的实际需求的基础上,在执行的时候UI.,就能 ...