在Termux中部署一个简单的服务导航页

之前的文章中, 谈到了怎样将Android手机改造为Linux服务器, 并且可以部署各种服务, 但是每个Web服务都占用一个单独的端口号, 多了之后怎么记得住呢?

我们可以再部署一个Web服务, 显示一个服务导航页, 每次需要什么服务通过导航页就可以快速抵达, 无需记住繁杂的端口号

实现过程

先安装一个http服务, 我选择了darkhttpd, 一个很轻量的工具

bash 复制代码
pkg install darkhttpd
darkhttpd --help

创建导航页

bash 复制代码
mkdir -p ~/www/
cd ~/www
nano index.html

页面内容如下, 需要导航的服务可以自行更改services定义部分

bash 复制代码
<!doctype html>
<html lang="en-US">
  <head>
    <meta charset="utf-8" />
    <meta name="viewport" content="width=device-width, initial-scale=1" />
    <link rel="shortcut icon" href="#" />
    <title>Services List</title>
  </head>
  <body>
    <div class="container">
      <h1>Services List</h1>
      <div id="services" class="list-group">
      </div>
    </div>
  
    <script>
      let services = [
        ["VSCode", 8101, ""],
        ["Siyuan", 6806, ""],
        //["Cloudreve", 5212, ""],
      ];
      let container = document.querySelector("#services");
      let hostname = window.location.hostname;
      let content = "";
      services.forEach((service) => {
        content += "<a class=\"list-group-item list-group-item-action\" "
                + "target=\"_blank\" "
                + "href=\"http://"
                + hostname + ":"
                + service[1]
                + service[2]
                + "\">"
                + service[0]
                + "</a>\n";
      })
      container.innerHTML = content;
    </script>
    <link href="https://cdn.jsdelivr.net/npm/bootstrap@5.1.3/dist/css/bootstrap.min.css" rel="stylesheet" integrity="sha384-1BmE4kWBq78iYhFldvKuhfTAU6auU8tT94WrHftjDbrCEXSU1oBoqyl2QvZ6jIW3" crossorigin="anonymous">
    <script src="https://cdn.jsdelivr.net/npm/bootstrap@5.1.3/dist/js/bootstrap.bundle.min.js" integrity="sha384-ka7Sk0Gln4gmtz2MlQnikT1wXgYsOg+OMhuP+IlRH9sENBO0LRn5q+8nbTov4+1p" crossorigin="anonymous"></script>
  </body>
</html>

绑定80端口号

测试一下启动服务, 注意: 仅root用户可以绑定1024以下的端口号, 若要绑定80端口, 必须使用root身份执行

bash 复制代码
su -c "/data/data/com.termux/files/usr/bin/darkhttpd /data/data/com.termux/files/home/www --port 80"

运行正常, 访问正常, 现在将它服务化, 实现开机自启动

bash 复制代码
mkdir -p $PREFIX/var/service/darkhttpd
cat << 'EOF' > $PREFIX/var/service/darkhttpd/run
#!/data/data/com.termux/files/usr/bin/sh
# 使用绝对路径调用系统 su,并将所有输出写入home目录的 log 文件中
exec /data/data/com.termux/files/usr/bin/su -c "/data/data/com.termux/files/usr/bin/darkhttpd /data/data/com.termux/files/home/www --port 80" > /data/data/com.termux/files/home/log/darkhttpd.log 2>&1
EOF

chmod +x $PREFIX/var/service/darkhttpd/run
sv-enable darkhttpd
sv up darkhttpd
sv status darkhttpd

访问Web, 一个简单的导航页就实现了, 需要新增导航服务时修改一下html即可, 以下services部分, 第一个参数是URL标题, 第二个是服务对应端口号, 第三个是后面的默认路径

javascript 复制代码
      let services = [
        ["VSCode", 8101, ""],
        ["Siyuan", 6806, ""],
        //["Cloudreve", 5212, ""],
      ];
相关推荐
fTiN CAPA1 小时前
服务器无故nginx异常关闭之kauditd0 kswapd0挖矿病毒 CPU占用200% 内存耗尽
运维·服务器·nginx
北山有鸟1 小时前
相机的水平消隐与垂直消隐
linux·驱动开发·相机
love530love1 小时前
修复 ComfyUI 插件 ComfyUI-BiRefNet-ZHO 报错 - Windows
服务器·人工智能·windows·python·birefnet-zho
还不秃顶的计科生1 小时前
多模态模型下载
java·linux·前端
无忧.芙桃2 小时前
进程控制之进程等待
linux·运维·服务器
云栖梦泽2 小时前
Linux内核与驱动:13.从设备树到Platform平台总线
linux·运维·c++·嵌入式硬件
纯氧゜2 小时前
文件名长度真相:别再被8.3规则误导了
linux·ai写作
xlq223222 小时前
43.线程同步
大数据·linux
charlie1145141912 小时前
嵌入式Linux驱动开发指南02——内核空间基础与硬件访问
linux·运维·c语言·驱动开发·嵌入式硬件
不会写DN2 小时前
TCP 长连接服务:登录注册认证体系实战指南
服务器·网络·网络协议·tcp/ip·计算机网络·面试