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

2024-06-11 11:52

本文主要是介绍开发性能优化+开发安全最大化,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

性能优化

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.chinasem.cn/article/1051098

相关文章

基于Qt开发一个简单的OFD阅读器

《基于Qt开发一个简单的OFD阅读器》这篇文章主要为大家详细介绍了如何使用Qt框架开发一个功能强大且性能优异的OFD阅读器,文中的示例代码讲解详细,有需要的小伙伴可以参考一下... 目录摘要引言一、OFD文件格式解析二、文档结构解析三、页面渲染四、用户交互五、性能优化六、示例代码七、未来发展方向八、结论摘要

在 VSCode 中配置 C++ 开发环境的详细教程

《在VSCode中配置C++开发环境的详细教程》本文详细介绍了如何在VisualStudioCode(VSCode)中配置C++开发环境,包括安装必要的工具、配置编译器、设置调试环境等步骤,通... 目录如何在 VSCode 中配置 C++ 开发环境:详细教程1. 什么是 VSCode?2. 安装 VSCo

正则表达式高级应用与性能优化记录

《正则表达式高级应用与性能优化记录》本文介绍了正则表达式的高级应用和性能优化技巧,包括文本拆分、合并、XML/HTML解析、数据分析、以及性能优化方法,通过这些技巧,可以更高效地利用正则表达式进行复杂... 目录第6章:正则表达式的高级应用6.1 模式匹配与文本处理6.1.1 文本拆分6.1.2 文本合并6

C#图表开发之Chart详解

《C#图表开发之Chart详解》C#中的Chart控件用于开发图表功能,具有Series和ChartArea两个重要属性,Series属性是SeriesCollection类型,包含多个Series对... 目录OverviChina编程ewSeries类总结OverviewC#中,开发图表功能的控件是Char

鸿蒙开发搭建flutter适配的开发环境

《鸿蒙开发搭建flutter适配的开发环境》文章详细介绍了在Windows系统上如何创建和运行鸿蒙Flutter项目,包括使用flutterdoctor检测环境、创建项目、编译HAP包以及在真机上运... 目录环境搭建创建运行项目打包项目总结环境搭建1.安装 DevEco Studio NEXT IDE

Python开发围棋游戏的实例代码(实现全部功能)

《Python开发围棋游戏的实例代码(实现全部功能)》围棋是一种古老而复杂的策略棋类游戏,起源于中国,已有超过2500年的历史,本文介绍了如何用Python开发一个简单的围棋游戏,实例代码涵盖了游戏的... 目录1. 围棋游戏概述1.1 游戏规则1.2 游戏设计思路2. 环境准备3. 创建棋盘3.1 棋盘类

Vue3 的 shallowRef 和 shallowReactive:优化性能

大家对 Vue3 的 ref 和 reactive 都很熟悉,那么对 shallowRef 和 shallowReactive 是否了解呢? 在编程和数据结构中,“shallow”(浅层)通常指对数据结构的最外层进行操作,而不递归地处理其内部或嵌套的数据。这种处理方式关注的是数据结构的第一层属性或元素,而忽略更深层次的嵌套内容。 1. 浅层与深层的对比 1.1 浅层(Shallow) 定义

这15个Vue指令,让你的项目开发爽到爆

1. V-Hotkey 仓库地址: github.com/Dafrok/v-ho… Demo: 戳这里 https://dafrok.github.io/v-hotkey 安装: npm install --save v-hotkey 这个指令可以给组件绑定一个或多个快捷键。你想要通过按下 Escape 键后隐藏某个组件,按住 Control 和回车键再显示它吗?小菜一碟: <template

性能测试介绍

性能测试是一种测试方法,旨在评估系统、应用程序或组件在现实场景中的性能表现和可靠性。它通常用于衡量系统在不同负载条件下的响应时间、吞吐量、资源利用率、稳定性和可扩展性等关键指标。 为什么要进行性能测试 通过性能测试,可以确定系统是否能够满足预期的性能要求,找出性能瓶颈和潜在的问题,并进行优化和调整。 发现性能瓶颈:性能测试可以帮助发现系统的性能瓶颈,即系统在高负载或高并发情况下可能出现的问题

Hadoop企业开发案例调优场景

需求 (1)需求:从1G数据中,统计每个单词出现次数。服务器3台,每台配置4G内存,4核CPU,4线程。 (2)需求分析: 1G / 128m = 8个MapTask;1个ReduceTask;1个mrAppMaster 平均每个节点运行10个 / 3台 ≈ 3个任务(4    3    3) HDFS参数调优 (1)修改:hadoop-env.sh export HDFS_NAMENOD