IT技术博客大学习 共学习 共进步
全部 移动开发 后端 数据库 AI 算法 安全 DevOps 前端 设计 开发者

标签:Filesystem

共 4 篇相关文章

IT 累计浏览 4,181

Linux下访问文件的基本模式

这篇讲的是Linux内核中几种常见的文件访问方式,作者从底层机制出发,对比了普通模式、同步模式、直接I/O、异步模式以及内存映射这五种模式的运作原理与核心差异。 普通模式依赖页高速缓存,读阻塞、写缓存即返回,是默认的平衡选择。同步模式则通过置位O_SYNC标志,强制写操作直到数据落盘才返回,代价是更高的延迟,但确保了数据持久性。直接I/O(O_DIRECT)完全绕过页高速缓存,在用户空间与磁盘间直接传输,适合数据库等需要自主管理缓存的场景。异步模式通过aio系列系统调用实现非阻塞I/O,进程提交请求后可立即返回处理其他任务,提升了并发处理能力。内存映射则通过mmap将文件映射到进程地址空间,把文件操作转化为内存操作,简化了编程模型并可能提升大文件访问效率。 文章清晰地拆解了每种模式下内核标志位的状态与数据流路径,帮助开发者理解不同I/O策略的适用场景——比如高性能存储系统可能倾向于直接I/O或异步模式,而追求开发简便性的应用则更适合内存映射。通过对比这些模式的适用场景和实现机制,文章为开发者提供了选择I/O策略的清晰指引。

IT 累计浏览 4,602

最简单的命令最让你抓狂

这篇文章从一次网站部署的经历讲起,分享了一个很多人可能都忽略的陷阱。作者发现,当使用经典的 `cp -r` 命令来同步整个网站目录时,一个关键的变化悄悄发生了:命令默认会将源目录中的符号链接替换为它们指向的实体文件。这意味着,原本通过符号链接共享的同一份文件,会在目的目录中变成多个副本,白白浪费了磁盘空间,并可能因文件不一致而引发难以察觉的故障。 问题的根源在于 `cp` 命令的设计逻辑——它忠实地执行“复制”动作,将符号链接的“目标”而非链接本身复制过来,这与许多人“两个目录完全一致”的直觉预期相悖。作者指出,如果你确实希望保持链接属性不变,正确的工具是 `rsync`,它提供了更精细的控制。这个小坑提醒我们,越是习以为常的简单命令,越值得在关键任务前确认其行为细节。

IT 累计浏览 3,956

windows下使用vim(gvim)的不便及解决方案(1)-文件查找和软链接

这篇讲的是跨平台Vim用户在Windows环境下容易遇到的典型痛点。作者从日常使用场景出发,具体描述了在Windows中使用GVim时,文件查找功能受限、软链接操作不友好两大实际问题。文章剖析了这些不便的根源:Windows原生文件系统和命令行环境与Linux存在差异,导致部分依赖Linux特性的Vim插件或脚本无法无缝运行。 针对文件查找,文章对比了Windows下几种不同的查找方案,并给出了针对Vim优化的配置思路。对于软链接问题,则介绍了在Windows环境下创建和管理符号链接的替代方法,以及如何调整Vim配置来更好支持。文中提供的解决方案都紧扣Windows系统特性,具有很强的实操性。对于习惯在Windows上使用Vim办公的开发者来说,这些来自一线经验的总结能直接提升工作效率。

IT 累计浏览 7,018

blktrace 深度了解linux系统的IO运作

这篇讲的是 blktrace 这个 Linux 下相对小众但极其强大的块层 IO 跟踪工具。作者没有停留在工具的基本用法上,而是深入讲解了如何利用它真正理解系统底层的 IO 流动。文章核心在于揭示 blktrace 与 iostat、perf 等更常见工具的区别:前者能让你像看地图一样,追踪一个 IO 请求从应用程序发起,经过文件系统、通用块层,最终到达具体设备的全过程,包括每个环节的耗时和队列状态。 作者详细展示了 blktrace 的输出格式和常用分析工具(如 blkparse、btt),并通过真实案例演示了如何从海量事件日志中,定位出“谁在何时对哪个设备发起了什么操作”、“IO 在哪个队列里排队过久”这类具体问题。这使得它在诊断复杂的 IO 性能瓶颈(如设备利用率高但响应慢)时,比仅能提供聚合统计信息的工具要精准得多。 文章最终将工具价值落到了实战层面:当你怀疑系统存在不规则的 IO 模式、需要优化特定应用的 IO 路径,或者想从根源上理解一次磁盘性能抖动的来龙去脉时,blktrace 提供的这种“逐帧回放”能力,能让排查过程事半功倍。