当前位置: 首页 > news >正文

企业网站建设可行分析wordpress自动发布文章

企业网站建设可行分析,wordpress自动发布文章,汕头企业网站怎么做,制作收款网站今天我们来聊一聊Linux零拷贝技术#xff0c;今天我们以一个比较有代表性的技术sendfile系统调用为切入点#xff0c;详细介绍一下零拷贝技术的原理。 1.零拷贝技术简介 Linux零拷贝技术是一种优化数据传输的技术#xff0c;它可以减少数据在内核态和用户态之间的拷贝次数今天我们以一个比较有代表性的技术sendfile系统调用为切入点详细介绍一下零拷贝技术的原理。 1.零拷贝技术简介 Linux零拷贝技术是一种优化数据传输的技术它可以减少数据在内核态和用户态之间的拷贝次数提高数据传输的效率。 在传统的数据传输过程中数据需要从内核缓冲区拷贝至应用程序的缓冲区然后再从应用程序缓冲区拷贝到网络设备的缓冲区最后才能发送出去。 而零拷贝技术通过直接在应用程序和网络设备之间传输数据避免了中间的拷贝过程从而提高了数据传输的效率。 Linux零拷贝技术实现方式 sendfile系统调用sendfile系统调用可以在内核态中直接将文件内容发送到网络设备的缓冲区避免了数据在用户态和内核态之间的拷贝。 splice系统调用splice系统调用可以将一个文件描述符的数据直接传输到另一个文件描述符也可以将数据从一个文件描述符传输到网络设备的缓冲区避免了中间的拷贝过程。 mmap和write系统调用mmap系统调用可以将文件映射到内存中然后使用write系统调用将内存中的数据直接发送到网络设备的缓冲区避免了数据在用户态和内核态之间的拷贝。 DMADirect Memory AccessDMA是一种硬件技术可以直接将数据从内存传输到网络设备的缓冲区避免了CPU的介入提高了数据传输的效率。 2.sendfile系统调用 sendfile系统调用直接在内核中操作文件数据将数据从源文件描述符复制到目标文件描述符的发送缓冲区然后通过网络协议栈将数据发送出去。 这样就避免了数据在内核和用户空间之间的复制提高了传输效率。 sendfile系统调用函数原型 #include sys/sendfile.h ssize_t sendfile(int out_fd, int in_fd, off_t *offset, size_t count);参数说明 out_fd目标文件描述符用于发送数据。 in_fd源文件描述符从该文件读取数据。 offset指定从源文件的哪个位置开始读取数据可以为NULL表示从当前位置开始。 count要传输的字节数。返回值 成功返回写入out_fd文件的字节数。 失败返回-1并设置errno。 3.sendfile实现原理 3.1 传统方式发送文件 使用传统方式把一个文件通过socket发送出去我们需要执行一个比较长的路径。 路径磁盘-文件页缓存-用户缓冲区-套接字缓冲区-网卡。 上下文切换和内存拷贝情况如下 上下文切换4次read调用read返回write调用write返回 DMA拷贝2次 CPU拷贝2次文件页缓存-用户缓冲区用户缓冲区-套接字缓冲区 3.2 sendfile发送文件 使用sendfile发送文件相对来说整个路径会短一些。 路径磁盘-文件页缓存-套接字缓冲区-网卡。 上下文切换和内存拷贝情况如下 上下文切换2次sendfile调用sendfile返回 DMA拷贝2次 CPU拷贝1次文件页缓存-套接字缓冲区 3.3 sendfile实现原理 sendfile实现的核心是管道管道在Linux系统中应用的比较多比如说通过管道实现进程间通信。 当需要将文件数据拷贝至socket缓冲区时会临时创建一个管道环形缓冲区将文件数据先拷贝至管道再将管道数据迁移至socket缓冲区数据迁移并不是数据拷贝只是将指针指向内存地址。 3.4 小节 通过采用sendfile发送文件可以减少2次上下文切换和1次CPU拷贝如果我们的实际应用场景是需要进行大量的文件发送采用sendfile能够很大程度上提高系统性能。 相关视频推荐 2024年c/c程序员如何提升自己的核心竞争力这套linux c/c后端服务器开发技术教程不要错过https://www.bilibili.com/video/BV1CF4m1L7hU/ Linux C/C开发后端/音视频/游戏/嵌入式/高性能网络/存储/基础架构/安全 需要C/C Linux服务器架构师学习资料加qun812855908获取资料包括C/CLinuxgolang技术NginxZeroMQMySQLRedisfastdfsMongoDBZK流媒体CDNP2PK8SDockerTCP/IP协程DPDKffmpeg等免费分享 4.管道 4.1 管道简介 管道在Linux系统中应用很广泛除了零拷贝技术使用到管道进程间通信同样使用到管道那么管道到底是什么 管道是什么 管道其实就是一个环形缓冲区通过管道可以将数据从一个文件拷贝另外一个文件。 管道由struct pipe_inode_info结构体定义该数据结构有4个重要成员 pipe_buffer管道缓冲区数组一个固定长度的数组每个数组成员都是一个缓冲区对应一个struct pipe_buffer结构。 head头部序号表示当前可写缓冲区的位置需要配合mask使用。 tail尾部序号表示当前可读缓冲区的位置需要配合mask使用。 ring_size管道缓冲区数组长度ring_size - 1计算出maskhead mask获取当前可写缓冲区数组下标tail  mask获取当前可读缓冲区数组下标。 管道缓冲区由struct pipe_buffer定义该结构有3个重要成员 page页指针 offset数据在页中偏移 len数据长度 管道已满或为空判断 管道已满判断 head - tail ring_size表示管道已满。 管道为空判断 head tail表示管道为空。 相关结构体定义  struct pipe_inode_info是Linux内核中用于管道文件的数据结构。它定义在include/linux/pipe_fs_i.h头文件中。 pipe_inode_info结构体的定义如下 struct pipe_inode_info {unsigned int head; //头部序号unsigned int tail; //尾部序号unsigned int max_usage; //最大使用量unsigned int ring_size; //缓冲区数组大小unsigned int nr_accounted; //已使用缓冲区数量struct pipe_buffer *bufs; //缓冲区数组...... } struct pipe_buffer是Linux内核中用于管道pipe缓冲区的数据结构。它定义在include/linux/pipe_fs_i.h头文件中。 4.2 管道写 通过head mask获取缓冲区数组下标将数据写入pipe_buffer对应的内存页数据起始位置为offset偏移值写入的数据长度记录在len成员中。 完成数据写操作后head头部序号增加1指向下一个可写位置。 4.3 管道读 通过tail mask获取缓冲区数组下标将数据从pipe_buffer对应的内存页读取出来数据起始位置为offset偏移值读取数据长度不能大于len记录的数据长度。 完成数据读操作后len设置成0pipe_buffer被清空tail尾部序号增加1指向下一个可读位置。 5.总结 相比于传统的数据传输技术零拷贝技术能够大大提高系统性能在实际项目开发中我们可以选择符合项目特点的零拷贝技术以最低的成本提高系统性能。
http://www.zqtcl.cn/news/225731/

相关文章:

  • ysl网站设计论文网站快照回档
  • 网站建设成本计划汕头网站开发服务
  • 云朵课堂网站开发怎么收费wordpress安装完不显示
  • 网站建设进什么分录wordpress5.0 安装
  • 网站建设丷金手指专业十五户县规划建设和住房保障局网站
  • 普通门户网站开发价格怎么查公司信息
  • 广告传媒公司网站怎么做高品质的网站开发公司
  • 建设品牌型网站制作一起做玩具网站
  • 中山品牌网站设计自建站怎么做
  • 最牛免费网站建设wordpress 相册功能
  • 网站开发是培训网站开发毕业设计评审表
  • 网站对网友发帖隐私做处理网站怎么上传模板
  • 网站建设大神级公司网站 百度地图
  • 网站营销定义高端网站建设免费分析
  • 韩国网站建站html5修改器下载
  • 网站做联盟广告能赚钱吗如何制作微信小程序教程
  • 免费网页代理浏览器1广州seo效果
  • 网站开发所需基础知识学网络营销有前途吗
  • php网站怎么做集群wordpress添加产品图
  • 公司怎么建立网站吗聊城高端网站建设
  • 女生做网站编辑wordpress 办公主题
  • 接单做网站的从什么网站建网站好
  • 服务器如何发布网站正能量不良网站进入窗口免费阅读
  • 深圳个性化建网站服务商百度秒收录神器
  • 金华做公司网站wordpress会员可见插件
  • 访问自己做的网站河南百度推广公司
  • Wordpress+仿站+工具建筑材料采购网站
  • 汕头免费建设网站制作阆中市网站建设
  • 怎样做网站表白墙网站设计的一般流程是什么
  • 河北手机网站制作企业网页设计的基本步骤和流程