Z2M v2.0版本更改比较大,对部分设备的支持也存在兼容性问题,建议不要急着升级到最新版本。
v2.0的配置文件存放路径都改变了,要按新方法存放xxxx.js配置文件。根据不同的设备安装方式,自己按以下路径新建文件夹(不行就换其他路径测试),最后将所有的xxxx.js配置文件复制到external_converters文件夹内,重启Z2M即生效。
config/zigbee2mqtt/external_converters 或者
docker/zigbee2mqtt/external_converters 或者
mnt/data/supervisor/homeassistant/zigbee2mqtt/external_converters 或者
config/zigbee2mqtt/data/external_converters
简单理解,就是在你原来的zigbee2mqtt文件夹下新建一个external_converters文件夹;如果不能识别就按data/external_converters新建2个层级文件夹。
现在无需在configuration.yaml中增加设备文件名(原有的要删掉),Z2M会自动从external_converters文件夹里加载所有的外部转换器。
如果你按上面的方法操作了,有些设备还是不被支持,试下删除设备再重新配网;还不行的话,可能就要修改外部转换器配置文件了。
by 顺势而为(已持续数年为购买客户提供zigbee设备的售后技术支持)
=====================================================================
我是在树莓派上安装的hassio,在加载项商店安装的zigbee2mqtt add-on,这种插件安装方式不能通过修改devices.js文件来支持新设备,要通过外部转换器的方式来支持新设备,当时zigbee2mqtt官方文档也没写得很清楚,我也是踩了不少坑才搞定的,现把配置方法分享总结如下:
1、把新设备配对接入z2m网关后,只要 Model 这一栏能识别出设备的型号,就能继续进行下面的修改配置文件,完成设备的识别和接入。有部分设备如果这一栏是空白的,就不能通过修改配置文件接入了;还有部分设备进入配对状态后,完全不能被z2m网关检测到,没有任何反应。后2种情况的设备只能通过刷入大神专门定制的固件才能救活并接入z2m网关了。
2、根据待接入设备的类型,把我上传附件提供的几种常用zigbee设备的配置文件模板简单修改下就行了。除说明的地方外,其他地方不要改动。
Zigbee设备配置文件模板.rar (67.2 KB)
zigbeeModel: ['ZHA-DoorLockSensor'],------------Model栏识别出的设备型号
model: 'ZHA-DLS', ------------设备型号,自己随意
vendor: 'LDS', ------------厂家或品牌,自己随意
description: '门锁传感器', ------------功能描述,自己随意
fromZigbee: [fz.ias_contact_alarm_1],
toZigbee: [],
exposes: [e.contact(), e.battery_low(), e.tamper()],
如果你的设备支持显示电量百分比,就要在exposes: []里加入e.battery(),
至于其他不常用的设备,要写配置文件,就要先到z2m官方支持的设备页面查询和你的设备同类型的设备型号,然后打开devices.js文件并找到这个型号,把配置信息代码复制出来再自己修改即可。
3、把修改好的配置文件复制到以下位置,\192.168.x.x\config\zigbee2mqtt
注意:文件名要英文的,名称自己随意,不重复就行。
4、修改Zigbee2mqtt的配置文件,Supervisor – Zigbee2mqtt – 配置
如上图修改好后,点击保存–重启加载项,重启Zigbee2mqtt后就大功告成了。
从下图可以看到,Manufacturer 这一栏由 Unsupported 变成你修改的制造商品牌,就表示配置成功了。
特别提醒:
如果配置文件里的配置信息代码不正确,会导致z2m系统启动失败,比如有个别设备的配置信息,在devices.js里能正常识别,但在external_converters里因为缺少几行配置信息代码,就导致z2m系统启动失败了,502: Bad Gateway。
如果上述原因导致z2m系统启动失败,又无法修改正确的配置信息,那就只能把xxxx.js文件里新增的配置信息删除,或删除external_converters下新增的 - xxxx.js 字段了,然后重启Zigbee2mqtt即可恢复正常。
可以根据不同类型的设备,创建几个不同的xxxx.js配置文件,以方便设备的管理。需要注意的是,只有一个设备的配置文件和多个设备合一的配置文件的代码格式是有区别的,具体看我上传的附件配置模板,搞错了也会导致z2m系统启动失败。
===============================================================
更新接入方法:
Zigbee2mqtt 升级1.25版本以后,外部转换器的配置方法又变了,之前的配置路径已失效(配置 – 加载项 – Zigbee2mqtt – 配置),有2种新的配置方法如下:
第一种:(推荐此方法,操作最简单)
\192.168.X.X\config\zigbee2mqtt\configuration.yaml
在上面的路径找到configuration.yaml,用记事本打开,把下面的内容复制进去,(注意把xxxx.js改成你自己的文件名称),保存,重启Zigbee2mqtt即生效。
external_converters:
- roome.js
- sensor.js
- switch.js
- yudun.js
(注意:上面的符号格式上传后,网站自动改了,正确的是 - yudun.js)
第二种:
Zigbee2MQTT – 设置 – 外部转换器
点击右下角的 +
在出现的长框内输入xxxx.js文件的全名
点击 Submit提交 重启即生效。
踩坑提醒:之前我在1.24版本里配置好的设备,升级到1.25版本后,按新方法修改配置,重启后,z2m系统启动失败,502: Bad Gateway,百思不得其解,因为已用此方法测试成功接入部分设备了,操作方法是没问题的,最后经过排查终于发现,是我其中一个设备在1.25版本被z2m官方支持了,我在外部转换器加了一个同样型号的设备引起冲突了,把此设备的配置文件删除,问题解决!