jdb2/kworker
创始人
2024-05-08 13:52:04
0

测试代码出自:块设备IO优化的典型案例分析_papaofdoudou的博客-CSDN博客_kworker/u2:2-2-

#include 
#include 
#include 
#include 
#include 
#include 
#include 
#include //O_DIRECT        
#define __USE_GNU 1
#include 
#include 
#include 
#include int fallocate(int , int , off_t, off_t);
static void write_test(int fdno)
{int origin_len;int reallen;void *mp;int len = 1 * 1024 * 1024;origin_len = len;len = len + (getpagesize() - len%getpagesize());//printf("%s line %d, len = %d.\n", __func__, __LINE__, len);unsigned char *p = malloc(len + getpagesize());if(p == NULL){printf("%s line %d, malloc failure.\n", __func__, __LINE__);return;}mp = p;unsigned char *q = (unsigned char *)(((unsigned long)p + getpagesize())&(~(getpagesize()-1)));p = q;//printf("q = %p, mp = %p.\n", q, mp);memset(p, 0x00, len);//lseek(fdno, 0, SEEK_SET);//int reallen = read(fdno, p,len);//printf("%s line %d, reallen %d read failure.er %s\n", __func__, __LINE__, reallen, strerror(errno));//printf("%s line %d, fdno = %d\n", __func__, __LINE__, fdno);//lseek(fdno, 0, SEEK_SET);reallen = write(fdno, p, origin_len);//printf("%s line %d, reallen = %d.\n", __func__, __LINE__, reallen);//lseek(fdno, 0, SEEK_SET);free(mp);mp = NULL;return;
}static void* write_thread1(void *p)
{int fdno;fdno = open("./fuck.bin", O_DIRECT|O_RDWR|O_CREAT, 0666);//fdno = open("./fuck.bin", O_RDWR|O_CREAT, 0666);if(fdno < 0){printf("%s line %d, open file failure.\n", __func__, __LINE__);return NULL;}fallocate(fdno, 1, 0, 100*1024*1024);//fallocate(fdno, 0, 0, 100*1024*1024);//return NULL;while(1){write_test(fdno);}close(fdno);return NULL;
}static void* write_thread2(void *p)
{int fdno;fdno = open("./new.bin", O_DIRECT|O_RDWR|O_CREAT, 0666);if(fdno < 0){printf("%s line %d, open file failure.\n", __func__, __LINE__);return NULL;}fallocate(fdno, 1, 0, 100*1024*1024);//fallocate(fdno, 0, 0, 100*1024*1024);//return NULL;while(1){write_test(fdno);}close(fdno);return NULL;
}int main(int argc,char **argv)
{pthread_t t1,t2;pthread_create(&t1,0,write_thread1,NULL);pthread_create(&t2,0,write_thread2,NULL);pthread_join(t1,NULL);pthread_join(t2,NULL);return 0;
}

块起始分别为9961472、9961984、9962496、9963008,每个需要512 sectiors 扇区,本次写1M的文件,需要4*512=1024个扇区,即每个扇区是1K

[281277.215000] test_emmc(14438): dirtied inode 1572868 (fuck.bin) on mmcblk0
[281277.215000] test_emmc(14438): WRITE block 9961472 on mmcblk0 (512 sectors)
[281277.215000] test_emmc(14438): WRITE block 9961984 on mmcblk0 (512 sectors)
[281277.219000] test_emmc(14438): WRITE block 9962496 on mmcblk0 (512 sectors)
[281277.220000] test_emmc(14438): WRITE block 9963008 on mmcblk0 (512 sectors)
[281283.008000] jbd2/mmcblk0-8(833): WRITE block 29730136 on mmcblk0 (8 sectors)
[281283.008000] jbd2/mmcblk0-8(833): WRITE block 29730144 on mmcblk0 (8 sectors)
[281283.013000] jbd2/mmcblk0-8(833): WRITE block 29730152 on mmcblk0 (8 sectors)
[281284.018000] kworker/u2:0(14315): WRITE block 50331904 on mmcblk0 (8 sectors)

问题1:jbd2/mmcblk0-8和kworker/u2:0有什么差别?

kworker线程创建

路径:kernel\workqueue.c

 

JBD2(journaling block device 2)

关于JBD介绍:https://help.aliyun.com/document_detail/155605.html

JDB的工作原理

JBD2(journaling block device 2)系统分析(一)-dessasic-ChinaUnix博客

性能分析之解决 jbd2 引起 IO 高问题_zuozewei的博客-CSDN博客

JDB2线程创建

[root@szclou mmcblk0-8]$ps -aux | grep jbd*
root       833  0.0  0.0      0     0 ?        S    Jan04   0:06 [jbd2/mmcblk0-8]
root     14546  0.0  0.3   1860   876 pts/2    S+   14:49   0:00 grep jbd*

JBD2源代码路径:fs\jbd2\journal.c

某大神发现jbd2日志更新时会引发io访问100%,是内核代码有bug,链接:性能分析之解决 jbd2 引起 IO 高问题_zuozewei的博客-CSDN博客

 而本人的内核却是还存在这个bug

int jbd2_log_start_commit(journal_t *journal, tid_t tid)
{int ret;write_lock(&journal->j_state_lock);ret = __jbd2_log_start_commit(journal, tid);write_unlock(&journal->j_state_lock);return ret;
}

 

相关内容

热门资讯

喜欢穿一身黑的男生性格(喜欢穿... 今天百科达人给各位分享喜欢穿一身黑的男生性格的知识,其中也会对喜欢穿一身黑衣服的男人人好相处吗进行解...
发春是什么意思(思春和发春是什... 本篇文章极速百科给大家谈谈发春是什么意思,以及思春和发春是什么意思对应的知识点,希望对各位有所帮助,...
网络用语zl是什么意思(zl是... 今天给各位分享网络用语zl是什么意思的知识,其中也会对zl是啥意思是什么网络用语进行解释,如果能碰巧...
为什么酷狗音乐自己唱的歌不能下... 本篇文章极速百科小编给大家谈谈为什么酷狗音乐自己唱的歌不能下载到本地?,以及为什么酷狗下载的歌曲不是...
家里可以做假山养金鱼吗(假山能... 今天百科达人给各位分享家里可以做假山养金鱼吗的知识,其中也会对假山能放鱼缸里吗进行解释,如果能碰巧解...
华为下载未安装的文件去哪找(华... 今天百科达人给各位分享华为下载未安装的文件去哪找的知识,其中也会对华为下载未安装的文件去哪找到进行解...
四分五裂是什么生肖什么动物(四... 本篇文章极速百科小编给大家谈谈四分五裂是什么生肖什么动物,以及四分五裂打一生肖是什么对应的知识点,希...
怎么往应用助手里添加应用(应用... 今天百科达人给各位分享怎么往应用助手里添加应用的知识,其中也会对应用助手怎么添加微信进行解释,如果能...
客厅放八骏马摆件可以吗(家里摆... 今天给各位分享客厅放八骏马摆件可以吗的知识,其中也会对家里摆八骏马摆件好吗进行解释,如果能碰巧解决你...
苏州离哪个飞机场近(苏州离哪个... 本篇文章极速百科小编给大家谈谈苏州离哪个飞机场近,以及苏州离哪个飞机场近点对应的知识点,希望对各位有...