玩转LiteOS组件:玩转Librws
Posted 华为云开发者社区
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了玩转LiteOS组件:玩转Librws相关的知识,希望对你有一定的参考价值。
本文分享自华为云社区《LiteOS组件尝鲜-玩转Librws》,作者: W922 。
本期小编为大家带来LiteOS开源版本Librws 组件的使用说明,请跟随小编的步伐一起进入探索之旅吧!
基本介绍
Librws是一个跨平台的websocket客户端,使用C语言编写。它有如下特点:
-
无其他依赖关系
-
带有公共方法的单独的公共方法库librws.h
-
线程安全
-
后台线程中的发送/接收逻辑
详情参考:https://github.com/OlehKulykov/librws。
WebSocket是一种在单个TCP连接上进行全双工通信的协议。
详情参考:https://baike.baidu.com/item/WebSocket/1953845?fr=aladdin。
使能Librws Demo
-
在LiteOS源码根目录下根据实际使用的开发板,拷贝tools/build/config/目录下的默认配置文件$platform.config到根目录,并重命名为.config。
注意:根据Librws所需资源,暂时只支持在STM32F769开发板上运行LibrwsDemo。
-
在LiteOS源码根目录下执行make menuconfig命令,按如下菜单路径使能Librws Demo。
Demos --->
Librws Demo --->
[*] Enable Librws Demo
注意:使能Librws Demo后会自动使能Librws组件和LWIP。
-
保存退出后,会从github上自动下载Librws源代码,并从gitee上下载适配于LiteOS系统的patch包,并打入patch。详细流程在components/download.sh文件中。
注意: 下载需要Linux主机可以访问互联网,并安装git。
编译运行Librws Demo
服务端配置
服务端代码路径为LiteOS/demos/librws/websocketserver.py,需要python3环境可运行。启动服务端步骤如下(命令行操作):
-
修改服务端代码中的变量的ip为服务器ip地址。
# creat websockets server, please change ip as your ip address.
ip = ''
startServer = websockets.serve(MainLogic, ip, 8000)
-
通过python pip命令安装websocket包。
pip install websockets
-
运行websocketserver.py脚本。
python websocketserver.py
客户端配置
Librws Demo需要网络连接,在STM32F769开发板插入网线,并确保网络连接。客户端操作步骤如下:
-
修改LiteOS/demos/librws/librws_demo.c中的WEBSOCKET_DEMO_SERVER为服务端IP或域名。
#define TEXT_BUFF_LEN 1024
#define BIN_BUFF_LEN 1024
#define WEBSOCKET_DEMO_SERVER "your.ip.address"
#define WEBSOCKET_DEMO_PORT 8000
#define LIBRWS_TASK_PRIORITY 6
#define LIBRWS_TASK_STACK_SIZE 0x1400
注意: 改为域名需要开启LWIP_DHCP(DNS需要DHCP来初始化,在Linux下编译,使能LWIP 会默认开启DHCP)。
-
修改Kernel中默认任务栈大小。在LiteOS源码根目录下执行make menuconfig命令,按如下菜单路径设置,修改为4096。
Kernel --->
Basic Config --->
Task --->
(4096) Task Defalut Stack Size
编译烧录
-
在LiteOS源码根目录下执行make clean; make -j命令编译LiteOS工程,编译成功后会在out/platform/lib路径下生成liblibrws.a和liblibrws_demo.a文件,系统镜像文件为Huawei_LiteOS.bin。
-
烧录操作请参考https://gitee.com/LiteOS/LiteOS/blob/master/doc/LiteOS_Quick_Start.md。
-
启动LiteOS后会先初始化网络,开启DHCP,然后运行Librws Demo,建立websocket连接并向服务端发送数据,服务端接收到数据后会返回数据,运行结果如下:
********Hello Huawei LiteOS********
LiteOS Kernel Version : 5.1.0
build data : Jul 14 2021 17:15:39
**********************************
OsAppInit
cpu 0 entering scheduler
app init!
Hello, welcome to liteos demo!
lwip_init OK!!
dhcp start...
Librws demo start to run.
Huawei LiteOS #
Websocket connected
Websocket receive text:
your submit context: LiteOS Websocket demo data
以上为“Librws”使用说明的全部内容,欢迎大家学习交流。
结语
未来我们还会持续新增更多组件、开发板、架构、特性等。
感谢您的阅读,有任何问题、建议,都可以留言给我们,让我们一起进步:
https://gitee.com/LiteOS/LiteOS/issues。
为了更容易找到“LiteOS”代码仓,建议访问https://gitee.com/LiteOS/LiteOS,关注“ Watch”、点赞“Star”、并“Fork”到自己账号下,如图所示。
以上是关于玩转LiteOS组件:玩转Librws的主要内容,如果未能解决你的问题,请参考以下文章