nginx的优化

news2024/11/25 7:06:48

目录

一 隐藏版本号在网页上面有nginx的版本号会让别人攻击你的服务器

二 nginx的优化之日志分割

三 nginx的优化之页面压缩

四 连接超时

五 nginx的并发设置

 七总结:nginx的优化


一 隐藏版本号在网页上面有nginx的版本号会让别人攻击你的服务器

如图所示

 第一种方法是关闭版本号的显示改配置文件

 重启nginx

systemctl restart nginx

 版本号就被隐藏起来了

第二种方法修改源码文件自定义版本号后打开隐藏的版本号(仅限于编译安装)

 

 重新编译安装

./configure \
--prefix=/usr/local/nginx \
--user=nginx \
--group=nginx \
--with-http_stub_status_module

make && make install

进入nginx的配置文件中把版本号打开 修改完重启服务

 之后打开浏览器版本号就变成这样了

二 nginx的优化之日志分割

 本身不带日志分割所有的日志分割都是以shell脚本来分割的

#!/bin/bash
d=$(date +%Y-%M-%d)  #获取年月日

dir="/usr/local/nginx/logs/"   #获取日志的路径

logs_file='/usr/local/nginx/logs/access.log' #定义需要分割的日志文件

logs_error='/usr/local/nginx/logs/error.log'
pid_file='/usr/local/nginx/logs/nginx.pid'  #定义nginx服务的pid文件
if [ ! -d $dir ]  #如果存放日志的目录不存在
  then
    mkdir $dir   #则创建日志目录
fi
mv ${logs_file} ${dir}/access_${d}.log #发送信号.给nginx主程序,让nginx生成新的日志文件

mv ${logs_error} ${dir}/error_${d}.log
kill -USER $(cat ${pid_file}) 

find $dir -mtime +30 -exec rm -rf {} \;  # 日志文件的清理,把三十天前的日志直接清除

 

授权并执行

 chmod 777 nginxlog.sh

./nginxlog.sh

 日志生成这两个文件代表成功

还需要设定时任务

croutab -e -u root

 

三 nginx的优化之页面压缩

nginx页面压缩 需要http中的gzip_module模块所提供的功能默认是注释掉的

gzip_min_length 1k;最小的压缩文件,小于1k就不再压缩了

gzip_buffers 4 64k; 压缩的缓冲区,4个64k缓冲区

gzip_http_version 1.1; 压缩版本,默认为1.1

gzip_comp_level 6; 压缩级别1-9不大不小,不快不慢正好

gzip_vary on; 支持前段缓存服务器的压缩功能打开

 gzip_types text/plain text/javascript application/x-javascript text/css text/xml application/xml  application/xml+rss image/jpg image/jpeg image/png image/gif application/x-httpd-php application/javascript application/json;

 完成后nginx -t检查有没有错误  在重启nginx服务

在打开网页进行验证

 图片缓存 避免重复访问,导致速度变慢,加快访问时间只针对静态页面,动态页面不设置缓存时间

完成之后ngint -t 在重启服务

在打开浏览器访问

四 连接超时

tttp :keepalive模式就是缓存时间 web服务器处理完一个请求之后保持tcp连接的时间 

keepalive一直保持打开状态会占用资源  一般都是设置的60s

五 nginx的并发设置

高并发保证快速相应,处理用户请求,避免阻塞

nginx工作的核心数要是服务器的核心数的两倍或者一致

最多给到八个,超过八个性能不在提升,会降低稳定性

六 防盗链防止别人盗用你的图片

 七总结:nginx的优化


1.隐藏版本号1.关闭版本号的显示2.修改源码文件自定义版本号后打开隐藏版本号的功能(仅限于编译安装)
2.日志的分割  按天数分割定时删除
3.nginx的页面压缩目的节约带宽,提高访问的速度针对静态页面 图片缓存
4.连接超时一般60s
5.nginx的并发设置 核心数的两倍最多不超过八个 指定工作的内核编号
6.防盗链防止别人盗用网站的图片

 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/684906.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

什么是 DOM?DOM树如何生成的?

什么是 DOM 文档对象模型(Document Object Model)。它提供了对文档结构化的描述,并将HTML页面与脚本、程序语言联系起来。 在渲染引擎中,DOM有以下几个层面的作用: 从页面来看,DOM就是生成页面的基本数据结构从JS脚本来看,DOM提…

前端 js 操作 Cookie 详细介绍与案例

1 前言 1.1 详细介绍 名称和值:Cookie由一个名称和对应的值组成。名称是一个字符串,用于标识Cookie,而值则是与名称相关联的数据。域名:每个Cookie都与特定的域名相关联。Cookie只会被发送到与其关联的域名下的请求中。路径&…

MybatisPlus多数据源原理与问题简析

文章目录 1. 使用1.1. 引包1.2 增加配置1.3 使用DS注解 2. 源码2.1 Configuration文件, 加载配置与bean注入2.1.1 配置类 2.2 注册DataSource2.2.1 获取所有的DataSource2.2.1.1 构建DataSource 2.2.2 对数据源分组 2.3 切换数据源2.3.1 DynamicDataSourceContextHolder2.3.2 D…

【LLMs 入门实战 】第一式:Vicuna 模型学习与实战

UC伯克利学者联手CMU、斯坦福等,再次推出一个全新模型70亿/130亿参数的Vicuna,俗称「小羊驼」,小羊驼号称能达到GPT-4的90%性能。 欢迎使用小羊驼🦙环境搭建权重下载下载 Vicuna Weight下载 LLAMA Weight构建真正的 working weigh…

InceptionNext实战:使用InceptionNext实现图像分类任务(一)

文章目录 摘要安装包安装timm安装 grad-cam 数据增强Cutout和MixupEMA项目结构计算mean和std生成数据集 摘要 论文翻译:https://wanghao.blog.csdn.net/article/details/131347001?spm1001.2014.3001.5502 官方源码:https://github.com/sail-sg/incept…

Spring Boot详细应用示例:构建一个简单的图书管理系统

文章目录 摘要正文1. 创建Spring Boot项目2. 配置数据库3. 创建实体类4. 创建数据访问层5. 创建业务逻辑层6. 创建控制器层7. 创建前端页面8. 添加身份验证9. 测试运行 小结 摘要 本文将介绍如何使用Spring Boot框架构建一个简单而完整的图书管理系统。通过这个示例&#xff0…

学术小技巧:如何使用easyscholar来提高论文查找效率

0 摘要 easyScholar是一款很好用的科研插件,可以显示会议期刊登记,支持轻量翻译,一键下载等等功能。 1 效果预览 可以直接显示SCI分区,目前中科院SCI分区基础版是免费的,升级版要收费。 目前支持的网站有&#xff1…

【C++】红黑树的插入实现

目录 红黑树的概念红黑树的性质 红黑树节点的定义红黑树的插入操作当p(父节点)在g(祖父节点)左子树grandfather->_left parent当p(父节点)在g(祖父节点)右子树grandfather->_right parent 📖 前言 本篇文章中红黑树的插入用到左单旋和右单旋在AVL树的插入中…

【Python】python进阶篇之面向对象编程

面向对象编程 封装、继承、多态 封装:提高程序安全性 将数据(属性)和行为(方法)包装到类中。在方法内部对属性进行操作,在类的外部调用方法。无需关心方法内部的具体实现细节,从而隔离代码复杂…

生成器模式(Builder)

定义 生成器是一种创建型设计模式,使你能够分步骤创建复杂对象。该模式允许你使用相同的创建 代码生成不同类型和形式的对象。 前言 1. 问题 假设有这样一个复杂对象,在对其进行构造时需要对诸多成员变量和嵌套对象进行繁复的初始化工作。这些初始化…

体验Vue神奇的响应式原理:让你的应用更快、更流畅

文章目录 I. 引言介绍Vue.js的响应式原理及其重要性概述本文的内容 II. 数据劫持解释什么是数据劫持Vue如何实现数据劫持示例说明 II. 依赖收集解释什么是依赖收集Vue如何实现依赖收集示例说明 IV. 派发更新解释什么是派发更新Vue如何实现派发更新示例说明 V. 响应式原理运作流…

数据仓库建设指导说明

文章目录 1、概念2、数仓特点3、数仓架构3.1、数据集市3.2、Inmon 架构3.3、Kimball 架构3.3.1、表分区3.3.1.1、事实表3.3.1.2、维度表3.3.1.2.1、维表设计步骤3.3.1.2.2、维度设计的建议3.3.1.2.3、主键设计3.3.1.2.4、缓慢变化维 SCD3.3.1.2.5、维表的整合与拆分3.3.1.2.5.1…

Verdi 之配置及波形打开

目录 写在前边 1.verdi的配置 2. 波形的产生及打开 写在前边 本部分内容主要对Verdi的学习进行总结,大概分三篇文章进行叙述。 1.verdi的配置 1.首先打开.bashrc文件进行环境配置 2.Verdi 配置如下: verdi_HOME: 配置Verdi的home目录&#xff0…

如何制作数字人的模型

首先我们先来了解一下什么是数字人,根据 中国人工智能产业发展联盟发布的《2020年虚拟数字人发展白皮书》指出,数字人意 指具有数字化外形的虚拟人物,除了拥有人的外观、人的行为之外,还拥有人的思想,具有识别外界环境…

【深入浅出RocketMQ原理及实战】「底层原理挖掘系列」透彻剖析贯穿RocketMQ的消息顺序消费和并发消费机制体系的原理分析

透彻剖析贯穿RocketMQ的消息顺序消费和并发消费机制体系的原理分析 DefaultMQPushConsumerImpl拉取消息consumeMessageService的并发消费和顺序消费并发消费顺序消费concurrently 创建 ConsumeRequestconcurrently ConsumeRequest#run 消费主体逻辑消费结束之后清除数据 orderl…

黑马程序员前端 Vue3 小兔鲜电商项目——(十)订单页

文章目录 路由配置和基础数据渲染模板代码配置路由封装接口渲染数据 切换地址-打开弹框交互切换地址-地址切换交互生成订单支付页组件封装订单接口绑定事件 路由配置和基础数据渲染 模板代码 新建 src\views\Checkout\index.vue 文件,添加以下代码: &…

容器管理中关于CGroup的那些事

前言 在一个docker宿主机上可以启动多个容器,默认情况下,docker并没有限制其中运行的容器使用硬件资源。 但如果在实际环境中,容器的负载过高,会占用宿主机大量的资源。这里的资源主要指的CPU,内存,和IO带…

Python Pandas 筛选数据以及字符串替换

str.replace使用示例 假设有一个DataFrame df,其中有一个列名为text,包含一些文本字符串: import pandas as pd data {text: [hello world, foo bar, hello there]} df pd.DataFrame(data) 我们可以使用str.replace方法来替换字符串。比…

操作系统——Linux 进程控制

一、实验题目 Linux 进程控制 二、实验目的 通过进程的创建、撤销和运行加深对进程概念和进程并发执行的理解,明确进程和程序之间的区别。 三、实验内容(实验原理/运用的理论知识、算法/程序流程图、步骤和方法、关键代码) (…

开源网安S-SDLC解决方案,为银行打造主动防御的安全体系

​某银行是全国上市最早的一批股份制商业银行,总部位于深圳,在全国拥有上百家分行、上千家营业机构,资产总额达数千亿元。近年来,该银行围绕数据化、智能化、生态化,全力打造“数字银行”,助力建设“数字中…