在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, ""],
      ];
相关推荐
辞旧 lekkk4 小时前
【Qt】信号和槽
linux·开发语言·数据库·qt·学习·mysql·萌新
疯狂成瘾者6 小时前
服务器的单体和集群
运维·服务器
liuhuizuikeai7 小时前
可视化门禁---Linux/Qt+SqLite篇
linux·运维·qt
初願致夕霞7 小时前
基于系统调用的Linux网络编程——UDP与TCP
linux·网络·c++·tcp/ip·udp
charlie11451419110 小时前
嵌入式Linux驱动开发——新 API 字符设备驱动完整教程 - 从设备结构体到应用测试
linux·运维·驱动开发
消失的旧时光-194310 小时前
C语言对象模型系列(四)《Linux 内核里的 container_of 到底是什么黑魔法?》—— 一篇讲透 Linux 内核的“对象模型”核心技巧
linux·c语言·算法
SWAGGY..10 小时前
Linux系统编程:(二)基础指令详解
linux·运维·服务器
kdxiaojie11 小时前
U-Boot分析【学习笔记】(3)
linux·笔记·学习
烛衔溟11 小时前
TypeScript 接口继承与混合类型
linux·ubuntu·typescript
蜡笔婧萱11 小时前
Linux--远程登录服务ssh
linux·服务器·ssh