关注
非语言向关题解
多路复用
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
牛客热帖
更多
正在热议
更多
# 26年哪些行业会变好/更差 #
6137次浏览 110人参与
# 实习,不懂就问 #
146899次浏览 1311人参与
# 去年的flag与今年的小目标 #
3388次浏览 104人参与
# 卷__卷不过你们,只能卷__了 #
2293次浏览 55人参与
# 有深度的简历长什么样? #
8168次浏览 169人参与
# 哪些公司在招寒假实习? #
3081次浏览 36人参与
# 你都用AI做什么 #
3120次浏览 82人参与
# 入职第一天 #
5129次浏览 85人参与
# 写论文的崩溃时刻 #
1774次浏览 48人参与
# 实习学到最有价值的工作习惯 #
54207次浏览 433人参与
# 一人分享一道面试手撕题 #
10760次浏览 537人参与
# 你不能接受的企业文化有哪些 #
3876次浏览 73人参与
# 你最满意的offer薪资是哪家公司? #
64164次浏览 319人参与
# 外包能不能当跳板? #
55928次浏览 260人参与
# 滴滴求职进展汇总 #
292651次浏览 2411人参与
# 应届生应该先就业还是先择业 #
161548次浏览 814人参与
# uu们,春招你还来吗? #
39508次浏览 232人参与
# AI了,我在打一种很新的工 #
125754次浏览 1304人参与
# 听到哪句话就代表面试稳了or挂了? #
240706次浏览 1681人参与
# 秋招你被哪家公司挂了? #
1002200次浏览 7704人参与