关注
非语言向关题解
多路复用
IO多路复用是指内核一旦发现进程指定的一个或者多个IO条件准备读取,它就通知该进程. 而不是阻塞在单个IO上面, 提高处理性能.
select、poll、epoll
select: 使用轮询(效率低)是否有感兴趣的事件发生, 底层使用bitmap标记, 现在了1024的文件描述服上限
poll: 使用pollfd数组替换bitmap的实现,没有1024的限制了, 还是轮询(效率低)
epoll: 使用事件触发通知,内核回调的方式, 避免了轮询,能够高效处理.
TCP拥塞控制
拥塞控制, 工具网络拥塞情况调整数据发送速度(拥塞窗口cwnd)
拥塞控制算法: 慢启动(指数增长) ,到达阈值后,拥塞避免(线性增长), 遇到拥塞后(超时), 将阈值调整为当前的一半,然后进入重启动.
快重传(优化): 当收到同一个ack3次后, 认为发送拥塞, 重传ack对应的数据,
快恢复(优化): 然后cwnd调整为当前的一半, 不进入慢启动,自己进入拥塞避免
TCP 沾包
应该是tcp 粘包, 说的是tcp是传输的数据是字节流, 数据是连续的, tcp协议层无法区分一次数据传输的其实位置, 需要应用层处理.
TCP 沾包解决方式
固定长度
固定头部(头部中固定位置表示整个body的长度)+可变长度的body
特殊字符做分隔符
mysql底层索引结构
底层采用B+树实现索引.
回表
回表指通过普通索引查到对应的数据行主建id之后, 再使用主建id到数据表中查询需要的数据行数据, 如果索引中已经包含了所有要查询的数据(覆盖索引), 就可以避免回表查询, 提高性能.
索引失效场景
1. 查询条件使用了函数或表达式
2. 隐式类型转换
3. LIKE 查询以通配符开头
4. OR 条件未全部使用索引列
5. 不满足最左前缀原则(复合索引)
6. 查询条件包含范围查询(复合索引)
7. NULL 值处理
8. 查询优化器选择错误的执行计划
9. ORDER BY 与 LIMIT 不匹配索引
10. 数据量太小
2
相关推荐

点赞 评论 收藏
分享
09-18 14:15
门头沟学院 Java 点赞 评论 收藏
分享
牛客热帖
更多
正在热议
更多
# 从顶到拉给所有面过的公司评分 #
45353次浏览 292人参与
# 产品薪资爆料 #
131102次浏览 838人参与
# 宣讲会你有哪些意向不到的收获 #
6005次浏览 42人参与
# 签约/解约注意事项 #
722992次浏览 4103人参与
# 聊聊这家公司值得去吗 #
582236次浏览 3819人参与
# 小厂实习有必要去吗 #
56601次浏览 285人参与
# 水滴求职进展汇总 #
6349次浏览 32人参与
# 你怎么评价今年的春招? #
131042次浏览 1369人参与
# 机械制造岗投递时间线 #
28213次浏览 372人参与
# 为了求职,我做过的疯狂伪装 #
21009次浏览 456人参与
# 十一假期一定要干的事 #
18280次浏览 145人参与
# 你的国庆怎么过 #
27559次浏览 253人参与
# 工作压力大怎么缓解 #
107929次浏览 1072人参与
# 晒晒你的中秋福利 #
18975次浏览 137人参与
# bilibili求职进展汇总 #
100872次浏览 864人参与
# 职场破冰,你们都聊什么? #
11838次浏览 97人参与
# 你面试被问到过哪些不会的问题? #
39339次浏览 1078人参与
# 秋招的嫡长offer #
54394次浏览 455人参与
# 顺丰求职进展汇总 #
56850次浏览 290人参与
# 机械笔面试考察这些知识点 #
12683次浏览 96人参与