简单的LNMP安全加固
安全加固
Nginx安全加固:
Nginx配置文件 (nginx.conf):/usr/local/nginx/nginx.conf
禁用autoindex:
autoindex:是Nginx的目录浏览功能,如果不禁用该功能,就可以通过URL访问查看目录中的文件
为了防止文件目录的泄露我们必须要禁用autoindex
:off或者不配置
关闭服务器标记:
Nginx默认每个返回的页面携带版本信息,我们需要设置server_tokens off;
关闭服务器标记(隐藏版本信息)
自定义缓存:
限制缓冲区溢出攻击,配置http_server{}如下:文章推荐
client_body_buffer_size 20k; //设置用于请求主体的缓冲区大小
client_header_buffer_size 1k; // 请求头分配一个缓冲区大小
client_max_body_size 1m; //设置NGINX能处理的最大请求主体大小
large_client_header_buffers 4 8k; //读取大型客户端请求头的缓冲区的最大数量和大小
# client_body_temp_path [temp]指定存储请求正文的临时文件的位置
# client_body_in_single_buffer [off/on]指令设置NGINX将完整的请求主体存储在单个缓冲区中
# client_body_in_file_only [off/clean/on] 禁用NGINX缓冲区并将请求体存储在临时文件中
设置(超时)timeout:
在http{}
设置:配置介绍
client_body_timeout 10;//指定客户端与服务端建立连接后发送 body 的超时时间
client_header_timeout 30;//指定客户端与服务端建立连接后发送 header 的超时时间
keepalive_timeout 60;//无状态协议,发送tcp请求,服务器响应[time]后断开连接
send_timeout 30; //服务端向客户端传输数据的超时时间。
配置日志:
系统有默认的格式日志,但是被注释了,取消注释就可以了
限制请求访问:
限制只允许GET|HEAD|POST等HTTP请求方法~~~
黑名单IP:
在server{}
配置选项中:
location /{
allow 192.168.2.0/24; //允许的IP
deny 192.168.1.0/24; //拒绝的IP
deny all; //拒绝其它IP
}
在Nginx配置文件中进行许多安全加固:
屏蔽了目录和服务器标记
定义了超时和缓存定义
对访问机制进行了限制
CentOS安全加固:
检查预留账号:
$ cat /etc/passwd
$ cat /etc/shadow
$ cat /etc/group
系统中保留一些账号,(bin,sys,adm……)
为了安全起见,生产环境下的系统都会将这些没有用的 账户锁定
锁定账号:
$ passwd -l <username> //锁定账号
$ passwd -u <username> //解锁账号
检查空口令:
$ awk -F ":" '($2=="!"){print $1}' /etc/shadow
如果发现空口令账号可以添加密码:
$ passwd <username>
密码策略:
$ cat /etc/login.defs // 查看密码策略设置
PASS_MAX_DAYS 用户密码的使用天数
PASS_MIN_DAYS 最小时间间隔修改密码
PASS_MIN_LEN 密码最小长度
PASS_WARN_AGE 密码过期前N天提示
检查其它超级用户:
正所谓军队只能有一个最高领导人~Linux系统管理也是如此,只得有一个超级用户root,
$ awk -F ":" '($3=="0"){print $1}' /etc/passwd # 检查用户ID为0的用户
限制能够su为root的用户:
$ cat /etc/pam.d/su
加固:
添加:auth required /lib/security/pam_wheel.so group=wheel
限制只有 wheel
组的用户可以su到root
文件操作属性:
将重要的文件添加不可改属性chattr +i <File_name>
SSH安全:
禁止root用户进行ssh登录~
$ vi /etc/ssh/sshd_config
设置PermitRootLogin
为no
账户爆破锁定系统:
$ vi etc/pam.d/system-auth
设置密码错误N次,锁定time秒
auth required pam_tally.so oneer=filad deny-<N> unlock_time=<time>
无操作退出登录:
$ vi /etc/profile TMOUT=<time>
time秒无效操作后自动退出登录
命令记录安全:
$ vi /etc/profiel
修改HISTSIZE=<N>
属性值,限制历史记录N条命令记录
系统日志策略配置:
$ ps -aef | grep syslog //查看syslog服务是否开启
$ cat /etc/rsyslog.conf //查看syslogd配置
/var/log/cron //crom日志
/var/log/messages // 系统日志
/var/log/secure // 安全日志
简单的LNMP安全加固的更多相关文章
- 0123简单配置LNMP
简单配置LNMP不怕出现错误,就怕错误不知道出现在哪里?看日值tail -f /var/log/message -- 系统整个的日志tail -f /var/log/nginx/error.log - ...
- centos7 简单搭建lnmp环境
1:查看环境: 1 2 [root@10-4-14-168 html]# cat /etc/redhat-release CentOS release 6.5 (Final) 2:关掉防火墙 1 [r ...
- android加固系列—2.加固前先要学会破解,调试内存值修改程序走向
[版权所有,转载请注明出处.出处:http://www.cnblogs.com/joey-hua/p/5138585.html] 因公司项目需要对app加固,经过本人数月的研究,实现了一套完整的仿第三 ...
- WDCP LNMPA和LNMP 504 Gateway time-out错误的解决方法
Nginx的特点是处理静态很给力,Apache的特点是处理动态很稳定,两者结合起来便是LNMPA,nginx处理前端,apache处理后端,这样处理静态会很快,处理动态会很稳定.当我以为安装完成以后便 ...
- 网易易盾最新一代Java2c加固究竟有什么厉害之处?
导语:几个月前,网易易盾正式推出Java2c加固.它以独有的"静态保护"技术,使得应用程序中的代码出现"下沉",达到不可逆的效果,兼顾"冷热启动时间& ...
- APK加固之静态脱壳机编写入门
目录: 0x00APK加固简介与静态脱壳机的编写思路 1.大家都知道Android中的程序反编译比较简单,辛苦开发出一个APK轻易被人反编译了,所以现在就有很多APK加固的第三方平台,比如爱加密和梆梆 ...
- lnmp环境快速搭建及原理解析
刚开始学习php的时候是在wamp环境下开发的,后来才接触到 lnmp 环境当时安装lnmp是按照一大长篇文档一步步的编译安装,当时是真不知道是在做什么啊!脑袋一片空白~~,只知道按照那么长的一篇文档 ...
- centos7 安装php7+mysql5.7+nginx+redis
.1.先修改yum源 https://webtatic.com rpm -Uvh https://dl.fedoraproject.org/pub/epel/epel-release-latest- ...
- 一次Debug过程的思考
前一段时间,部门接入了新业务,由于业务量小,架构非常简单,采用了最简单的LNMP架构,整个项目是交给一个刚毕业的RD负责的,这是背景. 上线前半天,服务平稳运行.下午的时候,开始收到大量报警:No h ...
随机推荐
- Cesium专栏-terrain地形、3dtiles模型、gltf模型 高度采样
在Cesium中,对于terrain地形.3dtiles模型.gltf模型的高度采样是一个很基本的功能,基于此,可以做一些深度应用,而Cesium已经帮我们提供了相应的API,在这里,我帮大家总结一下 ...
- JS + Canvas画图Demo
直接上代码,复制粘贴就能用: <%@ page language="java" contentType="text/html; charset=UTF-8" ...
- Android 开机充电图标和充电动画
首先驱动需要先获取到2个power supply kernel\msm-3.18\drivers\usb\phy\phy-msm-usb.c motg->usb_psy.name = " ...
- (办公)记事本_Linux常用的文件操作命令
参考尚硅谷的谷粒学院的linux教程:http://www.gulixueyuan.com/course/300/task/7080/show 好吧,其实一个命令他要是讲超过20分钟,我就去看菜鸟教程 ...
- 今天遇到的一些关于vsftp的坑!!!
起因:最近在捣鼓Linux,配置vsftp的时候发现权限问题很坑,头疼了一天,发现了一点小问题 常见的身份验证方式: 1.使用系统的用户认证 例如vsftp这种软件,如果想建立一个可以登录FTP的用户 ...
- 关联mysql失败_Server returns invalid timezone. Go to 'Advanced' tab and set 'serverTimezon'
关联mysql失败_Server returns invalid timezone. Go to ‘Advanced’ tab and set ‘serverTimezon’ 时区错误,MySQL默认 ...
- sap-abap 权限控制
FORM AUTH_CHECK . "工厂 LOOP AT S_WERKS. AUTHORITY-CHECK OBJECT 'M_BANF_WRK' ID 'WERKS' FIELD S_W ...
- PlayJava Day028
1.网络程序中套接字(Socket)用于将应用程序与端口连接起来 套接字是一个假想的连接装置,就像插插头的设备”插座“,用于连接电器与电线,如下所示 客户端:应用程序 <----> Soc ...
- js-函数的三种创建方式
1.声明式 function fn() { //do something } 2.函数表达式 let fn = function () { //do something } 3.构造函数 functi ...
- solo升级以及自动化更新的方法
使用solo过程总涉及到更新问题,所以就在这里把solo更新的方法总结一下.希望能给小伙伴们一些帮助.如何选择更新方法主要是跟你的部署方式有关,如果你是通过 docker方式进行部署,那么你可以还可以 ...