Linux下实现RPC编程

jackxiang 2011-1-16 00:07 | |
Linux 下面使用RPC需要使用到命令rpcgen.
在Linux下开发RPC程序流程如下:
1.写一个rpc程序
    如test.x
2.使用rpcgen生成必须的文件,通常是客户端和服务器端以及头文件
    $rpcgen test.x
3.使用rpcgen生成服务器端和客户端的C语言代码
    $rpcgen -Ss -o test_server.c test.x
    $rpcgen -Sc -o test_client.c test.x
4.生成Makefile
    $rpcgen -Sm test.x>Makefile
5.编辑源文件,加入你想要的服务等
6.编辑Makefile,这很重要!
7.执行测试

问题:
1.服务器无法启动,错误如下:
Cannot register service: RPC: Unable to receive; errno = Connection refused
unable to register (TESTPROG, VERSION, udp).
安装完rstatd后,为什么启动不了RPC?

提示:Cannot register service: RPC: Unable to receive; errno = Connection refused

这是因为你的服务器没有开启端口映射的功能。今天把这个问题的解决方法写下来,希望对有类似问题的朋友有所帮助。

[root@codebreaker]#setup

   这时会弹出一个类似图形化的界面,光标移动到System services,回车。在新界面中找到portmap项,空格选中。然后选择OK,再选择quit。

[root@codebreaker]#/etc/rc.d/init.d/portmap start   //启动portmap

现在再试下rpc.rstatd?

====================================


解决方法:系统没有安装portmap或者没有启动portmap端口映射。
$ls /etc/init.d/    
如果没有portmap则安装之
    $sudo apt-get install portmap
如果有了,则启动
    $sudo /etc/init.d/portmap start
还可以使用chkconfig设置系统开机启动的服务项,如将portmap加入开机启动:
    $sudo chkconfig --level 2 -s portmap on

下面是开发一个rpc程序的具体流程,详见
http://zhoulifa.bokee.com/6128714.html
我在编程中遇到以下几个问题:
1.MySQL数据库错误
    1)报告连接不上MySQL,代码如下
if(mysql_real_connect(conn,"127.0.0.1","root","password",
    "database",0,NULL,0)){
    fprintf(stderr,"%s\n%s\n",mysql_error(conn),
        "数据库连接失败");
    exit(1);
}
原因如下:判断语句错误,应该为if(mysql_real_connect(conn,...)==NULL){
    ...
}
2.更新数据失败
    char *sql="update test_table set balance=1000 where id=1000";
    result=mysql_query(conn,sql);
    if(result==NULL){
        .....
        /*错误*/
    }
原因如下:还是判断语句错误,由于更新操作不向查询select操作,如果成功也是返回NULL,所以这里不需要判断result==NULL,其实这时数据库中的结果已经被更新了。
3.RPC源文件test.x书写不当,但是我的程序已经基本实现了,这是怎么办?
    第一次声明test.x时就把函数完全声明正确有一点困难,所以出错在所难免,修改程序也很方便,首先,函数定义和声明(举例客户端)在 test_clnt.c,bank.h以及test_client.c(假设这个是你自己实现的客户端),只要修改这三个文件即可。

来源:http://blog.csdn.net/leisure512/archive/2009/11/11/4799328.aspx

作者:jackxiang@向东博客 专注WEB应用 构架之美 --- 构架之美,在于尽态极妍 | 应用之美,在于药到病除
地址:https://jackxiang.com/post/3957/
版权所有。转载时必须以链接形式注明作者和原始出处及本声明!


最后编辑: jackxiang 编辑于2011-7-29 20:47
评论列表
发表评论

昵称

网址

电邮

打开HTML 打开UBB 打开表情 隐藏 记住我 [登入] [注册]