研究 termux 时遇到的诡异的问题

想法

手上有个旧的Android 手机 MI 5 plus闲置了两年,性能还相当不错的,就是屏幕被我摔花了,最近总想着让他发挥点价值。

突然想到能不能用它当小型Linux服务器放在家里,用内网穿透工具 frp 将他的sshd 服务端口转发的公网的服务器上, 这样在外面就可以通过这台公网服务器连接上这个 linux 服务器 。

探索

一番网络搜索研究 发现两种方案:

  • 第一种安装 linux deploy,比较大, 需要 root
  • 第二种 用 termux,能访问有限的目录文件,可以安装各种Linux 应用,

果断选择了termux, 不想 root. 顺利安装了 python, gcc, openssh 等软件 。。。通过frp的客户端frpc连接上公网, 从公司 ssh连接上了这个 5plus ,爽歪歪。

障碍

但是-- 有个奇怪的问题, 每隔一分多钟会断开。 各种 ssh, frp客户端日志和服务器日志检查,发现是 frp客户端每隔 1分多钟会断开。

这个问题困扰了我几个星期,一开始还怀疑是运营商 每几分钟重置链接。但是我电脑上的 frpc 却没事。。。

源代码分析

后来分析frp的golang源码,打开详细日志 发现, 服务器上超时时间是90秒,客户端心跳上报时间是30秒, 而termux 上运行的frpc,服务器上显示的是超时,超时后会断开客户端,然后frp客户端会马上重连, 这个时间设定无论如何都不应该超时呀。 自己编译一边, 同样代码编译的frp客户端程序在mac电脑上运行却没问题,日志中看到每隔30秒会发布心跳。但是这个心跳日志在termux上没有。很是困惑呀, 仔细阅读代码。

于是开始怀疑是代码中的心跳定时器在电脑上和在手机上的时间不一样。 于是写了个最简单的go程序,定时每隔1秒输出包含时间信息到日志。在电脑上输出正常。 放到termux上去执行,发现了非常诡异的结果,输出的时间信息,并不是每秒输出,几乎是每隔6到 7秒中,但是我到定时器是每隔1秒啊!! wfk, 这是什么情况,太不可思议了

就这个定时器不准到问题再次去google 了一番,发现是Android深度睡眠导致的,为了减少耗电,后台程序的运行很慢,连timer定时器也不例外。

除掉障碍(解决办法)

在手机上termux里面执行termux-wake-lock命令 ,手机会弹出是否运行后台执行的,选择允许就好了,

然后在去 termux再次frp客户端,哈哈,终于不会频繁掉线了!不容易呀

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章