All Projects → bytedance → Tailor

bytedance / Tailor

Licence: other

Programming Languages

c
50402 projects - #5 most used programming language

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

xigua douyin huoshan kaiyan
Xigua Video Douyin Huoshan Kaiyan

Get started

Step1: Add to your build.gradle

implementation 'com.bytedance.tailor:library:1.0.7'

Step2: For simple usage

// Using Tailor to get a mini hprof file in exception callback
Thread.setDefaultUncaughtExceptionHandler(new Thread.UncaughtExceptionHandler() {
    @Override
    public void uncaughtException(Thread t, Throwable e) {
        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);

Step3: File upload

App needs to implement upload logic by itself

Step4: Data recovery(Python version 3.5 and above)

python3 library/src/main/python/decode.py -i mini.hprof -o target.hprof

Extra

In order to facilitate everyone to understand the file format of the hprof and the details of cropping and compression, we provide three script implementations (Python version 3.5 and above)

// 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

// Data recovery
python3 library/src/main/python/decode.py -i mini.hprof -o target.hprof

Support

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

Wechat 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.
Note that the project description data, including the texts, logos, images, and/or trademarks, for each open source project belongs to its rightful owner. If you wish to add or remove any projects, please contact us at [email protected].