移植lua5.2和luasocket库到嵌入式linux,使能强大的lua脚本和网络功能

简介: 移植lua5.2和luasocket库到嵌入式linux,使能强大的lua脚本和网络功能

在嵌入式linux上,想最简单方便的使用网络资源,如ftp,http,和socket,用c实现容易吗?


如果业务能热更新,每次升级都是补丁升级不用改一行代码都得重新打包,这不香吗?嵌入脚本语言让这些成为可能。


解析json,用c实现容易吗?解析json不如用dkjson.lua这个库。


所以,使用lua脚本强大的网络模块,能给嵌入式linux应用开发带来不少方便。


且lua很容易和c集成到一块儿,实现一些强大功能,比如应用的热更新机制。


还可以用来造一些工具或实现一些功能,总之很强大,能给你的嵌入式应用增强不少功能。


以下记录下移植lua5.2和luasocket网络库到嵌入式linux开发板的过程:


0.准备条件:


下载lua5.2的源码,还有readline-6.3,ncurses5.9的源码,luasocket网络库的源码。


先交叉编译readline-6.3,ncurses5.9,否则后续交叉编译lua时会报找不到readline头文件。


1.readline-6.3的交叉编译:


下载readline-6.3源码,地址在ftp://ftp.gnu.org/gnu/readline/readline-6.3.tar.gz


tar -zxvf readline-6.3.tar.gz


./configure CC=/root/ctools/gcc-linaro-arm-linux-gnueabihf-4.9-2014.09_linux/bin/arm-linux-gnueabihf-gcc --host=arm-linux CROSS_COMPILE=arm-linux-gcc


结果报错了,没能成功生成makefile.


报错信息如下:



checking for wcwidth broken with unicode combining characters... configure: error: in `/root/test/lua/readline/readline-6.3':
configure: error: cannot run test program while cross compiling


解决办法:


改动configure,


将6324行  if test "$cross_compiling" = no; then :中的yes改为no就可以.



成功生成了makefile,接下来就简单了。直接make就行。


好不容易编译完readline,接下来交叉编译lua5.2时,又出现新的错了,



经查才知道,原来编译readline时,少了一个configure的选项。


configure配置时,添加LDFLAGS="-lncurses"就好了。或者把-lncurses加到lua5.2的makefile中的lreadline后面。


这是因为lua编译依赖readline库,readline库依赖ncurses库,但没有指定,就会出现“未定义的符合引用”错误。


2.ncurses库的交叉编译:


ncurses库源码地址:


https://ftp.gnu.org/pub/gnu/ncurses/


https://blog.csdn.net/zadile1/article/details/52025818


这里下载了5.9的版本。


tar xzfv ncurses-5.9.tar.gz


把交叉编译工具目录添加到PATH路径。


我的是:/root/ctools/gcc-linaro-arm-linux-gnueabihf-4.9-2014.09_linux/bin


export PATH=$PATH:/root/ctools/gcc-linaro-arm-linux-gnueabihf-4.9-2014.09_linux/bin


进入解压后的ncurses-5.9目录,执行以下命令:


./configure --prefix=/root/test/lua/ncurses/output/target --host=arm-linux-gnueabihf --with-shared


其中:


–prefix 是指定生成文件的路径


–host 指定的是交叉编译工具链的前缀


–with-shared 生成动态库


接下来,make, make install


最后才到真正的主角出场啦,开始编译lua5.2,这次应该没问题了吧,


3.lua5.2的交叉编译:


改lua5.2里面的makefile,增加上readline和ncurses库的路径,


MYCFLAGS= -I../../readline


MYLDFLAGS= -L../../readline/readline/shlib  -L../../ncurses/output/target/lib




最后,make linux


成功交叉编译lua5.2到嵌入式linux上。


在板子上测试验证:


./lua: error while loading shared libraries: libncurses.so.5: cannot open shared object fil
root@b503_lcd:~#
root@b503_lcd:~# ./lua  -v
Lua 5.2.2  Copyright (C) 1994-2013 Lua.org, PUC-Rio



注意:


需要把 libncurses.so.5库也放进去才行。且,注意,别放成软链接了,真正的是那个libncurses.so.5.9的那个250k左右大小的那个库。否则,就是bus error的错。


4.luasocket库的交叉编译:


首先下载源码,地址在https://github.com/diegonehab/luasocket


修改src目录里的makefile文件,



lua的头文件源码路径,和输出的地方指定下,我的输出的位置在./local,



基本就这些了吧,这个库编译还好,中间没遇到过什么错。


最后生成的库和文件在local文件夹。若在板子上用,需要拷贝到板子的某个路径下固定好位置。


最后在板子上测试下吧,使用那个hello.lua来测试。


--hello.lua
package.path = './local/share/lua/5.2/?.lua;'    --搜索lua模块
package.cpath = './local/lib/lua/5.2/?.so;'       --搜索so模块
local socket = require"socket"
local mime   = require"mime"
print("Hello from " .. socket._VERSION .. " and " .. mime._VERSION .. "!")


看到板子上的输出结果:


相关文章
|
8月前
|
C++
基于Reactor模型的高性能网络库之地址篇
这段代码定义了一个 InetAddress 类,是 C++ 网络编程中用于封装 IPv4 地址和端口的常见做法。该类的主要作用是方便地表示和操作一个网络地址(IP + 端口)
362 58
|
8月前
|
网络协议 算法 Java
基于Reactor模型的高性能网络库之Tcpserver组件-上层调度器
TcpServer 是一个用于管理 TCP 连接的类,包含成员变量如事件循环(EventLoop)、连接池(ConnectionMap)和回调函数等。其主要功能包括监听新连接、设置线程池、启动服务器及处理连接事件。通过 Acceptor 接收新连接,并使用轮询算法将连接分配给子事件循环(subloop)进行读写操作。调用链从 start() 开始,经由线程池启动和 Acceptor 监听,最终由 TcpConnection 管理具体连接的事件处理。
280 2
|
8月前
基于Reactor模型的高性能网络库之Tcpconnection组件
TcpConnection 由 subLoop 管理 connfd,负责处理具体连接。它封装了连接套接字,通过 Channel 监听可读、可写、关闭、错误等
229 1
|
8月前
|
负载均衡 算法 安全
基于Reactor模式的高性能网络库之线程池组件设计篇
EventLoopThreadPool 是 Reactor 模式中实现“一个主线程 + 多个工作线程”的关键组件,用于高效管理多个 EventLoop 并在多核 CPU 上分担高并发 I/O 压力。通过封装 Thread 类和 EventLoopThread,实现线程创建、管理和事件循环的调度,形成线程池结构。每个 EventLoopThread 管理一个子线程与对应的 EventLoop(subloop),主线程(base loop)通过负载均衡算法将任务派发至各 subloop,从而提升系统性能与并发处理能力。
441 3
|
8月前
基于Reactor模式的高性能网络库github地址
https://github.com/zyi30/reactor-net.git
201 0
|
8月前
基于Reactor模型的高性能网络库之Poller(EpollPoller)组件
封装底层 I/O 多路复用机制(如 epoll)的抽象类 Poller,提供统一接口支持多种实现。Poller 是一个抽象基类,定义了 Channel 管理、事件收集等核心功能,并与 EventLoop 绑定。其子类 EPollPoller 实现了基于 epoll 的具体操作,包括事件等待、Channel 更新和删除等。通过工厂方法可创建默认的 Poller 实例,实现多态调用。
397 60
|
8月前
基于Reactor模型的高性能网络库之Channel组件篇
Channel 是事件通道,它绑定某个文件描述符 fd,注册感兴趣的事件(如读/写),并在事件发生时分发给对应的回调函数。
386 60
|
8月前
|
安全 调度
基于Reactor模型的高性能网络库之核心调度器:EventLoop组件
它负责:监听事件(如 I/O 可读写、定时器)、分发事件、执行回调、管理事件源 Channel 等。
413 57
|
8月前
基于Reactor模型的高性能网络库之时间篇
是一个用于表示时间戳(精确到微秒)**的简单封装类
270 57
|
6月前
|
安全 网络性能优化 网络虚拟化
网络交换机分类与功能解析
接入交换机(ASW)连接终端设备,提供高密度端口与基础安全策略;二层交换机(LSW)基于MAC地址转发数据,构成局域网基础;汇聚交换机(DSW)聚合流量并实施VLAN路由、QoS等高级策略;核心交换机(CSW)作为网络骨干,具备高性能、高可靠性的高速转发能力;中间交换机(ISW)可指汇聚层设备或刀片服务器内交换模块。典型流量路径为:终端→ASW→DSW/ISW→CSW,分层架构提升网络扩展性与管理效率。(238字)
1522 0