开发性能优化+开发安全最大化

性能优化

1.优化数据库访问

1.1索引

        在数据库表中为需要频繁查询的列创建索引,可以提高查询效率。实质(空间换时间):顺指针找到对应指定值的行,index_name:索引名;column_list:指定字段

        1.11INDEX普通索引

        语句:ALTER TABLE table_name ADD INDEX index_name (column_list)

        1.12UNIQUE 唯一索引

        语句:ALTER TABLE table_name ADD UNIQUE (column_list)        

        1.13PRIMARY KEY 索引

        语句:ALTER TABLE table_name ADD PRIMARY KEY (column_list)

注意点:

        1.只要列中包含有 NULL 值都将不会被包含在索引中,复合索引中只要有一列含有 NULL 值,那么这一列对于此复合索引就是无效的。所以我们在数据库设计时不要让字段的默认值为NULL

        2.MySQL 查询只使用一个索引,因此如果 where 子句中已经使用了索引的话,那么 order by 中的列是不会使用索引的。因此数据库默认排序可以符合要求的情况下不要使用    

        3.在创建索引时,可以规定索引能否包含重复值。如果不包含,则索引应该创建为 PRIMARY KEY 或 UNIQUE 索引。

        4.对于单列唯一性索引,这保证单列不包含重复的值。对于多列唯一性索引,保证多个值的组合不重复。

        5.PRIMARY KEY 索引和 UNIQUE 索引非常类似。事实上,PRIMARY KEY 索引仅是一个具有名称 PRIMARY 的 UNIQUE 索引。这表示一个表只能包含一个 PRIMARY KEY,因为一个表中不可能具有两个同名的索引。

        6.在 where 从句,group by 从句,order by 从句,on 从句中虚线的列添加索引。索引字段越小越好(因为数据库数据存储单位是以“页”为单位的,数据存储的越多,IO 也会越大)。

        7.查询中与其它表关联的字段需要添加索引。

        8.对一些经常处理的业务表应在查询允许的情况下尽量减少索引。

        9.在 InnoDB 中,表都是根据主键顺序以索引的形式存放的,这种存储方式的表称为索引组织表。InnoDB 使用了 B+ 树索引模型,所以数据都是存储在 B+ 树中的。每一个索引在 InnoDB 里面对应一棵 B+ 树。在 InnoDB 里,主键索引(PRIMARY KEY)也被称为聚簇索引。非主键索引的叶子节点内容是主键的值。在 InnoDB 里,非主键索引也被称为二级索引。

        10.最左前缀原则是数据库查询优化中的一个重要概念,特别是在使用复合索引时。它要求在查询中使用的过滤条件必须从复合索引的最左边开始,并且不能跳过中间的列。
这意味着,如果有一个包含多个列的复合索引,如(A, B, C),那么查询条件中必须包含列A,并且可以包含列B和C,但不能只使用列C进行过滤,除非它是范围查询且需要单独建立索引。遵循这一原则的好处包括提高查询性能和减少索引占用的空间

1.2减少查询次数

        尽量合并多个查询语句,减少数据库的访问次数:读写分离

1.3使用缓存:将经常查询的数据缓存在内存中,减少对数据库的访问:

        (redis,mongdb,Memcached,sessionstorage,cookie,localstorage)

1.4消息中间件

2.优化代码逻辑

        2.1避免循环嵌套

        循环嵌套会消耗大量的CPU资源,尽量减少循环嵌套的使用。比如使用数据库函数

        2.2优化算法和数据结构

        选择适合问题的算法和数据结构,可以大大提高代码的执行效率。例如,使用哈希表代替数组进行查找操作,可以显著减少查找时间。

        2.3减少内存占用

        通过合理使用变量、释放不再需要的资源以及优化循环结构等方式,我们可以减少程序的内存占用,提高程序的稳定性

        2.4提取公共代码

        将重复的代码提取到公共函数或类中,减少代码的冗余度

        2.5简化复杂逻辑

        将复杂的逻辑拆分成多个简单的逻辑单元,使代码更加易于理解和维护

        2.6采用设计模式

        使用设计模式可以提高代码的可扩展性和可重用性,使代码更加健壮

3优化算法

        选择高效的算法可以减少计算量,提高代码的运行速度

4优化文件操作

        4.1缓存文件

        将经常使用的文件缓存在内存中,减少对文件的访问

        4.2减少文件系统操作

        尽量合并多个文件操作,减少文件系统的IO操作

        4.3使用异步操作

        对于需要长时间处理的任务,可以使用异步操作来避免阻塞主线程


5优化Web服务器

        5.1配置适当的缓存

         根据项目需求,配置适当的缓存策略可以提高Web服务器的响应速度

        5.2压缩和合并静态资源:

        对静态资源进行压缩和合并可以减少传输的数据量,提高网页的加载速度。    

        5.3使用缓存技术

        5.4使用缓存插件

        根据项目需求,选择适合的缓存插件可以显著提高PHP项目的性能。常见的缓存插件包括Redis、Memcached等

        5.5缓存查询结果

        将经常使用的查询结果缓存在内存中,减少对数据库的访问

        5.6缓存页面内容

        将经常访问的页面内容缓存在内存中,减少对文件的访问

        5.7负载均衡和水平扩展

        随着业务量的增长,单个服务器可能无法承受所有的请求。为了提高系统的可用性和可扩展性,可以使用负载均衡和水平扩展技术。以下是一些负载均衡和水平扩展的技巧

        5.8使用负载均衡器

        将请求分发到多个服务器上,提高系统的吞吐量和可扩展性。常见的负载均衡器包括Nginx、HAProxy等

        5.9水平扩展数据库

        将数据库水平扩展到多个节点上,提高数据库的处理能力。常见的水平扩展数据库解决方案包括MySQL Cluster、Redis Cluster等

        5.10水平扩展应用服务器

        将应用服务器水平扩展到多个节点上,提高系统的吞吐量和可扩展性。常见的水平扩展应用服务器解决方案包括PHP-FPM、FastCGI等

        5.11监控和日志记录

        监控和日志记录是PHP项目性能优化的重要环节之一。以下是一些监控和日志记录的技巧

        5.12使用监控工具

        选择适合的监控工具可以实时监控PHP项目的性能指标和系统资源的使用情况。常见的监控工具包括Zabbix、Nagios等

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

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

相关文章

5.大模型高效微调(PEFT)未来发展趋势

PEFT 主流技术分类 UniPELT 探索PEFT 大模型的统一框架(2022) UIUC 和Meta AI 研究人员发表的UniPELT 提出将不同的PEFT 方法模块化。 通过门控机制学习激活最适合当前数据或任务的方法,尤其是最常见的3大类PEFT 技术: Adapters…

事业单位——被逆袭篇

目录 一、结果 二、考试 三、时间 四、复习 五、总结 一、结果 图1:2024年浙江广播电视集团下属浙江省中波发射管理中心公开招聘笔面试结果 准考证号笔试面试总成绩排名备注107016070.866.48310702416555.44107134390.871.681入围107146869.869.08210715406454.…

征信受损,别再犯傻!

听说你的征信出了点小问题?别急,这事儿说大不大,但也不能掉以轻心。征信,说白了就是你借钱还钱的记录本,一旦它“花”了,借钱可就没那么轻松了。 先来说说这征信“花”了是咋回事 征信“花”了&#xff0c…

18.1 HTTP服务器-极简服务器、请求与响应

1. 极简服务器 大道至简。使用Go语言构建世界上最简单的HTTP服务器,仅需四行代码。 标准库的net/http包提供了多种用于创建HTTP服务器的方法,其中包括: http.HandleFunc("/", rootHandler) 第一参数:访问的url 第二…

常见的50道java面试题及答案【java学习+面试指南】(九)

maven是什么? Apache Maven是一个软件项目管理和理解工具。基于项目对象模型(POM)的概念,Maven可以从一个中心信息管理项目的构建,报告和文档。 项目构建 在eclipse中新建一个WEB工程。 进行编码及编写配置文件 对源代…

【Linux】进程间通信之命名管道

👦个人主页:Weraphael ✍🏻作者简介:目前正在学习c和算法 ✈️专栏:Linux 🐋 希望大家多多支持,咱一起进步!😁 如果文章有啥瑕疵,希望大佬指点一二 如果文章对…

109.网络游戏逆向分析与漏洞攻防-装备系统数据分析-商店与捨取窗口数据的处理

免责声明:内容仅供学习参考,请合法利用知识,禁止进行违法犯罪活动! 如果看不懂、不知道现在做的什么,那就跟着做完看效果 现在的代码都是依据数据包来写的,如果看不懂代码,就说明没看懂数据包…

【优选算法】详解target类求和问题(附总结)

目录 1.两数求和 题目: 算法思路: 代码: 2.!!!三数之和 题目 算法思路: 代码: 3.四数字和 题目: 算法思路: 代码: 总结&易错点&…

用人工智能写2024年高考作文

目录 用人工智能写2024年高考作文 引用 一、2024年 新课标I卷 作文真题 AI写作范文 二、2024年 全国甲卷 作文真题 AI写作范文 三、2024年 新课标II卷 作文真题 AI写作范文 四、2024年 北京卷 作文真题一 AI写作范文 作文真题二 AI写作范文 作文真题三 AI写作…

php 混合xml js,html 代码报错 ,结束标签关闭, short_open_tag 的作用,php关闭文件结束判断

结束标签关闭, short_open_tag 的作用,php关闭文件结束判断 有时候我们我们会将php,xml,js,html 混合编写 php文件只要开始标签而不要结尾标签? 混合代码看代码 直接运行 yntax error, unexpected version (T_STRING) in php…

验证码识别接口、多种样式验证码识别接口、中英文验证码识别接口

验证码识别接口、多种样式验证码识别接口、中英文验证码识别接口 本文提供一个基于OCR和机器学习的验证码识别接口,能够识别较复杂的中文、英文验证码,在OCR的基础上针对验证码进行算法优化。本接口是收费的(最低0.5分1次调用,试…

C语言详解(文件操作)2

Hi~!这里是奋斗的小羊,很荣幸您能阅读我的文章,诚请评论指点,欢迎欢迎 ~~ 💥💥个人主页:奋斗的小羊 💥💥所属专栏:C语言 🚀本系列文章为个人学习…

CSS id选择器

目录 任务描述 相关知识 id选择器 id选择器语法 类选择器与id选择器的区别 编程要求 任务描述 在本关中,你将通过id选择器的方式完成页面菜单栏样式布局,栏目导航等任务。 完成任务之后,基本页面效果如下: 动态效果如下&am…

IDEA:配置Golang的开发环境

1、下载&安装 进入GO的官网下载对应的GO 我们可以下载安装版,不过本人习惯下载解压版,这个因个人而异 2、配置环境变量 GOBIN : %GOROOT%\bin GOPATH : D:\MyGo 工作区间 GOROOT : D:\Program Files\Go GOJDK地址PATH: %GOBIN% ; %GOROOT%\bin ; …

生成性人工智能模型:行业和当局的机会和风险

1 目标受众和本文档目的 BSI(德国联邦信息安全办公室)通过本出版物面向考虑在其工作流程中使用生成性AI模型的公司和当局,以提高对这些模型的基本安全意识,并促进它们的安全使用。为此,除了机会外,它还突出…

Spring Boot整合Redis实现发布/订阅功能

😄 19年之后由于某些原因断更了三年,23年重新扬帆起航,推出更多优质博文,希望大家多多支持~ 🌷 古之立大事者,不惟有超世之才,亦必有坚忍不拔之志 🎐 个人CSND主页——Mi…

Kimichat使用案例012:用Kimichat拆解雷军在小米汽车SU7发布会上的演讲技巧

文章目录 一、介绍二、输入内容三、输出内容四、继续追问五、继续回答六、讲解对比七、对比回答相似之处:不同之处:八、职场人士如何借鉴九、借鉴内容一、介绍 小米SU7发布会可以说是非常成功。雷军的演讲技巧是发布会成功的重要因素之一,很值得借鉴学习。 可以借助Kimichat…

git服务器gitblit安装

1、下载 Gitblit 2、下载完后解压: 3、配制: 保存,退出编辑。 4、运行cmd,启用gitblit。 5、根据运行后的提示,也就是我们之间设置的port9990打开: 输入admin,admin就可以登录,这个账号密码&a…

[大模型]GLM4-9B-chat Lora 微调

本节我们简要介绍如何基于 transformers、peft 等框架,对 LLaMA3-8B-Instruct 模型进行 Lora 微调。Lora 是一种高效微调方法,深入了解其原理可参见博客:知乎|深入浅出 Lora。 这个教程会在同目录下给大家提供一个 nodebook 文件&#xff0c…

IP协议报文格式

IP协议报文格式 一: 报头格式1.1 : 4位版本1.2 : 4位首部长度1.3 : 8位服务类型 :1.4 : 16位总长度(字节数)1.5 : 8位生存时间(TTL)1.6 : 8 位协议1.7 : 32 位源IP / 32 位目的IP 一: 报头格式 1.1 : 4位版本 现在使用的也就只有IPv4,IPv6 1.2 : 4位首部长度 以 4字节为单位…