百度360必应搜狗淘宝本站头条
当前位置:网站首页 > IT技术 > 正文

php六道高频面试题(php面试题目100及最佳答案)

wptr33 2025-06-24 17:12 24 浏览

一、php-fpm是什么?有什么作用?

简介:PHP-FPM(FastCGI Process Manager)是 PHP 的一个 FastCGI 进程管理器,主要用于提高 PHP 在 Web 服务器上的性能。

作用:

1. 进程管理:可以保持多个 PHP 进程常驻内存,动态调整 PHP 子进程数量(根据负载)

2. 高性能处理:使用 FastCGI 协议与 Web 服务器通信,比传统的 CGI 模式更高效

3. 资源控制:限制 PHP 进程的内存使用,控制最大请求处理数

4. 灵活配置:支持不同用户/组运行 PHP 进程,可以为不同网站配置不同的 PHP 池(pool)

PHP-FPM 通常与 Nginx 搭配使用(因为 Nginx 本身不直接处理 PHP),但也可以与其他支持 FastCGI 的 Web 服务器(如 Apache)配合使用。PHP-FPM 已经成为现代 PHP 应用部署的标准组件之一,特别是在高流量网站和应用中。

二、redis 实现持久化的方式及原理、特点

Redis是基于内存快照的持久化策略基础上的,提供两种主要的持久化方式,确保数据在服务器重启后不会丢失。

1. RDB (Redis Database) 持久化

原理:定时生成内存数据的快照(Snapshot),将某个时间点的全量数据写入二进制文件(默认文件名为dump.rdb)

触发方式:手动执行`SAVE`(阻塞)或`BGSAVE`(后台异步)命令,配置文件中设置自动保存条件(如`save 900 1`表示900秒内至少1个key变化)

优点:性能高(二进制格式,恢复速度快),适合灾难恢复(单个文件便于备份),最大化Redis性能(父进程无需额外工作)

缺点:可能丢失最后一次快照后的数据,数据集大时fork子进程可能阻塞服务

2. AOF (Append Only File) 持久化

原理:记录所有写操作命令(以Redis协议格式追加到文件), 重启时重新执行AOF文件中的命令重建数据

配置选项:`appendfsync always`:每个命令都同步到磁盘(最安全但最慢),`appendfsync everysec`:每秒同步一次(推荐,平衡安全与性能), `appendfsync no`:由操作系统决定何时同步(最快但最不安全)

优点:数据安全性更高(最多丢失1秒数据),AOF文件易于理解和解析,自动处理AOF文件过大问题(重写机制)

缺点:文件体积通常比RDB大,恢复速度比RDB慢, 对性能影响比RDB大

三、mysql主从复制原理及模式

基本原理:

1. 主库(Master)** 记录所有数据更改到二进制日志(binlog)

2. 从库(Slave)** 通过I/O线程从主库拉取binlog

3. 从库的SQL线程重放这些日志事件,实现数据同步

有三种主要复制模式:

异步复制、半同步复制和全同步复制。每种模式在数据一致性、性能和适用场景上有所不同。

四、redis缓存击穿,缓存雪崩问题

1.缓存击穿(热点key失效)

问题:单个热点key过期,突发高并发直接访问数据库

解决:永不过期 + 异步更新 或 加互斥锁重建缓存

2.缓存雪崩(大规模失效)

问题:大量key同时失效/Redis宕机,数据库压力激增

解决:随机过期时间 + 多级缓存 + 熔断降级

3.缓存穿透(查询不存在数据)

问题:恶意查询不存在的数据,绕过缓存攻击数据库

解决:布隆过滤器拦截 + 缓存空值(带短过期时间)

五、http状态码

1、状态码分类

  • - 1xx:信息,服务器收到请求,需要请求者继续操作
  • - 2xx:成功
  • - 3xx:重定向
  • - 4xx:客户端错误
  • - 5xx:服务端错误

2、常用状态码

  • 200:请求成功
  • 301:永久重定向
  • 302:临时移动
  • 400 bad request:客户端请求语法错误
  • 401 unauthorized:客户端没有权限
  • 403 forbidden:服务器拒绝客户端请求
  • 404 not found:客户端请求资源不存在
  • 500 Internal Server Eerro:服务器内部错误
  • 502 bad gateway:作为网关或者代理工作的服务器尝试执行请求时,从上游服务器接收到无效的响应
  • 503 Service Unavailable 超载或系统维护
  • 504 Gateway timeout:网关超时

六、mysql存储引擎innoDB与MyISAM的区别

InnoDB (默认引擎):事务支持,行级锁,外键支持,特性有MVCC、崩溃恢复

MyISAM :不支持事务,表级锁,不支持外键,特点有全文索引、压缩表、计数更快

索引类型:

1.hash索引:适合精确查询且效率高,无法排序、不适合范围查询,hash冲突的情况下需要遍历链表(php数组的实现原理、redis zset 的实现原理类似)

2.b-tree、b+tree:b-tree 和b+tree的去区别

b+tree 的数据全部存储在叶子节点,内部节点只存key,一次磁盘IO能获取到更多的节点

b-tree 的内部节点和叶子节点都存储key和数据,查找数据不需要找到叶子节点,内部节点可以直接返回数据

b+tree 增加了叶子节点到相邻节点的指针,方便返回查询遍历

3.聚簇索引和非聚簇索引

概念:聚簇索引是索引和数据存储在一个节点,非聚簇索引是索引和数据分开存储,通过索引找到数据实际存储的地址

详解:

innodb 使用的聚簇索引,且默认主键索引为聚簇索引(没有主键索引的时候,选择一个非空索引,还没有则隐式的主键索引),辅助索引指向聚簇索引位置,然后在找到实际存储地址

myisam 使用非聚簇索引,所有的索引都只需要查询一次就能找到数据

聚簇索引的优势和略势

1. 索引和数据在一起,同一页的数据会被缓存到(buffer)内存中,所以查看同一页数据的时候只需要从内存中取出,

2. 数据更新之后之只需要维护主键索引即可,辅助索引不受影响

3. 辅助索引存的是主键索引的值,占用更多的物理空间。所以会受到影响

4. 使用随机的UUID,数据分布不均匀,导致聚簇索引可能扫全表,降低效率,所以尽量使用自增主键id

相关推荐

MySQL进阶五之自动读写分离mysql-proxy

自动读写分离目前,大量现网用户的业务场景中存在读多写少、业务负载无法预测等情况,在有大量读请求的应用场景下,单个实例可能无法承受读取压力,甚至会对业务产生影响。为了实现读取能力的弹性扩展,分担数据库压...

Postgres vs MySQL_vs2022连接mysql数据库

...

3分钟短文 | Laravel SQL筛选两个日期之间的记录,怎么写?

引言今天说一个细分的需求,在模型中,或者使用laravel提供的EloquentORM功能,构造查询语句时,返回位于两个指定的日期之间的条目。应该怎么写?本文通过几个例子,为大家梳理一下。学习时...

一文由浅入深带你完全掌握MySQL的锁机制原理与应用

本文将跟大家聊聊InnoDB的锁。本文比较长,包括一条SQL是如何加锁的,一些加锁规则、如何分析和解决死锁问题等内容,建议耐心读完,肯定对大家有帮助的。为什么需要加锁呢?...

验证Mysql中联合索引的最左匹配原则

后端面试中一定是必问mysql的,在以往的面试中好几个面试官都反馈我Mysql基础不行,今天来着重复习一下自己的弱点知识。在Mysql调优中索引优化又是非常重要的方法,不管公司的大小只要后端项目中用到...

MySQL索引解析(联合索引/最左前缀/覆盖索引/索引下推)

目录1.索引基础...

你会看 MySQL 的执行计划(EXPLAIN)吗?

SQL执行太慢怎么办?我们通常会使用EXPLAIN命令来查看SQL的执行计划,然后根据执行计划找出问题所在并进行优化。用法简介...

MySQL 从入门到精通(四)之索引结构

索引概述索引(index),是帮助MySQL高效获取数据的数据结构(有序),在数据之外,数据库系统还维护者满足特定查询算法的数据结构,这些数据结构以某种方式引用(指向)数据,这样就可以在这些数据结构...

mysql总结——面试中最常问到的知识点

mysql作为开源数据库中的榜一大哥,一直是面试官们考察的重中之重。今天,我们来总结一下mysql的知识点,供大家复习参照,看完这些知识点,再加上一些边角细节,基本上能够应付大多mysql相关面试了(...

mysql总结——面试中最常问到的知识点(2)

首先我们回顾一下上篇内容,主要复习了索引,事务,锁,以及SQL优化的工具。本篇文章接着写后面的内容。性能优化索引优化,SQL中索引的相关优化主要有以下几个方面:最好是全匹配。如果是联合索引的话,遵循最...

MySQL基础全知全解!超详细无废话!轻松上手~

本期内容提醒:全篇2300+字,篇幅较长,可搭配饭菜一同“食”用,全篇无废话(除了这句),干货满满,可收藏供后期反复观看。注:MySQL中语法不区分大小写,本篇中...

深入剖析 MySQL 中的锁机制原理_mysql 锁详解

在互联网软件开发领域,MySQL作为一款广泛应用的关系型数据库管理系统,其锁机制在保障数据一致性和实现并发控制方面扮演着举足轻重的角色。对于互联网软件开发人员而言,深入理解MySQL的锁机制原理...

Java 与 MySQL 性能优化:MySQL分区表设计与性能优化全解析

引言在数据库管理领域,随着数据量的不断增长,如何高效地管理和操作数据成为了一个关键问题。MySQL分区表作为一种有效的数据管理技术,能够将大型表划分为多个更小、更易管理的分区,从而提升数据库的性能和可...

MySQL基础篇:DQL数据查询操作_mysql 查

一、基础查询DQL基础查询语法SELECT字段列表FROM表名列表WHERE条件列表GROUPBY分组字段列表HAVING分组后条件列表ORDERBY排序字段列表LIMIT...

MySql:索引的基本使用_mysql索引的使用和原理

一、索引基础概念1.什么是索引?索引是数据库表的特殊数据结构(通常是B+树),用于...