网络通信与OS
文章平均质量分 95
网络通信
hancoder
谢谢支持
展开
-
【网络通信】Java NIO
基本概念和IO入门对于任何程序设计语言而言,输入输出(Input/Output)系统都是非常核心的功能。程序运行需要数据,数据的获取往往需要跟外部系统进行通信,外部系统可能是文件、数据库、其他程序、网络、IO设备等等。外部系统比较复杂多变,那么我们有必要通过某种手段进行抽象、屏蔽外部的差异,从而实现更加便捷的编程。Jvm虚拟机主要打交道的io操作是文件,内存,网络输入(Input)指的是:可以让程序从外部系统获得数据(核心含义是“读”,读取外部数据)。常见的应用:Ø 读取硬盘上的文件内容到程序。例如原创 2021-01-03 19:40:08 · 1256 阅读 · 0 评论 -
【网络通信】4、零拷贝、DMA、系统调用、消息队列原理
本文通过一步步讲解预备知识最后引出零拷贝文章目录DMA系统调用内核缓冲区读写:虚拟内存:零拷贝:传统IO①mmap零拷贝②sendfile零拷贝零拷贝总结mmap 和 sendFile 的区别NIO的buffer:NIO必然使用了堆外空间:java-NIO 零拷贝案例DMADMA: direct memory access 直接内存拷贝(不使用 CPU)1 要把内存数据发送到网卡然后发出去时:没有DMA时候怎么办:CPU读内存数据到CPU的高速缓存,再写到网卡。这样就把CPU的速度拉低到和网卡一个原创 2021-01-03 19:36:43 · 1462 阅读 · 0 评论 -
【网络】java密码安全
笔记整理自:尚硅谷java密码安全学+Swagger2第一章 密码学1.1 密码学基本概念密码在我们的生活中有着重要的作用,那么密码究竟来自何方,为何会产生呢?密码学是网络安全、信息安全、区块链等产品的基础,常见的非对称加密、对称加密、散列函数等,都属于密码学范畴。密码学有数千年的历史,从最开始的替换法到如今的非对称加密算法,经历了古典密码学,近代密码学和现代密码学三个阶段。密码学不仅仅是数学家们的智慧,更是如今网络空间安全的重要基础。1.1.1 古典密码学在古代的战争中,多见使用隐藏信息的方原创 2020-12-20 22:32:43 · 6632 阅读 · 2 评论 -
【网络】http、socket、长连接、长轮询
文章目录socket与长连接短连接一、长连接/短连接二、Socketsocket通信流程:ServletTomcat四大容器四个容器的关系:阀门tomcat参数maxConnections、maxThreads、acceptCount关系图解:maxConnections、maxThreads、acceptCount关系整个就餐的流程,大致如下:Tomcat源码总结调优Linux查看连接数,并发数查看tomcat 并发连接数配置长连接为什么要配置长连接1,Nginx 设置2,Tomcat 设置三、测试参考原创 2020-11-30 03:04:12 · 1443 阅读 · 0 评论 -
【网络通信】详解NIO、select
数据源数据源data source,提供数据的原始媒介。常见的数据源有:数据库、文件、其他程序、内存、网络连接、IO设备。如图10-1所示。 数据源分为:源设备、目标设备。 \1. 源设备:为程序提供数据,一般对应输入流。 \2. 目标设备:程序数据的目的地,一般对应输出流。图10-1 数据源示意图.png流流是一个抽象、动态的概念,是一连串连续动态的数据集合。 对于输入流而言,数据源就像水箱,流(stream)就像水管中流动着的水流,程序就是我们最终的用户。我们通过流(A S原创 2020-10-02 02:12:59 · 2474 阅读 · 1 评论 -
网络--传输层TCP、UDP、流量控制、拥塞避免、三次挥手
文章目录第五章 传输层5.1 OSI和DoD模型5.2 传输层协议和应用层协议的关系5.3 服务和应用层协议的关系5.3.2 如何查看服务侦听的端口5.4 传输层功能和端口范围5.4.1 传输层协议和网络层协议的主要区别5.4.2 传输层的主要功能5.4.3 传输层的端口5.5 ==UDP协议==5.5.1 UDP的首部格式常用TCP/UDP协议5.6 ==TCP协议==5.6.1 TCP的连接5.7 TCP如何实现可靠传输(1)可靠传输的工作原理——停止等待协议。(2)确认机制(3)可靠通信的实现(4)流原创 2020-08-30 13:12:22 · 1180 阅读 · 1 评论