发布于 

小米手表之Temrux折腾

前言

我一直有自建服务器的想法,可家里旧的台式电脑耗电太大。回想起2年前折腾的Termux,便把“魔爪”伸向了我的小米手表。尝试搭建一些服务在手表上。

以下是我的折腾过程。

安装 Termux

小米手表的安卓版本是支持安装最新的Termux

下载链接[官方]:

下载完apk文件后,利用 安卓手表ADB实用工具箱 将apk文件安装到小米手表上。

更改dpi

由于小米手表的屏幕过小,在Termux中无法调用输入法,因此利用 “安卓手表ADB实用工具箱” 更改dpi至150

更换清华源

众所周知的原因,我们需要更换软件源以提高下载速度这里推荐使用清华源使用如下命令行替换官方源为 TUNA 镜像源

1
sed -i 's@^\(deb.*stable main\)$@#\1\ndeb https://mirrors.tuna.tsinghua.edu.cn/termux/apt/termux-main stable main@' $PREFIX/etc/apt/sources.list
1
apt update && apt upgrade

ssh服务

1.安装openssh:pkg install openssh
2.启动openssh: sshd
开放端口默认为8022
3.查看用户名: whoami
4.修改用户密码: passwd
5.查看IP地址: ifconfig

后续可根据平台选择对应的ssh软件(我是用Xshell)

安装Ubuntu

1.安装基础件proot-distro:

1
pkg install proot-distro

2.安装Ubuntu:

1
proot-distro install ubuntu

3.进入Ubuntu:

1
proot-distro login ubuntu

安装网盘服务alist

1.在termux本体中运行:

1
pkg i alist

2.提权:

1
chmod +x alist

3.获取管理员信息(登陆要用)

1
alist admin
如图所示
如图所示
我的管理员信息是:
  • name: admin* passwd: VYHkW1dl

4.开启alist服务

1
alist server
如图所示
如图所示
在这里可以查看到服务端口是5244打开浏览器输入以下地址:http://ip地址:5244(ip地址是你的手表的网络ip)恭喜你🤗 ,你已经成功配置了alist服务

5.登录alist

打开浏览器输入:

http://192.168.0.119:5244/@login(192.168.0.119是我的ip地址,你需要根据你的ip进行替换)用户名填写:admin密码填写:****** (刚刚在第三步获取的密码)

6.配置相关设置

这一步便需要你自己探索了,这里提供官方wiki:https://alist.nn.ci/zh/

Termux设置自启动

每一次打开termux都要重新输入命令,实在有点繁琐。

我们可以编辑**.bashrc**文件来配置启动项
1.安装vim

1
pkg install vim

2.打开.bashrc文件

1
vi ~/.bashrc

3.编辑.bashrc文件

1
输入 "i"进入编辑模式

我的.bashrc文件如下(根据你的需要编辑):

1
sshd  #开始ssh服务alist server #开启alist服务curl -s i996.me | bash -s ****** #开启内网穿透服务

4.保存退出

1
按下esc -> 输入冒号+wq字符,按下回车

内网穿透

由于众所周知的原因,普通用户家里是没有公网IP的。如果我们想在外部网络访问搭建在小米手表上的服务,我们需要使用内网穿透。

我这里是推荐大家使用i996内网穿透服务: https://www.i996.me/

这个内网穿透服务可以在微信公众号配置,而开启这个服务也仅仅需要一行命令,而且纯免费!!

注意:目前由于强的关系,无法绑定自定义域名,故提供以下方案

Cloudflare Argo Tunnel – 公网 IP

1.安装Argo Tunnel Client

1
pkg install cloudflared

2.身份认证

1
cloudflared tunnel login

执行完毕后会输出一个链接,复制链接到浏览器内登陆账号,登录后选择使用的域名,完成验证Cloudflared 会在 ~/.cloudlflared/ 下生成 cert.pem 证书,之后的操作都依赖于此文件

3.新建 Tunnel

1
cloudflared tunnel create [Tunnel 名称]

我的【Tunnel名称】为bit

执行完命令后会输出UUID,即:

Created tunnel 【Tunnel 名称】 with id 【UUID】

每个 Tunnel 都对应一个 UUID,每新建一个 Tunnel,Cloudflared 都会在 /.cloudflared/ 下生成对应 UUID 的 json 文件~

4.配置 DNS 记录

访问域名的控制面板,进入 DNS 配置页,新建 CNAME 记录,名称填写你想要的名称,目标填写 【UUID】.cfargotunnel.com

Argo Tunnel 的一个 UUID 只会与同一账户下的一个 DNS 记录绑定

5.新建配置文件

新建 YAML 配置文件于~/.cloudflared 目录下,写入以下内容

1
tunnel: [tunnel 的名称或 UUID]credentials-file: [tunnel 的 UUID].jsoningress:  - hostname: [CNAME 记录名称].[接入 CLoudflare 的域名]    service: http://localhost:[你想要使用的端口]  - service: http_status:404

我的yaml文件名为:miwatch.yaml

6.开启 Tunnel
cd到~/.cloudflared 目录

1
cd ~/.cloudflared

执行

1
cloudflared tunnel --config miwatch.yaml run

将miwatch.yaml更改为你的yaml文件

效果