HomeAssistant开源的智能家居docker快速部署实践笔记(CentOS7)

1. SGCC_Electricity 应用介绍

SGCC_Electricity 是一个用于将国家电网(State Grid Corporation of China,简称 SGCC)的电费和用电量数据接入 Home Assistant 的自定义集成组件。通过该应用,用户可以实时追踪家庭用电量情况,并将每日用电量数据保存到数据库中,以便后续查询和分析。

1.1. 核心功能

  1. 实时数据接入

    • 电费与用电量同步:SGCC_Electricity 能够直接从国家电网的官方系统获取用户家庭的实时电费和用电量数据,并同步到 Home Assistant 中。
    • 自动化更新:支持设置定时更新频率,确保 Home Assistant 中的数据始终与国家电网的最新数据保持一致。
  2. 数据存储与历史查询

    • 数据库存储:应用支持将每日用电量数据保存到用户指定的数据库中(如 Sqlite3 等),确保历史数据有迹可循。
    • 历史数据查询:用户可以通过 Home Assistant 的界面或第三方工具查询历史用电量数据,分析用电趋势,制定节能计划。
  3. 可视化展示

    • Home Assistant 仪表板集成:SGCC_Electricity 提供的数据可以直接在 Home Assistant 的仪表板中展示,用户可以自定义仪表板,以图表、卡片等形式直观地查看用电量情况。
    • 多维度分析:支持按日、周、月等时间维度分析用电量,帮助用户更好地了解家庭用电习惯。

1.2. 使用场景

  • 家庭节能管理:用户可以通过 SGCC_Electricity 实时了解家庭用电量情况,发现高耗电设备或时段,及时调整用电习惯,实现节能减排。
  • 智能家居联动:结合 Home Assistant 的其他功能,用户可以设置自动化规则,如当用电量超过一定阈值时自动关闭非必要电器,或根据用电量情况调整室内温度等。
  • 数据分析与报告:对于需要定期提交用电量报告的用户(如企业、学校等),SGCC_Electricity 提供的历史数据查询功能可以大大简化报告制作流程。

1.3. 关于Home Assistant

Home Assistant是一个开源的智能家居自动化系统,其核心特点是将本地控制和隐私保护放在首位。它由全球范围内的爱好者和DIY(自己动手做)热衷者组成的社区推动发展,并且在2024年被列为顶级开源项目之一。以下是关于Home Assistant的简单概述:

  • 开源与社区驱动:Home Assistant是一个非营利项目,由Open Home Foundation支持,它不能被出售或收购。该系统的开发依赖于一个活跃且友好的全球社区,成员们热衷于分享他们对智能家居的热情和技术。
  • 本地控制与隐私:Home Assistant强调本地控制,意味着用户的数据和操作主要在本地设备上处理,而不是上传到云端,这有助于保护用户隐私。
  • 语音助手集成:Home Assistant支持与主流语音助手如Alexa和Google Assistant的集成,允许用户通过语音命令控制家中的智能设备。
  • 自定义与扩展性:作为一个开源项目,Home Assistant提供了高度的自定义和扩展性,用户可以根据自己的需求添加功能或集成新的设备。
  • 快速且私密的语音助手:Home Assistant还拥有自己的语音助手,它运行在价格实惠的硬件上,提供极快的响应速度,并且支持唤醒词功能,同时保证用户数据的私密性。
  • 社区参与:Home Assistant的社区非常活跃,用户可以参与讨论、分享经验,甚至贡献代码来改进系统。
  • 最新动态与路线图:用户可以通过Home Assistant的官方网站了解项目的最新进展、发布说明、博客文章以及未来的发展路线图。
  • Home Assistant的官方网站是https://www.home-assistant.io/,用户可以在这里找到更多关于系统的详细信息、安装指南、设备集成列表以及社区资源等。
    在这里插入图片描述

2. 系统快速部署

2.1. 系统概述

Docker镜像部署方式

系统由SGCC_Electricity 应用系统和Home Assistant系统平台构成,其中Home Assistant是本地私有化离线方式。
在这里插入图片描述

2.2. CentOS7 离线安装Docker

Docker 离线安装包下载地址https://download.docker.com/linux/centos/7/x86_64/stable/Packages/。

依赖包参考如下文档,在此只安装核心文件。

[root@DeepLearning ha]#rpm -ivh docker-ce-cli-19.03.12-3.el7.x86_64.rpm
[root@DeepLearning ha]#rpm -ivh container-selinux-2.119.1-1.c57a6f9.el7.noarch.rpm
[root@DeepLearning ha]#rpm -ivh containerd.io-1.2.13-3.2.el7.x86_64.rpm
[root@DeepLearning ha]#rpm -ivh docker-ce-18.09.0-3.el7.x86_64.rpm
[root@DeepLearning ha]#rpm -ivh docker-compose-plugin-2.6.0-3.el7.x86_64.rpm 
  • 启动 Docker 服务
    安装完成后,启动 Docker 服务:
[root@DeepLearning ha]#systemctl start docker
  • 设置 Docker 开机自启:
[root@DeepLearning ha]#systemctl enable docker
  • 检查 Docker 安装
    确保 Docker 本身已正确安装:
[root@DeepLearning ha]#docker --version

2.3. 安装Home Assistant镜像

官方安装文档,参考https://www.home-assistant.io/installation/linux。
随着 Docker 命令变得越来越复杂,切换到使用 docker compose 可能会更合适,因为它支持在服务失败或系统重启时自动重启。创建一个 compose.yml 文件(注:实际文件名为 docker-compose.yml)。

创建ha目录,创建docker-compose.yml文件,把如下内容编辑进去。

[root@DeepLearning ha]#mkdir ha
[root@DeepLearning ha]#touch docker-compose.yml
[root@DeepLearning ha]#nano docker-compose.yml

docker compose 安装方式,镜像配置文件。

services:homeassistant:container_name: homeassistantimage: ghcr.io/home-assistant/home-assistant:stable # 中国地区镜像地址:ghcr.nju.edu.cn/home-assistant/home-assistant:stable或者用你自己的 $volumes:- "./config:/config"- "/etc/localtime:/etc/localtime:ro"- "/run/dbus:/run/dbus:ro" # 蓝牙设备需要environment:- SET_CONTAINER_TIMEZONE=true- CONTAINER_TIMEZONE=Asia/Shanghairestart: unless-stoppedprivileged: true

从中国区镜像地址安装镜像。

[root@DeepLearning ha]#docker compose up --build -d

Docker 容器默认运行在独立的网络命名空间中,若未显式映射端口,外部无法访问。设置ports端口,如下配置所示。

[root@DeepLearning ha]#vi docker-compose.yml
services:homeassistant:container_name: homeassistantimage: ghcr.nju.edu.cn/home-assistant/home-assistant:stableports:- "8123:8123" # 关键:将容器的 8123 端口映射到宿主机的 8123 端口volumes:- "./config:/config"- "/etc/localtime:/etc/localtime:ro"- "/run/dbus:/run/dbus:ro"environment:- SET_CONTAINER_TIMEZONE=true- CONTAINER_TIMEZONE=Asia/Shanghairestart: unless-stoppedprivileged: true

停止当前服务,重新启动服务。

docker compose down  # 停止当前服务
docker compose up -d # 重新启动服务

2.4. Home Assistant获取永久访问令牌

https://blog.csdn.net/qq_25886111/article/details/106282492

在这里插入图片描述

2.5. 安装sgcc_electricity镜像

2.5.1. 克隆仓库

git clone https://github.com/ARC-MX/sgcc_electricity_new.git
# 如果github网络环境不好的话可以使用国内镜像,完全同步的,个人推荐使用国内镜像
# git clone https://gitee.com/ARC-MX/sgcc_electricity_new.git
cd sgcc_electricity_new

2.5.2. 创建环境变量文件

cp example.env .env
vim .env # 参考以下文件编写.env文件

### 以下项都需要修改
## 国网登录信息
# 修改为自己的登录账号
PHONE_NUMBER="xxx" 
# 修改为自己的登录密码
PASSWORD="xxxx" 
# 排除指定用户ID,如果出现一些不想检测的ID或者有些充电、发电帐号、可以使用这个环境变量,如果有多个就用","分隔,","之间不要有空格
IGNORE_USER_ID=xxxxxxx,xxxxxxx,xxxxxxx# SQLite 数据库配置
# or False 不启用数据库储存每日用电量数据。
ENABLE_DATABASE_STORAGE=True
# 数据库名,默认为homeassistant
DB_NAME="homeassistant.db"
# COLLECTION_NAME默认为electricity_daily_usage_{国网用户id},不支持修改。## homeassistant配置
# 改为你的localhost为你的homeassistant地址
HASS_URL="http://localhost:8123/" 
# homeassistant的长期令牌
HASS_TOKEN="eyxxxxx"## selenium运行参数
# 任务开始时间,24小时制,例如"07:00”则为每天早上7点执行,第一次启动程序如果时间晚于早上7点则会立即执行一次,每隔12小时执行一次。
JOB_START_TIME="07:00"
# 每次操作等待时间,推荐设定范围为[2,30],该值表示每次点击网页后所要等待数据加载的时间,如果出现“no such element”诸如此类的错误可适当调大该值,如果硬件性能较好可以适当调小该值
RETRY_WAIT_TIME_OFFSET_UNIT=15## 记录的天数, 仅支持填写 7 或 30
# 国网原本可以记录 30 天,现在不开通智能缴费只能查询 7 天造成错误
DATA_RETENTION_DAYS=7## 余额提醒
# 是否缴费提醒
RECHARGE_NOTIFY=Flase
# 余额
BALANCE=5.0
# pushplus token 如果有多个就用","分隔,","之间不要有空格,单个就不要有","
PUSHPLUS_TOKEN=xxxxxxx,xxxxxxx,xxxxxxx

2.5.3. 运行

我已经优化了镜像环境,将镜像的地址配置为阿里云,如果要使用docker hub的源可以将docker-compose.yml中 image: registry.cn-hangzhou.aliyuncs.com/arcw/sgcc_electricity:latest 改为 arcw/sgcc_electricity:latest

services:sgcc_electricity_app:env_file:- .envimage: registry.cn-hangzhou.aliyuncs.com/arcw/sgcc_electricity:latest # for use docker.io: arcw/sgcc_electricity:latestprivileged: true # 这是后加上的container_name: sgcc_electricitynetwork_mode: "host"environment:- SET_CONTAINER_TIMEZONE=true- CONTAINER_TIMEZONE=Asia/Shanghairestart: unless-stoppedvolumes:- ./:/data        # if you want to read homeassistant.db, homeassistant.db is in the container at /data/command: python3 main.pyinit: true

运行获取传感器名称:

docker-compose up -d
docker-compose logs sgcc_electricity_app

在这里插入图片描述

3. 实践中所遇到的问题:

3.1. docker: ‘compose’ is not a docker command

docker compose version
docker: ‘compose’ is not a docker command.

Docker Compose 是一个独立的工具,需要单独安装。根据你的 Docker 版本和环境,选择适合的安装方法。

3.2. 运行docker镜像,报权限错:

OpenBLAS blas_thread_init: pthread_create failed for thread 1 of 6: Operation not permitted

解决方案:
增加参数,privileged: true:这会授予容器几乎所有的内核功能,类似于使用 docker run --privileged。

vim docker-compose.yml
services:sgcc_electricity_app:env_file:- .envimage: registry.cn-hangzhou.aliyuncs.com/arcw/sgcc_electricity:latest # for use docker.io: arcw/sgcc_electricity:latestcontainer_name: sgcc_electricitynetwork_mode: "host"environment:- SET_CONTAINER_TIMEZONE=true- CONTAINER_TIMEZONE=Asia/Shanghairestart: unless-stoppedvolumes:- ./:/data        # if you want to read homeassistant.db, homeassistant.db is in the container at /data/command: python3 main.pyinit: true

参考:
[1]. https://github.com/ARC-MX/sgcc_electricity_new
[2]. https://www.home-assistant.io/installation/linux
[3].花陌黎呀. Home Assistant获取永久访问令牌. CSDN博客. 2020.05
[4].一枚小爪哇. 【CentOS7离线安装Docker】. CSDN博客. 2021.12

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.pswp.cn/bicheng/82284.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

maven 3.0多线程编译提高编译速度

mvn package 默认只使用 单线程 来执行构建生命周期(即顺序地构建每一个模块)。 如果你使用的是多模块项目,Maven 从 3.0 开始提供了**并行构建(parallel build)**的能力,但它不是默认开启的。 如何启用多…

python模块管理环境变量

概要 在 Python 应用中,为了将配置信息与代码分离、增强安全性并支持多环境(开发、测试、生产)运行,使用专门的模块来管理环境变量是最佳实践。常见工具包括: 标准库 os.environ:直接读取操作系统环境变量…

K8s 集群运行时:从 Docker 升级到 Containerd

一、背景:Kubernetes容器运行时演进史 自2020年Kubernetes 1.20版本宣布弃用Docker作为默认容器运行时以来,容器技术生态经历了重大变革。作为CNCF毕业项目,Containerd凭借其轻量化架构、原生CRI支持和卓越性能表现,逐渐成为云原生…

30-消息队列

一、消息队列概述 队列又称消息队列,是一种常用于任务间通信的数据结构,队列可以在任务与任务间、 中断和任务间传递信息,实现了任务接收来自其他任务或中断的不固定长度的消息,任务能够从队列里面读取消息,当队列中的…

AI Agent开发第74课-解构AI伪需求的魔幻现实主义

开篇 🚀在之前的系列中我们狂炫了AI Agent的各种高端操作(向量数据库联动、多模态感知、动态工作流等…),仿佛每个程序员都能用LLM魔法点石成金✨。 但今天咱们要泼一盆透心凉的冷水——当企业把AI当成万能胶水强行粘合所有需求时,连电风扇都能被玩出量子纠缠的魔幻现实…

低代码AI开发新趋势:Dify平台化开发实战

在人工智能快速发展的今天,AI应用的开发方式也在不断演变。从传统的手写代码到如今的低代码甚至零代码开发,技术的进步让更多的非专业开发者也能轻松上手。本文将带你走进Dify平台化开发的世界,探索如何通过这一强大的低代码AI开发平台&#…

开发积累总结

export default 和export const 均用于从模块导出函数、对象或原始值,区别在于: export default:一个文件中只能有一个,为默认导出,在引用时指定名字。 export const:一个文件中有多个,为命名…

【TCP/IP协议族详解】

目录 第1层 链路/网络接口层—帧(Frame) 1. 链路层功能 2. 常见协议 2.1. ARP(地址解析协议) 3. 常见设备 第2层 网络层—数据包(Packet) 1. 网络层功能 2. 常见协议 2.1. ICMP(互联网…

vocabulary in program

编号意思(英译中)音标单词1n. 稀薄;稀罕;珍奇/ˈreərɪsn/rareness2n.登记表,注册簿;注册员;(人或乐器的)声区,音区;(适合特定场合使…

整平机技术进阶:从原理到实战的深度解析

一、整平机的力学原理与数学模型 整平机的核心在于通过材料塑性变形消除内应力,其力学过程可简化为以下模型: 弹塑性变形理论 当材料通过辊轮时,表层受拉应力,芯部受压应力,超过屈服强度后产生永久变形。 关键公式&a…

【b站计算机拓荒者】【2025】微信小程序开发教程 - chapter1 初识小程序 - 3项目目录结构4快速上手

3 项目目录结构 3.1 项目目录结构 3.1.1 目录介绍 # 1 项目主配置文件,在项目根路径下,控制整个项目的-app.js # 小程序入口文件,小程序启动,会执行此js-app.json # 小程序全局配置文件,配置小程序导航栏颜色等信息…

427. 建立四叉树

https://leetcode.cn/problems/construct-quad-tree/description/?envTypestudy-plan-v2&envIdtop-interview-150思路:这题乍一看很复杂但是只要读懂题找到规律就会发现其实很简单 四叉树的构造规律: 1. 如果一个区域的值全相等,那么这个…

IDEA中创建SpringBoot项目没有Java8

IDEA中创建SpringBoot项目没有Java8 文章目录 IDEA中创建SpringBoot项目没有Java8一:解决办法 很久没单独创建springboot项目,今天使用idea的Spring Initializr 创建 Spring Boot项目时,发现java版本里,无法选择jdk1.8,只有17、21、22,所以本文介绍了使用Spring Ini…

聊一聊手动测试与探索性测试的区别

目录 一 定义与目标 手动测试 探索性测试 二 执行方式 手动测试 探索性测试 三 测试重点及计划性 手动测试 探索性测试 四 测试效率及成本 手动测试 探索性测试 五 优缺点对比 六 关键却别与总结 七 适应场景 手动测试 探索性测试 八 实际应用与结合 在我们进…

Spring用到的设计模式

Spring框架中广泛应用了多种设计模式,以提升代码的灵活性和可维护性。 工厂模式:BeanFactory,整个 IoC 容器就是一个工厂。 单例模式:Spring 管理的 Bean 默认都是单例的。 模版方法:如 RedisTemplate、JdbcTemplat…

Mybatis(2)

sql注入攻击 SQL注入攻击是一种常见的网络安全威胁,攻击者通过在输入字段中插入恶意SQL代码,绕过应用程序的安全机制,直接操纵数据库。 SQL注入的原理 SQL注入利用应用程序未对用户输入进行充分过滤或转义的漏洞。当用户输入被直接拼接到S…

【Node.js】高级主题

个人主页:Guiat 归属专栏:node.js 文章目录 1. Node.js 高级主题概览1.1 高级主题架构图 2. 事件循环与异步编程深度解析2.1 事件循环机制详解事件循环阶段详解 2.2 异步编程模式演进高级异步模式实现 3. 内存管理与性能优化3.1 V8 内存管理机制内存监控…

冰箱热交换的原理以及如何加氟

冰箱如何加氟: 氟利昂被节流装置降压后,进入冰箱的蒸发器,此时它处于低温低压液态状态。在冰箱内部(例如 0C 或 -10C):它很容易气化(因为其沸点很低)在气化过程中吸收周围热量。 1…

WordPress多语言插件安装与使用教程

WordPress多语言插件GTranslate的使用方法 在wordpress网站后台搜索多语言插件GTranslate并安装,安装完成、用户插件后开始设置,以下为设置方法: 1、先在后台左侧找到Gtranslate,进入到设置界面 2、选择要显示的形式&#xff0c…

DELL EMC PowerStore BBU更换手册

写在前面 上周给客户卖了一个BBU电池,客户要写一个更换方案。顺利完成了更换,下面就把这个更换方案给大家share出来,以后客户要写,您就Ctrlc 和Ctrlv就可以了。 下面的步骤是最理想的方式,中间没有任何的问题&#xff…