uci配置管理和ubus通信框架是openwrt系统上非常好的轻量级服务。
以至于,在非openwrt系统上都想用它们来搞事情。
而它们又都是cmake来自动编译的。
这里记录下HOWTO。
sourouce ${你的交叉环境变量}
CC=${CROSS}gcc
CXX=${CROSS}g++
0.先搞定libubox依赖的libjson-c
./autogen.sh # newly configure
install_dir="`pwd`/target_install/"
LIBS=" -ldl "
./configure --build=`sh config.guess` --host=arm-oe-linux-gnueabi --target=arm-oe-linux-gnueabi --prefix="$install_dir"
make clean
make V=s
make install
1. libubox
git clone git://nbd.name/luci2/libubox.git
cmake -DBUILD_LUA=off -DCMAKE_INSTALL_PREFIX=${PWD}/target_install -DCMAKE_SYSTEM_NAME=Linux -DCMAKE_SYSTEM_PROCESSOR=arm
cmake -DCMAKE_C_FLAGS:STRING="$CFLAGS $CPPFLAGS $LDFLAGS $LIBS" --debug-output --trace
# 依赖json-c.so 路径错误,不得其解,没搞清楚 cmake 自动补上的 LDFLAGS 总是包含 /usr/local/lib 路径
# 这里给显式指定 target json-c.so 的绝对路径。
# cmake 传入的所有定义见于CMakeCache.txt
cmake -Djson:FILEPATH="${你的交叉编译库路径}/usr/lib/libjson-c.so"
make V=s
make install
2. uci + libuci.so
git clone git://nbd.name/uci.git
cmake -DBUILD_LUA=off -DCMAKE_INSTALL_PREFIX=${PWD}/target_install -DCMAKE_SYSTEM_NAME=Linux -DCMAKE_SYSTEM_PROCESSOR=arm
cmake -DCMAKE_C_FLAGS:STRING="$CFLAGS $CPPFLAGS $LDFLAGS $LIBS" --debug-output --trace
make V=s
make install
3. ubus + ubusd + libubus.so
git clone git://nbd.name/luci2/ubus.git
cmake -DBUILD_LUA=off -DENABLE_SYSTEMD=off -DCMAKE_INSTALL_PREFIX=${PWD}/target_install -DCMAKE_SYSTEM_NAME=Linux -DCMAKE_SYSTEM_PROCESSOR=arm --debug-output --trace
cmake -DCMAKE_C_FLAGS:STRING="$CFLAGS $CPPFLAGS $LDFLAGS $LIBS" --debug-output --trace
# 同样 指定json-c.so绝对路径
make V=s
make install
注意:
ubus可用于两个进程之间的通信,并以json格式进行数据交互。ubus的常见场景为:
由于ubus实现方式的限制,在一些场景中不适宜使用ubus:
-
ubus用于少量数据的传输,如果数据量很大或是数据交互很频繁,则不宜用ubus,当ubus一次传输数据量超过60KB,就不能正常工作了;
-
ubus对多线程支持的不好,例如在多个线程中去请求同一个服务,就有可能出现不可预知的结果;
-
不建议递归调用ubus,例如进程A去调用进程B的服务,而B的该服务需要调用进程C的服务,之后C将结果返回给B,然后B将结果返回给A。
阅读(4482) | 评论(0) | 转发(0) |