dbus安装与验证

  1. sudo apt-get install dbus:

  2. 安装d-feet,用于查看 session bus 和 system bus
    sudo apt-get install d-feet

  3. 安装glib2.0, 这步安装的会比较多
    sudo apt-get install libgtk2.0-dev

  4. 安装 dbus-glib
    apt-get install libdbus-glib-1-dev

  5. 整理dbus路径
    5.1 进入/usr/include下,将/usr/include/dbus-1.0/dbus文件夹复制到/usr/include下
    5.2.将/usr/lib/x86_64-linux-gnu/dbus下dbus-arch-deps.h文件复制到/usr/include/dbus下
    5.3.将/usr/include/glib-2.0下所有文件及文件夹复制至/usr/include/下
    5.4.将/usr/lib/x86_64-linux-gnu/glib-2.0/include下glibconfig.h复制到/usr/include/下

这里也整理好了dbus_Include路径,可以将里面的所有文件到拷贝至/usr/include下即可,文件链接-》
在这里插入图片描述

  1. 先运行: dbus-launch 这个如果有问题,加一参数运行: dbus-launch --sh-syntax
    june@june:~/document/method$ dbus-launch
    DBUS_SESSION_BUS_ADDRESS=unix:abstract=/tmp/dbus-ZkvUxSYjDt,guid=2725ec7c229349533242c8a45b34ac2e
    DBUS_SESSION_BUS_PID=2934
    DBUS_SESSION_BUS_WINDOWID=71303169

  2. 导出这个变量
    export DBUS_SESSION_BUS_ADDRESS=unix:abstract=/tmp/dbus-ZkvUxSYjDt,guid=2725ec7c229349533242c8a45b34ac2e

使用dbus服务端和客户端代码进行测试,看看dbus环境是否正常

// 服务端代码

#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <dbus/dbus.h>
#include <unistd.h>

void listen_signal()
{
    DBusMessage * msg;
    DBusMessageIter arg;
    DBusConnection * connection;
    DBusError err;
    int ret;
    char * sigvalue;

     //步骤1:建立与D-Bus后台的连接
    dbus_error_init(&err);
    connection =dbus_bus_get(DBUS_BUS_SESSION, &err);
    if(dbus_error_is_set(&err)){
        fprintf(stderr,"ConnectionError %s\n",err.message);
        dbus_error_free(&err);
    }
    if(connection == NULL)
        return;

   //步骤2:给连接名分配一个可记忆名字test.singal.dest作为Bus name,这个步骤不是必须的,但推荐这样处理
    ret =dbus_bus_request_name(connection,"test.singal.dest",DBUS_NAME_FLAG_REPLACE_EXISTING,&err);
    if(dbus_error_is_set(&err)){
        fprintf(stderr,"Name Error%s\n",err.message);
        dbus_error_free(&err);
    }
    if(ret !=DBUS_REQUEST_NAME_REPLY_PRIMARY_OWNER)
        return;

    //步骤3:通知D-Bus daemon,希望监听来行接口test.signal.Type的信号
    dbus_bus_add_match(connection,"type='signal',interface='test.signal.Type'",&err);
    //实际需要发送东西给daemon来通知希望监听的内容,所以需要flush
    dbus_connection_flush(connection);
    if(dbus_error_is_set(&err)){
        fprintf(stderr,"Match Error%s\n",err.message);
        dbus_error_free(&err);
    }

    //步骤4:在循环中监听,每隔开1秒,就去试图自己的连接中获取这个信号。这里给出的是中连接中获取任何消息的方式,所以获取后去检查一下这个消息是否我们期望的信号,并获取内容。我们也可以通过这个方式来获取method call消息。
    while(1){
        dbus_connection_read_write(connection,0);
        msg =dbus_connection_pop_message (connection);
        if(msg == NULL){
            sleep(1);
            continue;
        }

        if(dbus_message_is_signal(msg,"test.signal.Type","Test")){
            if(!dbus_message_iter_init(msg,&arg))
                fprintf(stderr,"MessageHas no Param");
            else if(dbus_message_iter_get_arg_type(&arg)!= DBUS_TYPE_STRING)
                fprintf(stderr,"Param isnot string");
            else
                dbus_message_iter_get_basic(&arg,&sigvalue);
            printf("Recetive Singal Value : %s\n",sigvalue);
        }
        dbus_message_unref(msg);
    }//End of while

}
int main(void){

    printf("------Start Listen_signal!-------\n");
    listen_signal();
    return 0;
}
// 客户端代码
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <dbus/dbus-glib.h>
#include <dbus/dbus.h>
#include <unistd.h>

int send_a_signal( char * sigvalue)
{
    DBusError err;
    DBusConnection * connection;
    DBusMessage * msg;
    DBusMessageIter arg;
    dbus_uint32_t  serial =0;
    int ret;

    dbus_error_init(&err);

    //步骤1:建立与D-Bus后台的连接
    //
    connection =dbus_bus_get(DBUS_BUS_SESSION ,&err );
    if(dbus_error_is_set(&err)){
        fprintf(stderr,"ConnectionErr : %s\n",err.message);
        dbus_error_free(&err);
    }
    if(connection == NULL)
        return -1;

    //步骤2:给连接名分配一个well-known的名字作为Bus name,这个步骤不是必须的,可以用if 0来注释着一段代码,我们可以用这个名字来检查,是否已经开启了这个应用的另外的进程。
#if 1
    ret =dbus_bus_request_name(connection,"test.singal.source",DBUS_NAME_FLAG_REPLACE_EXISTING,&err);
    if(dbus_error_is_set(&err)){
        fprintf(stderr,"Name Err :%s\n",err.message);
        dbus_error_free(&err);
    }
    if(ret !=DBUS_REQUEST_NAME_REPLY_PRIMARY_OWNER)
        return -1;
#endif

    //步骤3:发送一个信号
    //根据图,我们给出这个信号的路径(即可以指向对象),接口,以及信号名,创建一个Message
    if((msg =dbus_message_new_signal("/test/signal/Object","test.signal.Type","Test"))== NULL){
        fprintf(stderr,"MessageNULL\n");
        return -1;
    }
    //给这个信号(messge)具体的内容
    dbus_message_iter_init_append(msg,&arg);
   if(!dbus_message_iter_append_basic(&arg,DBUS_TYPE_STRING,&sigvalue)){
        fprintf(stderr,"Out OfMemory!\n");
        return -1;
    }

    printf("Signal Send: %s\n",sigvalue);
    //步骤4: 将信号从连接中发送
    if( !dbus_connection_send(connection,msg,&serial)){
        fprintf(stderr,"Out of Memory!\n");
        return -1;
    }
    dbus_connection_flush(connection);
    printf("--------Success Signal Send----------\n");

   //步骤5: 释放相关的分配的内存。
    dbus_message_unref(msg );
    return 0;
}

int main(void)
{
    printf("------Start Send_a_signal!-------\n");
    send_a_signal("hello ");
    return 0;
}
  1. 编译
    gcc service.c -ldbus-1 -I/usr/include/dbus-1 -o service
    gcc client.c -ldbus-1 -I/usr/include/dbus-1 -o client

备注:报错可以输入如下命令
(1) eval dbus-launch --auto-syntax
(2) ./yourapp

  • 0
    点赞
  • 12
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
LocalSocket和DBus都是用于进程间通信的机制,但它们有着不同的优缺点。 1. LocalSocket LocalSocket是一种Linux系统提供的进程间通信机制,它可以在同一台机器上的进程间进行通信。它的优点包括: - 简单易用:LocalSocket的使用非常简单,只需要调用几个API就可以完成进程间通信。 - 高效:LocalSocket使用Unix域套接字实现,不需要经过网络协议栈的处理,因此速度比较快。 - 安全:LocalSocket只能在同一台机器上的进程间进行通信,因此安全性比较高。 但是,LocalSocket也有一些缺点: - 可靠性较差:LocalSocket不提供可靠的传输保证,数据可能会丢失或乱序。 - 功能受限:LocalSocket只能在同一台机器上的进程间进行通信,不能跨机器通信。 2. DBus DBus是一种跨平台的进程间通信机制,它可以在不同机器的进程间进行通信。DBus的优点包括: - 跨平台:DBus可以在不同的操作系统上使用,包括Linux、Windows等。 - 功能丰富:DBus提供了丰富的接口,可以支持异步调用、事件通知等功能。 - 可靠性较高:DBus提供了可靠的传输保证,可以保证数据不会丢失或乱序。 但是,DBus也有一些缺点: - 复杂性高:DBus的使用比较复杂,需要编写大量的代码才能完成进程间通信。 - 性能较低:DBus需要经过网络协议栈的处理,因此速度比较慢。 总的来说,LocalSocket适用于在同一台机器上的进程间通信,使用简单、高效、安全,但功能受限,可靠性较差。DBus适用于在不同机器的进程间通信,功能丰富、可靠性较高,但复杂性高、性能较低。选择哪种进程间通信机制,需要根据实际需求进行权衡。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值