PHP服务端优化全面总结
一.优化PHP原则
1.1PHP代码的优化
(1)升级最新的PHP版本
鸟哥PPT里的对比数据,就是WordPress在PHP5.6执行100次会产生70亿次的CPU指令执行数目,而在PHP7中只需要25亿次,减少64.2%。
参考:PHP的性能演进(从PHP5.0到PHP7.1的性能全评测)
(2)减少include和require的使用
include和require方法中包含了文件读取逻辑,大量使用会造成性能的下降.
解决这个问题可以使用APC加速器组件,缓解此类问题.
(3)使用局部变量代替全局变量
局部变量的速度比全局变量运行的速度要快,使用局部变量可以提高运行效率,同时也易于管理.
(4)使用静态函数和方法
结合实际情况,尽量添加static标签,使用静态函数或者方法,可以有效的提升执行速度.
(5)及时释放无用的变量和资源
PHP自带内存回收机制,但是我们不能过分的依赖,我们要通过unsettle方法,或者直接设置为null的方式来及时的释放无用的变量和资源.
(6)使用单引号代替双引号
单引号和双引号都可以用来包含字符串,但是双引号有字符转义和变量解析的逻辑,所以尽量使用单引号,提升执行效率.
(7)减少
@屏蔽错误的使用
@号可以用来屏蔽报错的信息,但是需要注意的是@会降低脚本的运行速度.
(8)减少PHP中OOP的使用
使用OOP来构建程序框架比较便捷,但是可能会产生额外的系统开销.所以我们要根据实际情况合理的使用OOP思想.
(9)使用抽象类代替接口
PHP中使用接口(interface)的成本比较高,我们应该尽量避免使用,可以使用抽象类(abstract class)来代替.
(10)减少正则表达式的使用
正则表达式的执行成本十分的高昂,尽量使用PHP中自带的字符串处理函数来代替.
(11)压缩需要存储的数据
例如我们保存IP地址的时候可以使用ip2long函数把IP地址转化成整数型数据存储,使用的时候通过long2ip函数还原.
对大数据还可以使用gzcompress和gzuncompress进行压缩和解压.
(12)使用高效的PHP语句
分支语句效率:switch ... case>if ... elseif ... else.
循环语句效率:foreach>for>while.
叠加语句效率:++$i>$i++.
(13)使用高效的PHP函数
字符打印函数效率:echo>print
字符替换函数效率:strtr>str_replace>preg_replace
数组查询函数效率:array_key_exists>isset>in_array
1.2Session机制的优化
(1)在PHP session设置中避免开启auto_start,通常在使用的时候在使用session_start函数开启,减少资源消耗.
(2)合理设置session的有效期,有效期设置过长导致出现负载问题,通常设置在1到8小时之间.
(3)PHP session默认使用文件存储,我们可以通过php.ini中的session_handle选项选择需要的存储方式,常见的有数据库和高速缓存服务Memcache Redis等.
1.3使用缓存中间件
(1)Memcache
(2)Redis
1.4使用APC加速
二.数据库优化
2.1SQL优化
(1)使用慢查询.
在MySQL数据库配置文件my.cnf中加入配置,使用show status like 'Slow%'查看慢查询数量.
分析查询时间大于设置时间的SQL语句,使用explain语句.
(2)使用索引
where:使用确定性的判断添加字段一般加索引
like: 'faf%'使用索引,'%faf%'不能使用索引
少用不确定的判断.如:!=,is not null, not in等.索引非常占据空间,合理创建索引.
(3)使用表关联需要慎重
常用的内连接(inner join)和左连接(left join)每次进行关联查询的时候都会对两张数据表的笛卡尔乘积进行查询,扫描数量大,所以我们尽量使用添加冗余字段避免表关联,使用空间换时间.
如果难以避免使用表关联,那么我们最好给关联的字段建立索引.
不要使用SQL的子查询,效率非常的低.
(4)使用MySQL中查询条件和函数要谨慎
不要使用查询数量的COUNT(*),而是使用COUNT(1).
尽量不要使用DISTINCT.
group by计算十分消耗资源.
max(),min(),substr(),concat(),date_format(),to_days()等都会加大数据库负担.
我们应尽量让数据库负责查询工作,其他使用PHP来做.
2.3数据库架构设计
(1)主从结构
主库负责数据写入,从库负责数据查询,主库写入后快速同步从库.
主从架构既能避免读写造成的锁表问题,又能多台从库分担访问.
但应该注意同步不及时问题.例如,用户修改信息时,主库更新.而从从库获取数据时,从库却没有从主库同步过来.就会造成信息无变化现象.
(2)集群(Cluster)
当主从结构无法满足需求时,我们可以使用集群结构.由众多的主从结构数据库组成集群.
集群架构对分布式逻辑要求比较高,通常是使用唯一的字段作为分布式数据的ID,通过散列分布算法获得数据所在位置,常见的算法有取模算法,一致性散列算法等.
还可以按照数据库名来实现分布式存储数据.这种算法比较简单实用,由于数据库的相关功能不同,每个数据库访问量和数据量也不平均,所以可以按照数据库名来处理.
PHP服务端优化全面总结的更多相关文章
- 【gRPC】C++异步服务端优化版,多服务接口样例
官方的C++异步服务端API样例可读性并不好,理解起来非常的费劲,各种状态机也并不明了,整个运行过程也容易读不懂,因此此处参考网上的博客进行了重写,以求顺利读懂. C++异步服务端实例,详细注释版 g ...
- SSH服务端配置、优化加速、安全防护
CentOS7自带的SSH服务是OpenSSH中的一个独立守护进程SSHD.由于使用telnet在网络中是明文传输所以用其管理服务器是非常不安全的不安全,SSH协议族可以用来对服务器的管理以及在计算机 ...
- 谈一款MOBA类游戏《码神联盟》的服务端架构设计与实现(更新优化思路)
注:本文仅用于在博客园学习分享,还在随着项目不断更新和完善中,多有不足,暂谢绝各平台或个人的转载和推广,感谢支持. 一.前言 <码神联盟>是一款为技术人做的开源情怀游戏,每一种编程语言都是 ...
- 服务端spark gbdt模型计算性能优化
服务端使用训练出来的模型,spark模型计算第一步是实现spark模型加载. 线上服务对用户体验影响极大,故需要对模型使用进行优化. 1.多线程并发进行计算,线上两个服务.优化cpu 2.在扩召回集, ...
- Vue(SPA) WebPack模块化打包、SEO优化(Vue SSR服务端同构直出)、全浏览器兼容完整解决方案
白驹过隙,时光荏苒 大概去年这个时候写了angular 结合webpack的一套前端方案,今年此时祭出vue2结合webpack的一套前端方案. 明年的这个时候我又是在做什么... 读在最前面: 1. ...
- 用prerender-spa-plugin插件Vue项目优化SEO做ssr服务端渲染及预渲染
今天在做公交的时候没干,用手机看看文章,偶然发现了一个关于Vue优化seo的文章,我先是在Vue的官方文档看了一篇关于Vue做SEO优化的文章. 上面提到了nuxt.js这个框架,这个框架我做过一个小 ...
- PHP服务端如何通过程序将图上传到指定的图片服务器与图片服务器的优化方案
一:PHP服务端如何通过程序将图上传到指定的图片服务器与图片服务器的优化方案 (1) php服务器把图片处理成缩率图或指定大小的图片在通过PHP程序代码 操作FTP 上传到图片服务器. 二:图片服务器 ...
- 谈反应式编程在服务端中的应用,数据库操作优化,提速 Upsert
反应式编程在客户端编程当中的应用相当广泛,而当前在服务端中的应用相对被提及较少.本篇将介绍如何在服务端编程中应用响应时编程来改进数据库操作的性能. 开篇就是结论 接续上一篇<谈反应式编程在服务端 ...
- Java服务端性能优化
<Java程序性能优化>说性能优化包含五个层次:设计调优.代码调优.JVM调优.数据库调优.操作系统调优. 常用的几个代码优化方案: 使用单例 对于IO处理.数据库连接.配置文件解析加载等 ...
随机推荐
- 将Windows网络适配器共享网络的ip:192.168.137.1 改为其他IP
修改注册表 方法1 HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\services\SharedAccess\Parameters 中的: ScopeAddr ...
- python with语句与contextlib
参考链接:https://www.ibm.com/developerworks/cn/opensource/os-cn-pythonwith/ with语句用于异常处理,适用于存在资源访问的场合,无论 ...
- Python常用代码,置顶备用!
1.jupyter notebook 设置全部行输出: # 设置全部行输出 from IPython.core.interactiveshell import InteractiveShellInte ...
- java 反射基本认识
java 反射基本认识 最近重新复习java反射的知识,有了新的理解. class类? 在面向对象中,万事万物皆对象.类也是个对象,是java.lang.class类的实例对象. public cla ...
- RIP路由协议:基础设置/通信练习/兼容问题
RIP工作原理 首先路由器学习到直连网段 路由器开始运行RIP,当路由器的更新周期30秒到了的时候,会向邻居发送路由表 Metric:度量值,衡量一条路由好坏的值.发送路由表时Metric值会加1 学 ...
- Odoo10学习笔记三:模型(结构化的应用数据)、视图(用户界面设计)
转载请注明原文地址:https://www.cnblogs.com/ygj0930/p/11189263.html 一:模型 [Odoo中,一切皆模型,连视图都是模型.Odoo将各种数据,如:权限数据 ...
- Confluence 6.9.0 安装
平台环境:centos 7.6 数据库版本:mysql-5.7.26,提前安装好,安装步骤略. 软件版本:Confluence6.9.0 所需软件:提前下载到本地电脑 atlassian-conflu ...
- Skyshop.代码解析
MarmosetInput.cginc: Input结构定义: struct Input { #if defined(MARMO_PACKED_UV) || defined(MARMO_PACKED_ ...
- 自动化部署-Jenkins备份回滚
1.备份 备份可以使用批处理命令解决,实际就是复制当前发布文件 ::备份文件夹名,使用当前时间 set foldername=%date:~0,4%%date:~5,2%%date:~8,2%%tim ...
- udf文件十六进制
如下为网上找的前辈们的UDF(以做记录) set @a = unhex('7F454C4602010100000000000000000003003E0001000000800A00000000000 ...