https://note.youdao.com/s/UjVWPaA5 格式乱了,可以看下笔记地址
这里以s3fs为例
s3用的是minio,默认配置启动即可,启动minio后,执行
echo minioadmin:minioadmin >~/.passwd-s3fs
后面s3fs需要用到。
开始干活吧
1、下载源码
git clone GitHub - s3fs-fuse/s3fs-fuse: FUSE-based file system backed by Amazon S3
2、创建json文件
- tasks.json
{ "tasks": [ { "label": "build_debug", // 任务名称,调试时可以指定不用任务进行处理 "type": "shell", // [shell, process], 定义任务作为作为进程运行还是在shell中作为命令运行; (测试没看出啥区别...) "command": "make", // 要执行的命令,可以是外部程序或者是shell命令。这里使用make编译命令 "problemMatcher": [ // 要使用的问题匹配程序。可以是一个字符串或一个问题匹配程序定义,也可以是一个字符串数组和多个问题匹配程序。 "$gcc" ], "group": { // 定义此任务属于的执行组。它支持 "build" 以将其添加到生成组,也支持 "test" 以将其添加到测试组。 "kind": "build", "isDefault": true }, "presentation": { // 配置用于显示任务输出并读取其输入的面板 "echo": true, // 控制是否将执行的命令显示到面板中。默认值为“true”。 "reveal": "always", // 控制运行任务的终端是否显示。可按选项 "revealProblems" 进行替代。默认设置为“始终”。 "focus": false, // 控制面板是否获取焦点。默认值为“false”。如果设置为“true”,面板也会显示。 "panel": "shared", // 控制是否在任务间共享面板。同一个任务使用相同面板还是每次运行时新创建一个面板。 "showReuseMessage": true, // 控制是否显示“终端将被任务重用,按任意键关闭”提示 "clear": false // 运行前清屏 } }, { "label": "build_release",//可以手动执行 "type": "shell", "command": "make", "args": ["CFLAGS = -O2"], // 编译参数, 替换makefile中让CFLAGS字段 "dependsOn":["build_clean"], // 指定依赖让task, 即会先执行build_clean,然后再执行build_release "problemMatcher": [ "$gcc" ], "group": { "kind": "build", "isDefault": true } }, { "label": "build_clean",//可以手动执行 "type": "shell", "command": "make", "args": ["clean"], // 相当于执行 make clean命令 "problemMatcher": [ "$gcc" ], "group": { "kind": "build", "isDefault": true } } ], "version": "2.0.0" }
launch.json
{ "configurations": [ { "name": "(gdb) Attach", "type": "cppdbg", "request": "attach", "program": "${workspaceFolder}/src/s3fs", "processId": "${command:pickProcess}", "MIMode": "gdb", "setupCommands": [ { "description": "Enable pretty-printing for gdb", "text": "-enable-pretty-printing", "ignoreFailures": true } ] } ] }
3、启动s3fs
./src/s3fs -o passwd_file=/home/xxx/.passwd-s3fs -s -o url=http://127.0.0.1:9000 -o use_path_request_style -f -o curldbg -o dbglevel=debug -o umask=0 -o mp_umask=0 bucketname /mnt/s3
4、打断点
这里以ls列出桶内容为例
断点这里打在s3fs_readdir方法里
3
5、attach process
按F5
然后选择自己要调试的进程
因为需要超级用户身份运行,所以会弹出输入密码的框
6、执行对应测试
cd /mnt/s3
ls
OK