Giter VIP home page Giter VIP logo

tailor's Introduction

Tailor

简体中文版说明 >>>

GitHub license Platform API

Tailor is a general-purpose hprof cropping and compression tool developed by Xigua video android team. Through it, a mini hprof file can be dump directly during exception handling. There is no sensitive information in the file。More importantly, the file is small but the data is relatively complete, which is very suitable for offline analysis of oom and other exceptions

Apps using Tailor

Get started

Step 1: Add the JitPack repository to your build file

allprojects {
    repositories {
        maven { url 'https://jitpack.io' }
    }
}

Step 2: Add the dependency

dependencies {
    implementation 'com.github.bytedance:tailor:1.1.6'
}

Step 3: Add code for simple usage

if (e instanceof java.lang.OutOfMemoryError) {
    String path = Environment.getExternalStorageDirectory().getAbsolutePath() + File.separator + "mini.hprof";
    try {
        Tailor.dumpHprofData(path, true);
    } catch (IOException ex) {
        ex.printStackTrace();
    }
}
// Crop and compress the existing hprof files directly
Tailor.cropHprofData(source, target, true);

Step 4: Upload data

## !!! App needs to implement upload logic by itself

Step 5: Process data (Python version >= 3.5)

## Data recovery
python3 library/src/main/python/decode.py -i mini.hprof -o target.hprof
## Hprof verify
python3 library/src/main/python/verify.py -i source.hprof
## Crop and compress
python3 library/src/main/python/encode.py -i source.hprof -o mini.hprof

Extra

  1. Android Camera内存问题剖析
  2. 西瓜视频稳定性治理体系建设一:Tailor 原理及实践
  3. 西瓜视频稳定性治理体系建设二:Raphael 原理及实践

Support

  1. Communicate on GitHub issues
  2. Mail: [email protected]
  3. WeChat: 429013449
  4. QQ Group

QQ Group

License

Copyright (c) 2020 ByteDance Inc

Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at

   http://www.apache.org/licenses/LICENSE-2.0

Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.

tailor's People

Contributors

knight-zxw avatar ptrainbow avatar shentianzhou avatar

Stargazers

 avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar

Watchers

 avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar

tailor's Issues

decode hprof时发生错误

Not supported tag: 175, length: 65218099
Not supported tag: 157, length: 76630619
Not supported tag: 0, length: 76274784

A/libc: FORTIFY: open: called with O_CREAT/O_TMPFILE but no mode

执行 Tailor.dumpHprofData(target, true); 崩溃了
异常信息为:
2021-02-03 17:21:57.958 1226-1443/com.bytedance.demo E/gralloc: Arm Module v1.0
2021-02-03 17:21:57.960 1226-1443/com.bytedance.demo E/ion: ioctl c0044901 failed with code -1: Invalid argument
2021-02-03 17:22:00.685 1226-1226/com.bytedance.demo E/TAILOR: >>> open success
2021-02-03 17:22:00.685 1226-1226/com.bytedance.demo I/.bytedance.dem: hprof: heap dump "/storage/emulated/0/2.hprof" starting...
2021-02-03 17:22:01.120 1226-1226/com.bytedance.demo A/libc: FORTIFY: open: called with O_CREAT/O_TMPFILE but no mode
2021-02-03 17:22:01.120 1226-1226/com.bytedance.demo A/libc: Fatal signal 6 (SIGABRT), code -6 (SI_TKILL) in tid 1226 (.bytedance.demo), pid 1226 (.bytedance.demo)

手机机型为:Redmi Note 8 Pro Android 9

couldn't find "libtailor.so"

运行demo,找不到so
2020-12-17 17:39:18.252 27105-27105/com.bytedance.demo E/AndroidRuntime: FATAL EXCEPTION: main Process: com.bytedance.demo, PID: 27105 java.lang.UnsatisfiedLinkError: dalvik.system.PathClassLoader[DexPathList[[zip file "/data/app/com.bytedance.demo-CKMQ9X0L46A-DkP2K_dqqg==/base.apk"],nativeLibraryDirectories=[/data/app/com.bytedance.demo-CKMQ9X0L46A-DkP2K_dqqg==/lib/arm, /data/app/com.bytedance.demo-CKMQ9X0L46A-DkP2K_dqqg==/base.apk!/lib/armeabi-v7a, /system/lib, /system/vendor/lib]]] couldn't find "libtailor.so" at java.lang.Runtime.loadLibrary0(Runtime.java:1012) at java.lang.System.loadLibrary(System.java:1669) at com.bytedance.tailor.Tailor.<clinit>(Tailor.java:28) at com.bytedance.tailor.Tailor.isHprofValid(Tailor.java:46) at com.bytedance.demo.MainActivity.tailor_for_file(MainActivity.java:42) at com.bytedance.demo.MainActivity.onClick(MainActivity.java:33) at android.view.View.performClick(View.java:7352) at android.widget.TextView.performClick(TextView.java:14230) at android.view.View.performClickInternal(View.java:7318) at android.view.View.access$3200(View.java:846) at android.view.View$PerformClick.run(View.java:27800) at android.os.Handler.handleCallback(Handler.java:873) at android.os.Handler.dispatchMessage(Handler.java:99) at android.os.Looper.loop(Looper.java:214) at android.app.ActivityThread.main(ActivityThread.java:7050) at java.lang.reflect.Method.invoke(Native Method) at com.android.internal.os.RuntimeInit$MethodAndArgsCaller.run(RuntimeInit.java:494) at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:965)

裁剪后的文件用python还原会报错

Traceback (most recent call last):
File "D:\temp\fast-dump\tailor-master\library\src\main\python[decode.py](https://github.com/bytedance/tailor/issues/decode.py)", line 446, in process
decode(reader, writer)
File "D:\temp\fast-dump\tailor-master\library\src\main\python[decode.py](https://github.com/bytedance/tailor/issues/decode.py)", line 63, in decode
raise Exception('Not supported tag: %d, length: %d' % (tag, reader.tell()))
Exception: Not supported tag: 0, length: 37792595

During handling of the above exception, another exception occurred:

Traceback (most recent call last):
File "D:\temp\fast-dump\tailor-master\library\src\main\python[decode.py](https://github.com/bytedance/tailor/issues/decode.py)", line 466, in
process(args.input, args.output)
File "D:\temp\fast-dump\tailor-master\library\src\main\python[decode.py](https://github.com/bytedance/tailor/issues/decode.py)", line 452, in process
raise Exception('decode failed at %d/%d: %s' % (reader.tell(), os.path.getsize(reader.name, str(e)))
Exception: decode failed at 37792595/37792595: Not supported tag: 0, length: 37792595

获取到的文件使用python还原不了

python3 /Users/dingqiqi/Desktop/tailor-master/library/src/main/python/verify.py -i /Users/dingqiqi/Desktop/log/1.hprof
'ascii' codec can't decode byte 0x9c in position 1: ordinal not in [range(128)]

python3 /Users/dingqiqi/Desktop/tailor-master/library/src/main/python/decode.py /Users/dingqiqi/Desktop/log/2.hprof target.hprof
usage: decode.py [-h] [-i INPUT] [-o OUTPUT]
decode.py: error: unrecognized arguments: /Users/dingqiqi/Desktop/log/2.hprof target.hprof

tailor Public

裁减以后用haha库解析不了,android studio也解析不了;

不开启压缩,到处的 hprof 打不开

case 1
Tailor.dumpHprofData(path, 【true】);
拿到的 hprof ,还原之后,可以正常打开。

case 2
Tailor.dumpHprofData(path, 【false】);
直接打开,失败。
decode 还原也失败。

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. 📊📈🎉

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google ❤️ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.