高并发,高性能,高可用,三高
高性能:性能是硬件决定的,编写高性能应用程序就是要少浪费硬件资源
程序调用分为
1.函数调用 最快,用户态内内存调用
2.系统调用 调用操作系统内核的函数,要切换内核态,相对更慢
3.RPC调用 应用程序->内核->网卡,最慢
BIO:
每个socket连接都要一个线程去处理,当有一万个客户端连接时也安排一万个线程去处理
缺点,占内存,线程上下文切换频繁
NIO:
固定几个线程去轮询内核的所有socket,找到有数据的socket来处理
缺点,每查询一个socket的状态都要系统调用,一万个socket轮询一次就要一万次系统调用
当一万个socket只有一个有数据时也这样轮询,会有9999个空轮询
IO多路复用:
使用内核的select或者poll或者epoll函数一次性返回所有socket的状态集
优点,只需要一次系统调用就能找到有数据的socket
内核的select或者poll或者epoll这些函数的作用都是返回内核中所有socket的状态集
三个函数有区别,目前epoll最优反正
select:无差别轮询
poll:忙轮询
epoll:事件驱动