5.9 KiB
Zigbee2MQTT
配置说明
mqtt
- 如果不使用mosquito to broker插件,请填写MQTT详细信息(使用mosquito to broker插件时可不填写)。格式可参考下面的实例
server: mqtt://localhost:1883
user: mqtt
password: "123456"
注意:如果密码包含某些特殊字符(由yaml规范保留),则需要加上引号。所以我们建议如果日志显示密码错误时,优先考虑加上引号。
serial
- 端口
填写串口详细信息(例如USB协调器的端口)。格式可参考下面的实例
USB协调器
port: /dev/ttyUSB0
如果您不知道详细的端口,并且只有一个USB设备连接到您的机器,请尝试/dev/ ttyUSB0。否则,请查看“配置 - 系统 - 硬件 - 全部硬件”,在搜索上输入“tty”查看。
网络版协调器(xzg固件示例)
port: tcp://xzg.local:6638
查看适配器的ip地址
注意!!!
从2.0.0开始,zigbee2mqtt引入了新的配置规则,要求必须填写适配器信息。
- 适配器
适配器的类型配置,常见的
TI的芯片(Texa Instrument):zstack
芯科(Silicon):ember
还可能是deconz,zigate或者zboss。
- 示例
serial:
port: /dev/ttyUSB0
adapter: zstack
port: tcp://xzg.local:6638
adapter: zstack
port: /dev/ttyUSB0
adapter: ember
详细信息:可查看官网:https://www.zigbee2mqtt.io/guide/configuration/adapter-settings.html#basic-configuration
使用方法
-
点击启动(启动时长大约一分钟),进入日志页面中点击刷新,出现“Zigbee2MQTT started!”则表示启动成功。
-
启动完成后可在信息页中点击"打开 网页界面",或点击“在侧边栏显示”,方便以后从左侧栏快速访问。
自定义转换器
如果 Z2M Addons 官方显示不支持你的设备,别慌,可以自定义转换器,操作如下: 先打开调试模式,能查看到更多调试信息:使用 FileBroswer 打开 homeassistant/zigbee2mqtt/configuration.yaml 文件, 并添加或修改log_level: debug
第一步:打开zigbee2mqtt,点击开发控制台,找到 JS 代码,复制并保存到本地,命名为 [ 设备型号 ].js (此处将 [ 设备型号 ] 替换为你真实的设备信息);
如果这里的js没有生成有效文件或者生成的文件在调试过程中没有很好的效果,需要从官方已经存在的转换器(https://github.com/Koenkk/zigbee-herdsman-converters)查找相关设备类型的代码,多次修改调试验证。
第二步:将 [ 设备型号 ].js 通过 FileBroswer 拖拽上传到目标目录
homeassistant/zigbee2mqtt/external_converters
zigbee2mqtt 2.0.0 之后的版本文件存放位置(如果没有external_converters 这个文件夹,请手动创建 )
简单参考一个js:
const {} = require('zigbee-herdsman-converters/lib/modernExtend');
const fz = require('zigbee-herdsman-converters/converters/fromZigbee');
const exposes = require('zigbee-herdsman-converters/lib/exposes');
const reporting = require('zigbee-herdsman-converters/lib/reporting');
const e = exposes.presets;
const definition = {
zigbeeModel: ['FNB56-ZRC06FB2.0'],
model: 'NZRC106W-M2',
vendor: 'Feibit',
description: 'Security controller',
extend: [],
fromZigbee: [fz.command_arm, fz.battery],
toZigbee: [],
exposes: [e.battery(), e.action(['panic', 'disarm', 'arm_day_zones', 'arm_all_zones'])],
configure: async (device, coordinatorEndpoint) => {
const endpoint = device.getEndpoint(1);
await reporting.bind(endpoint, coordinatorEndpoint, ['genBasic']);
},
onEvent: async (_, data) => {
if (data.type === 'commandArm' && data.cluster === 'ssIasAce') {
await data.endpoint.defaultResponse(0, 0, 1281, data.meta.zclTransactionSequenceNumber);
}
},
};
module.exports = definition;
第三步:点击 “允许添加新设备”,等待设备连接完成就好了,然后就是测试功能。
验证过程:
-
查看 z2m 界面新加入的设备是否已经不显示 不支持了,如果还显示,说明匹配失败或 JS 文件有问题。
-
重启 z2m 加载项,点击 日志,ctrl+F,搜索步骤二中添加的 JS 文件名,出现 Load xxx.js ,并下面没有出现 error 相关字样,表示成功加载且 JS 内容正确。 然后 在日志中查看 MQ 消息,验证设备发送和接收的消息的正确性是否符合预期。如果不满意效果,就需要调整 JS 内容并重启 z2m 加载项,查看日志,重复此过程达到满意即可。
-
如果确定 JS 没问题,但设备还是没有接入成功或者设备按钮效果不符合预期,可能是设备固件需要升级或者固件本身和 z2m 兼容性不好。咨询设备厂商或客服烧录最新固件,再次调试。
接入完成之后,关闭调试,减少日志输出提高 z2m 性能,log_level: debug 改为 log_level: info
参考:
官方接入自定义设备参考
升级到 2.0.0+的说明
https://github.com/Koenkk/zigbee2mqtt/discussions/24198
如果需要贡献给官方,步骤如下:
-
fork 官方转换器仓库,https://github.com/Koenkk/zigbee-herdsman-converters
-
clone 你 fork 的仓库
-
找到你设备对应的文件,比如:src/devices/feibit.ts
-
将你测试通过的 JS 代码按照格式添加到官方文件中,根据官方 README 按照步骤操作,提交到你 fork 的仓库,注意提交的 message 按照如下格式:feat(add): xxxx(新的设备型号),更多请参考官方历史提交日志记录
-
然后提交 PR,等待官方审核,等待审核同时准备好设备照片:512*512 背景透明
-
同样 fork 官方平台仓库:https://github.com/Koenkk/zigbee2mqtt.io
-
clone 你 fork 的仓库
-
在位置public/images/devices添加你的设备图片,提交到你 fork 仓库,提交 PR,等待审核