分类:work
Luckfox开发板开启WIFI热点并设置代理
1. 添加软件包
cd luckfox-pico ./build.sh buildrootconfig
在配置菜单中,找到并启用 squid:
Target packages -> Networking applications -> squid
2. 开启 Wi-Fi 热点
2.1 配置 Hostapd
创建 /etc/hostapd.conf 文件,内容如下:
interface=wlan0 driver=nl80211 ssid=MyHotspot hw_mode=g channel=6 wmm_enabled=0 macaddr_acl=0 auth_algs=1 ignore_broadcast_ssid=0 wpa=2 wpa_passphrase=MyPassword wpa_key_mgmt=WPA-PSK rsn_pairwise=CCMP
interface :指定无线网卡接口(通常是 wlan0)。
ssid :热点名称。
wpa_passphrase :热点密码。
hw_mode :无线模式(g 表示 2.4GHz,a 表示 5GHz)。
channel :信道号(推荐 1、6 或 11)。
2.2 后台启动 Hostapd
hostapd -B /etc/hostapd.conf
3. 配置 DHCP 服务器
3.1 配置 Dnsmasq
创建 /etc/dnsmasq.conf 文件,内容如下:
interface=wlan0 dhcp-range=192.168.43.10,192.168.43.100,12h
interface :指定无线网卡接口。
dhcp-range :定义分配的 IP 地址范围和租约时间。
3.2 启动Dnsmasq 服务
dnsmasq
4. 配置无线网卡
4.1 设置静态 IP 地址
ifconfig wlan0 192.168.43.1 netmask 255.255.255.0 up
解决PySNMP无法使用的问题
1.NameError: name ‘SnmpEngine’ is not defined
pysnmp高版本的api路径有改动,from pysnmp.hlapi import * 无法引入需要的模块。解决方案,使用低版本pysnmp(4.4.12)
pip uninstall pysnmp pip install pysnmp==4.4.12
2.ModuleNotFoundError: No module named ‘pyasn1.compat.octets’
pyasn1版本过高导致的问题。解决方案,使用低版本(0.4.8)
pip uninstall pyasn1 pip install pyasn1==0.4.8
参考资料:
Cannot find getCmd in pysnmp.hlapi
SNMP Library for Python(7.1.15)
pysnmp : AttributeError: ‘module’ object has no attribute ‘NotificationOriginator’
WSL2测试snmp
解决snmp服务无法开机启动问题
新建 /etc/wsl.conf,文件内容如下:
[boot] systemd=true
一些常用的OID
系统描述:1.3.6.1.2.1.1.1.0
系统名称:1.3.6.1.2.1.1.5.0
系统运行时间: 1.3.6.1.2.1.1.3.0
CPU利用率: 1.3.6.1.4.1.2021.11.11.0
内存利用率: 1.3.6.1.4.1.2021.4.5.0
使用snmpget测试
snmpget -v 2c -c public localhost 1.3.6.1.2.1.1.1.0 1.3.6.1.2.1.1.5.0
在Win10上通过WSL2编译LuckFox Pico的Buildroot系统
在 win10 2021 LTSC 上安装配置 wsl2 和 ubuntu
解决python和bc命令无法使用问题
sudo apt install python-is-python3 bc
解决Path中存在空格问题
新建 /etc/wsl.conf,文件内容如下:
[interop] appendWindowsPath=false
NFC卡片相关文章
什么是M1卡?
MifareClassic1K卡简称M1卡,属于非接触式射频卡,而与射频卡进行通讯的技术,叫做近场通讯技术,简称NFC。Mifareclassic1K卡,普通IC卡,0扇区不可修改,其他扇区可以反复擦写,通常使用的门禁卡、电梯卡都是M1卡。
串口通信UART、TTL、RS232,USB相关文章
DirectAdmin笔记
数据库密码
/usr/local/directadmin/conf/mysql.conf
CSF防火墙
如何在 CentOS 8 上安装和配置服务器防火墙 (CSF)?
编辑配置文件 vi /etc/csf/csf.conf 重启CSF防火墙 csf -r
Redis
编辑配置文件 vi /etc/redis.conf 使用配置文件启动 redis redis-server /etc/redis.conf &
MQTT project for Spring Boot
项目地址:https://github.com/isilent-me/MQTT
参考项目:https://github.com/brandonbai/mqtt-spring-boot
订阅
mosquitto_sub -h localhost -t "test/#" -u hanmeimei -P 123456 -i "client1"
发布
mosquitto_pub -h localhost -t "test/abc" -u lilei -P 123456 -i "client3" -m "How are you?"
【转】在Spring Boot中使用MQTT
为什么选择MQTT
MQTT的定义相信很多人都能讲的头头是道,本文章也不讨论什么高大上的东西,旨在用最简单直观的方式让每一位刚接触的同行们可以最快的应用起来
先从使用MQTT需要什么开始分析:
- 消息服务器
- 不同应用/设备之间的频繁交互
- 可能涉及一对多的消息传递
根据上面列举的这三点,我们大概可以了解到, MQTT最适合的场景是消息做为系统的重要组成部分,且参与着系统关键业务逻辑的情形
MQTT, 启动!
既然决定使用它,我们首先要研究的是如何让MQTT正常工作,毕竟它不是简单的在maven里加入个依赖就完事的
我们总共需要干如下两件事:
- 下载EMQX消息服务器, 作为broker
- 在maven中引入依赖
<dependency> <groupId>org.springframework.integration</groupId> <artifactId>spring-integration-mqtt</artifactId> <version>5.3.2.RELEASE</version> </dependency>
完成上面两步后, 启动EMQX服务器, 正式进入我们的MQTT旅途
使用方式
在Spring Boot中使用MQTT的代码, 笔者总结了如下两种方式:
- 使用spring-integration的消息通道概念
- 使用传统的Client客户端概念
第一种会产生一定程度的心智负担,但在笔者成功搭配(抄袭+造轮子)自动注册后, 比后者要方便许多
在介绍具体代码之前, 我们先简单整理下使用中最常见的概念:
- 主题: MQTT消息的主要传播途径, 我们向主题发布消息, 订阅主题, 从主题中读取消息并进行业务逻辑处理, 主题是消息的通道
- 生产者: MQTT消息的发送者, 他们向主题发送消息
- 消费者: MQTT消息的接收者, 他们订阅自己需要的主题, 并从中获取消息
- broker: 消息转发器, 消息是通过它来承载的, EMQX就是我们的broker, 在使用中我们不用关心它的具体实现
其实, MQTT的使用流程就是: 生产者给主题发消息->broker进行消息的传递->订阅该主题的消费者拿到消息并进行相应的业务逻辑