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

五花八门客户问题(BUG) - 重复打印

根据commit猜测客户问题

git://sourceware.org / glibc.git / commit

commit

summary | shortlog | log | commit | commitdiff | tree
(parent: 4573c6b) | patch
Don't flush write buffer for ftell
author	Siddhesh Poyarekar <siddhesh@redhat.com>	
Fri, 28 Sep 2012 13:07:23 +0000 (18:37 +0530)
committer	Siddhesh Poyarekar <siddhesh@redhat.com>	
Fri, 28 Sep 2012 13:08:14 +0000 (18:38 +0530)
commit	adb26faefe47b7d34c941cbfc193ca7a5fde8e3f
tree	799a1e10dae3c9aac2b9c2c79e0b8adaaa1eae90	tree
parent	4573c6b09884a93fffa3a754678ef881cadebfb3	commit | diff
Don't flush write buffer for ftell

真实客户问题

客户发现打印到文件的内容重复了。这不是普通文件,我们是做数据库的,影响很大。

问题所在

大喜的是问题很好重现,所以直接debug吧。在所有的fwrite函数上下断点,愣是没看出来怎么重复的。后来才怀疑到fwrite+fork这项操作上。如下是一个简易版的重现代码。踩踩结果吧:

#include<stdio.h>
#include<stdlib.h>
#include<unistd.h>

void main(){
    FILE* file=fopen("test.txt", "a+");
    fwrite("First", 1, 5, file);
    fwrite("Secon", 1, 5, file);
    ftell(file); /*NOTE: redhat 6/AIX7  flushs the data, while centos 7 doesn't flush!!!!*/
    //setbuf(file, 0);
    if(fork()>0){
           fwrite("In Parent", 1, 9, file);
           exit(0);
     }else{
           fclose(file);
     }
}

结果:FirstSeconIn ParentFirstSecon

相信读者应该已经注意到上面的注释了,与glibc中的ftell有关系,redhat6中ftell不会强刷缓冲中的数据到磁盘,但是redhat7却会,这是文章一开始的glibc的commit导致的。基础软件的一点点更新都是影响巨大啊。

fix办法

fix也很简单,只需要在fork之前调用下fflush即可。


http://www.kler.cn/a/160567.html

相关文章:

  • 【R78/G15 开发板测评】串口打印 DHT11 温湿度传感器、DS18B20 温度传感器数据,LabVIEW 上位机绘制演化曲线
  • C/C++精品项目之图床共享云存储(3):网络缓冲区类和main
  • flink sql + kafka + mysql 如何构建实时数仓
  • Linux kernel 堆溢出利用方法(二)
  • Elasticsearch可视化工具Elasticvue插件用法
  • Java设计模式面试题及参考答案
  • 华为配置流量抑制示例
  • linux逻辑卷LVM
  • 【LeetCode刷题】-- 79.单词搜索
  • 机器学习之布谷鸟搜索算法(Cuckoo Search Algorithm,CSA)剖析
  • 【MySQL】:数据库基本认识
  • 【网络奇缘】- 计算机网络|深入学习物理层|网络安全
  • HarmonyOS4.0从零开始的开发教程01运行Hello World
  • Linux(centos)学习笔记(初学)
  • git 分支的创建与删除
  • kyuubi整合flink yarn session mode
  • 【唐山海德教育】一级建造师社保需交满多少年
  • 【数值分析】雅可比迭代和高斯-赛德尔迭代求解线性方程组应用举例(编程求解)
  • 使用 OpenFunction 在任何基础设施上运行 Serverless 工作负载
  • Python高级数据结构——B树和B+树
  • vue3版本学习
  • CSS属性 display和visibility的区别
  • 【QT】容器类的迭代
  • 【洛谷算法题】P1909-买铅笔【入门2分支结构】
  • 【恶意刷券】电商中恶意刷券如何防止?
  • 鼎捷受邀出席“中国制造业产品创新数字化国际峰会”,共话工业软件创新发展