本文共 2369 字,大约阅读时间需要 7 分钟。
根据文档内容对 أنا|安娜 需要的 Mosquitto 安装和配置进行优化,以下是优化后的内容:
安装 Mosquitto 及相关组件:
sudo apt-get install mosquitto mosquitto-clients mosquitto-dev
生成证书和密钥容_transformer:
# 项目名称设为 TLS_Projectmkdir camkdir servermkdir clientmkdir cert# 生成私钥openssl genrsa -out ca.key 2048openssl genrsa -out server.key 2048openssl genrsa -out client.key 2048# 生成证书请求openssl req -out ca.req -key ca.key -new -config ./ca_cert.confopenssl req -out server.req -key server.key -new -config ./server_cert.confopenssl req -out client.req -key client.key -new -config ./client_cert.conf#签名生成证书openssl x509 -req -in ca.req -out ca.crt -sha512 -days 5000 -signkey ca.keyopenssl x509 -req -in server.req -out server.crt -sha512 -CAcreateserial -days 5000 -CA ca.crt -CAkey ca.keyopenssl x509 -req -in client.req -out client.crt -sha512 -CAcreateserial -days 5000 -CA ca.crt -CAkey ca.key# 转换为 DER 格式openssl x509 -in ca.crt -outform DER -out ca.deropenssl x509 -in server.crt -outform DER -out server.deropenssl x509 -in client.crt -outform DER -out client.der# 清理rm -f *.reqrm -f *.srlmv ca.crt ca.key ca/mv server.crt server.key server/mv client.crt client.key client/mv ca.der server.der client.der cert/
运行脚本:
chmod +x generate-CA.sh./generate-CA.sh
Mosquitto 配置文件(mosquitto.conf)内容:
# 指定密码文件password_file /etc/mosquitto/pwfile.txt# 禁止匿名访问allow_anonymous false# 注意:rhoBlog注:`use_identity_as_username` 已在其他步骤中处理# TLS 端口设置listener 1883cafile /etc/mosquitto/ca/ca.crtcertfile /etc/mosquitto/server/server.crtkeyfile /etc/mosquitto/server/server.key# 双向认证设置require_certificate true# 保持兼容性tls_version tlsv1.2
设置密码:
mosquitto_passwd /etc/mosquitto/pwfile.txt tianning
启动 Mosquitto 服务:
mosquitto -c /etc/mosquitto/mosquitto.conf
本地测试时若端口冲突,请先停止服务:
sudo service mosquitto stop
完成上述步骤后,根据 IP 地址 (如 Ubuntu 上的 IP),在 MQTT FX 中配置相同 IP 和端口 1883。
如果在使用过程中遇到权限问题,可以执行以下命令赋予读写执行权限:
chmod -R 777 /etc/mosquitto/ *
将生成的证书文件复制到您的 Windows 系统,并安装 MQTT FX 工作station。完成后,在 FX 中依次进行以下步骤:
hello,设置正确的 topics 参数。通过命令发布测试消息(从本地运行 Mosquitto):
mosquitto_pub -t "hello" -m "hello" -u tianning -P tianning --cafile /etc/mosquitto/ca/ca.crt --key /etc/mosquitto/client/client.key --cert /etc/mosquitto/client/client.crt -p 1883 --insecure
在 FX 中可以看到消息收到,确认配置正确无误。
注:以上操作基于 dorsifery 创建的示例,实际环境中请根据需求调整配置参数,并确保所有文件权限和路径正确。
转载地址:http://xulhz.baihongyu.com/