【附】相关架构及资料
往期Android高级架构资料、源码、笔记、视频。高级UI、性能优化、架构师课程、NDK、混合式开发(ReactNative+Weex)微信小程序、Flutter全方面的Android进阶实践技术,群内还有技术大牛一起讨论交流解决问题。
网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。
一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!
allow catlog storage_file:dir { search };
allow catlog storage_file:lnk_file { read };
allow catlog mnt_user_file:dir { search };
allow catlog mnt_user_file:lnk_file { read };
allow catlog fuse:dir { search getattr create write read open add_name rename remove_name };
allow catlog fuse:file { getattr create write open rename append };
allow catlog toolbox_exec:file { execute read open getattr execute_no_trans };
allow catlog logdr_socket:sock_file { write };
allow catlog logd:unix_stream_socket { connectto };
allow catlog logcat_exec:file { execute read open execute_no_trans getattr };
2.添加cat_log.sh脚本
#!/system/bin/sh
在init.方案.rc下加入如下语句
service catlog /system/bin/busybox sh /system/bin/cat_log.sh
disabled
oneshot
on property:sys.boot_completed=1
start catlog
function enable_log()
{
LOG_FILE=“/data/tool.log”
exec 2>> $LOG_FILE
exec 1>> $LOG_FILE
echo “----------------------------------”
echo “para: $*”
}
enable_log $* ; set -x
echo 1 > /proc/sys/kernel/panic
#命名文件夹名字e5_log,也可以自己更改
ENABLE_LOG_FILE=“/mnt/sdcard/.enable_logsave”
LOG_DIR=“/mnt/sdcard/LOGSAVE”
LAST_LOG_DIR=“/mnt/sdcard/LOGSAVE/last”
SAVE_LOG_COUNT=5 # 保存上5次的log,值最小为1;例为5,则last.1为最后一次重启前的log;last.5为最老的log
#echo “save last_time ${SAVE_LOG_COUNT} log”
#if [ ! -f “$ENABLE_LOG_FILE” ];then
echo “disable logsave”
exit
#fi
#echo “enable logsave”
if [ ! -d “$LOG_DIR” ];then
mkdir $LOG_DIR
fi
if [ -d “ L A S T L O G D I R . LAST_LOG_DIR. LASTLOGDIR.SAVE_LOG_COUNT” ];then
rm -r “ L A S T L O G D I R . LAST_LOG_DIR. LASTLOGDIR.SAVE_LOG_COUNT”
fi
#for((i= ${SAVE_LOG_COUNT}-1; $i >= 1 ;i–));do
#for i in $(seq expr $SAVE_LOG_COUNT - 1
-1 1)
i=$((SAVE_LOG_COUNT -1))
while [ $i -ge 1 ]
do
if [ -d “ L A S T L O G D I R . LAST_LOG_DIR. LASTLOGDIR.i” ];then
#echo " L A S T L O G D I R . LAST_LOG_DIR. LASTLOGDIR.i is exists "
if [ “ls -a $LAST_LOG_DIR.$i
” = “” ]; then
echo “ L A S T L O G D I R . LAST_LOG_DIR. LASTLOGDIR.i is indeed empty”
else
echo “ L A S T L O G D I R . LAST_LOG_DIR. LASTLOGDIR.i is not empty”
#j=expr $i + 1
j= ( ( (( ((i+1))
mv “ L A S T L O G D I R . LAST_LOG_DIR. LASTLOGDIR.i” “ L A S T L O G D I R . LAST_LOG_DIR. LASTLOGDIR.j”
fi
#else
#echo “ L A S T L O G D I R . LAST_LOG_DIR. LASTLOGDIR.i isnot exists”
fi
i= ( ( (( ((i-1))
done
#创建上一次日志保存目录
mkdir $LAST_LOG_DIR.“1”
#保存上次开机之后的log
mv $LOG_DIR/*.log $LAST_LOG_DIR.“1”
mv $LOG_DIR/.log $LAST_LOG_DIR.“1”
DATE=$(date +%Y%m%d%H%M)
cat /sys/fs/pstore/console-ramoops"-0" > L O G D I R / " LOG_DIR/" LOGDIR/"DATE"_panic_kmsg.log
echo “------start kmsg log------”
cat /proc/kmsg > L O G D I R / " LOG_DIR/" LOGDIR/"DATE"_kmsg.log &
echo “------start logcat log------”
logcat -v time -n 1 -f L O G D I R / " LOG_DIR/" LOGDIR/"DATE"_logcat.log -r10240
3.拷贝脚本到system/bin,在mk里添加:
PRODUCT_COPY_FILES +=$(CUR_PATH)/cat_log.sh:system/bin/cat_log.sh
4.property_service里赋予权限
在property_service.cpp 的检查权限check_mac_perms函数中添加:
if(strcmp(“persist.sys.cat_log”,name) == 0)
{
return 1;
}
新的开始
改变人生,没有什么捷径可言,这条路需要自己亲自去走一走,只有深入思考,不断反思总结,保持学习的热情,一步一步构建自己完整的知识体系,才是最终的制胜之道,也是程序员应该承担的使命。
《系列学习视频》
《系列学习文档》
《我的大厂面试之旅》
网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。
一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!
[外链图片转存中…(img-sEWSnCit-1715875493470)]
网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。
一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!