本地部署 Home Assistant 高级自动化 AppDaemon 并实现外部访问

AppDaemon 是一款用 Python 编写的、独立于 Home Assistant 运行时的自动化应用程序运行环境,它允许用户使用 Python 编写更加复杂、灵活和可维护的自动化逻辑,而不仅仅依赖于 Home Assistant 内置的 YAML 或可视化自动化编辑器。本文将详细介绍如何利用 Docker 在局域网内部署 AppDaemon 并结合路由侠实现外网访问局域网内部署的 AppDaemon 。

第一步,本地部署安装 AppDaemon

1,本教程操作环境为 Linux Ubuntu 系统,AppDaemon 依赖 Docker 运行,我们需要先确保你的系统上已经安装了 Docker 。如果尚未安装,可以参考文档进行安装,点此查看

2,安装 Docker Compose 。

复制代码
sudo curl -L "https://github.com/docker/compose/releases/download/$(curl -s https://api.github.com/repos/docker/compose/releases/latest | grep -Po '"tag_name": "\K.*\d')" /usr/local/bin/docker-compose

3,可以参考文档安装 Home Assistant ,点此查看,安装完成后从 HA 用户界面生成长期访问令牌,复制以备后用。

4,在终端输入以下命令创建并进入项目目录。

复制代码
mkdir -p ~/appdaemon && cd ~/appdaemon
mkdir config

5,创建 docker-compose.yml 文件。

复制代码
sudo vim docker-compose.yml

写入以下内容:

复制代码
version: '3'
services:
  appdaemon:
    image: acockburn/appdaemon:latest
    container_name: appdaemon
    restart: unless-stopped
    ports:
      - "5050:5050"
    volumes:
      - ./config:/conf
    environment:
      - TZ=Asia/Shanghai
    networks:
      - appdaemon-net

networks:
  appdaemon-net:
    driver: bridge

6,编辑 ~/appdaemon/config/appdaemon.yaml 文件。

复制代码
sudo vim ~/appdaemon/config/appdaemon.yaml

修改你的 Home Assistant 地址和长期访问令牌等基本配置。

复制代码
appdaemon:
  latitude: 31.2304
  longitude: 121.4737
  elevation: 10
  time_zone: Asia/Shanghai
  plugins:
    HASS:
      type: hass
      api_port: 8123
      ha_url: http://你的服务器 IP:8123
      token: 你的长期访问令牌

http:
  url: http://0.0.0.0:5050
  ssl: false

admin:
api:
hadashboard:

7,启动 AppDaemon 服务。

复制代码
docker-compose up -d

8,打开浏览器访问地址 http://你的服务器 IP:5050 ,就能看到你部署的 AppDaemon 界面了。

第二步,外网访问本地 AppDaemon

安装路由侠内网穿透。

1,当前未提供网页管理,需要先在任意一台 Windows 机器安装路由侠 Windows 版本,用作跨机器管理。点此下载

2,在路由侠客户端主界面,进入" 设备管理 ",点击右下角的" 添加设备 ",此时可查看到对应的安装码,此安装码用于将设备添加到对应账号下,可选中后复制。

3,直接下载后导入:

复制代码
wget https://dl.luyouxia.com:8443/v2/lyx-docker-x86_64.tar
docker load -i lyx-docker-x86_64.tar

4,然后使用该镜像启动容器。

复制代码
docker run --name lyx -it --restart=always --net=host -e code=这里填写安装码 luyouxia/lyx

5,此时,需要等待下载和安装的过程,如果一切正常,最终可以看到一些输出,并且可以看到如下提示:

复制代码
[Device] Logged in. Token: ....

这就表示安装成功了。

当前 Linux 终端这边,如果是使用的上面的命令,Docker 是运行在前台,此时可以按住 Ctrl + C ,退出路由侠,容器也将退出。现在可以使用以下命令将其放入后台持续运行:

复制代码
docker start lyx

注意如果容器删除,重新 docker run , 将创建为新的设备。

需要注意的是,因为容器参数已经添加了 --restart=always ,这样开机就会自动启动,不需要再手动启动路由侠了。

6,现在回到 Windows 这边设备列表,点击右上角的 × 返回主界面,再次进入,就可以找到这个设备,可以修改名称。

7,回到主界面,点击【内网映射】。

8,注意右上角的设备名称下拉框,这里选中刚刚添加的设备名称,此时在这个界面上添加的映射,就属于刚刚这个设备。添加或修改一般需要等待 30 秒,容器中的路由侠进程就会更新并加载。切换好设备后,点击【添加映射】。

9,选择【原生端口】。

10,在内网地址填写你的服务器 IP 和 AppDaemon 端口 5050 后点击【创建】按钮,如下图。

11,创建好后,就可以看到一条映射的公网地址,鼠标右键点击【复制地址】。

12,在外网电脑上,打开浏览器,在地址栏输入从路由侠生成的外网地址,就可以看到内网部署的 AppDaemon 界面了。

相关推荐
2401_8346369918 小时前
Nginx 从入门到实战:静态 / 动态站点、PHP 部署与反向代理全解析
运维·nginx·php
爱喝水的鱼丶18 小时前
SAP-ABAP:SAP视图开发入门:四类标准视图的适用场景与创建步骤详解
服务器·数据库·性能优化·sap·abap
aosky18 小时前
一台电脑配置多个 SSH Key 对应不同的 GitHub 账号
运维·ssh·github
云登指纹浏览器19 小时前
WebDriver反检测技术详解:如何让自动化脚本看起来像真实浏览器
运维·自动化·跨境电商
xmtxz19 小时前
计算机网络基础课程学习心得:从理论抽象到硬核实战的进阶之路
运维·学习
RisunJan20 小时前
Linux命令-pgrep (通过进程名查找进程 ID)
linux·运维
2601_9619633820 小时前
技术解剖:哈希值、区块链与CA认证如何守护电子合同安全?
网络·人工智能·安全·区块链·智能合约·政务
2601_9619633820 小时前
从“电子化”到“自动化”:2026年智能合约与电子合同融合的技术逻辑与法律适配
网络·人工智能·区块链·智能合约·政务
Teacher.chenchong21 小时前
AI-Agent2.0 科研全链路实战营:LLM+NotebookLM + 自动化编程 + 文献管理 + 论文写作,搭建本地科研智能体
人工智能·自动化
回忆2012初秋21 小时前
【Nginx】优雅地走进高性能 Web 服务器世界(1)
服务器·前端·nginx