写点什么

Java 开发人员不得不收集的代码,史上最全的微服务专业术语面试 50 问

用户头像
极客开源
关注
发布于: 刚刚

1 关于 MySQL,面试官会问哪些问题?

  • 第一个:MySQ 性能优化最佳实践 21 个(有具体的解释)你知道哪些?


  1. 为查询缓存优化你的查询

  2. EXPLAIN 你的 SELECT 查询

  3. 当只要一行数据时使用 LIMIT 1

  4. 为搜索字段建索引

  5. 在 Join 表的时候使用相当类型的例,并将其索引

  6. 千万不要 ORDER BY RAND()

  7. 避免 SELECT *

  8. 永远为每张表设置一个 ID

  9. 使用 ENUM 而不是 VARCHAR

  10. 从 PROCEDURE ANALYSE() 取得建议

  11. 尽可能的使用 NOT NULL

  12. Prepared Statements

  13. 无缓冲的查询

  14. 把 IP 地址存成 UNSIGNED INT

  15. 固定长度的表会更快

  16. 垂直分割

  17. 拆分大的 DELETE 或 INSERT 语句

  18. 越小的列会越快

  19. 选择正确的存储引擎

  20. 使用一个对象关系映射器(Object Relational Mapper)

  21. 小心“永久链接”


篇幅有点长,整理成了一个 PDF 文档:



  • 第二个:来看下 MySQL 的高频 20 问(附带详细解答,整理成册)


  1. 事务四大特性(ACID)原子性、一致性、隔离性、持久性?

  2. 事务的并发?事务隔离级别,每个级别会引发什么问题,MySQL 默认是哪个级别?

  3. MySQL 常见的三种存储引擎(InnoDB、MyISAM、MEMORY)的区别?

  4. MySQL 的 MyISAM 与 InnoDB 两种存储引擎在,事务、锁级别,各自的适用场景?

  5. 查询语句不同元素(where、jion、limit、group by、having 等等)执行先后顺序?

  6. 什么是临时表,临时表什么时候删除?

  7. MySQL B+Tree 索引和 Hash 索引的区别?

  8. sql 查询语句确定创建哪种类型的索引?如何优化查询?

  9. 聚集索引和非聚集索引区别?

  10. 有哪些锁(乐观锁悲观锁),select 时怎么加排它锁?

  11. 非关系型数据库和关系型数据库区别,优势比较?

  12. 数据库三范式,根据某个场景设计数据表?

  13. 数据库的读写分离、主从复制,主从复制分析的 7 个问题?

  14. 使用 explain 优化 sql 和索引?

  15. MySQL 慢查询怎么解决?

  16. 什么是 内连接、外连接、交叉连接、笛卡尔积等?

  17. mysql 都有什么锁,死锁判定原理和具体场景,死锁怎么解决?

  18. varchar 和 char 的使用场景?

  19. mysql 高并发环境解决方案?

  20. 数据库崩溃时事务的恢复机制(REDO 日志和 UNDO 日志)?


1.3 MySQL 性能调优笔记分享

  • 《MySQL 性能调优与架构设计--全册(PDF)》


本书分为 3 个部分,第一部分是基础篇,第二部分是重点之重性能调优篇,第三部分是架构设计篇


(1)目录简介



(2)详情内容



  • 《重学 MySQL:从入门到精通(PDF)》


本书包括 MySQL 的安装与配置、数据库的创建、数据表的创建、数据类型和运算符、MySQL 函数、查询数据、数据表的操作(插入、更新与删除数据)、索引、存储过程和函数、视图、触发器、用户管理、数据备份与恢复、日志以及性能优化等等。本书注重实战操作,帮助读者循序渐进的掌握 MySQL 的各项技术。需要重学一下 MySQL,建议可以看看这个


02 Tomcat 性能调优

2.1 Tomcat 性能调优面试必备题(附带详细解答)你能答多少?

  1. 你怎样给 tomcat 去调优?

  2. 如何加大 tomcat 连接数

  3. tomcat 中如何禁止列目录下的文件

  4. 怎样加大 tomcat 的内存

  5. Tomcat 有几种部署方式

  6. Tomcat 的优化经验

  7. Tomcat 的缺省端口是多少,怎么修改?

  8. tomcat 有哪几种 Connector 运行模式( 优化) ?

  9. Tomcat 有几种部署方式?

  10. tomcat 容器是如何创建 servlet 类实例?用到了什么原理?

  11. tomcat 如何优化?

  12. 内存调优

  13. 垃圾回收策略调优

  14. 添加 JMS 远程监控

  15. 专业点的分析工具有

  16. 关于 Tomcat 的 的 session 数目

  17. 监视 Tomcat 的内存使用情况

  18. 打印类的加载情况及对象的回收情况

  19. Tomcat 一个请求的完整过程

  20. Tomcat 工作模式?

如何快速更新自己的技术积累?

  • 在现有的项目里,深挖技术,比如用到 netty 可以把相关底层代码和要点都看起来。

  • 如果不知道目前的努力方向,就看自己的领导或公司里技术强的人在学什么。

  • 知道努力方向后不知道该怎么学,就到处去找相关资料然后练习。

  • 学习以后不知道有没有学成,则可以通过面试去检验。


我个人觉得面试也像是一场全新的征程,失败和胜利都是平常之事。所以,劝各位不要因为面试失败而灰心、丧失斗志。也不要因为面试通过而沾沾自喜,等待你的将是更美好的未来,继续加油!


以上面试专题的答小编案整理成面试文档了,文档里有答案详解,以及其他一些大厂面试题目




本文已被CODING开源项目:【一线大厂Java面试题解析+核心总结学习笔记+最新讲解视频+实战项目源码】收录

用户头像

极客开源

关注

还未添加个人签名 2021.03.18 加入

还未添加个人简介

评论

发布
暂无评论
Java开发人员不得不收集的代码,史上最全的微服务专业术语面试50问