http://code.google.com/p/protobuf/downloads/list上可以下载Protobuf的源代码。

安装步骤如下所示:

1>tar -xzf protobuf-2.5.0.tar.gz

//进入目录

cd protobuf-2.5.0

//将protobuf的函数库放在此目录文件下

./configure--prefix=/usr/local/protobuf

//下面的make是操作目录下的一个Makefile文件,如果之前用过此命令,又先重新编译过,可在此之前输 make clean

make

make check

make install       //安装protobuf

2> sudo vim /etc/profile

添加路径

export PATH=$PATH:/usr/local/protobuf/bin/

export PKG_CONFIG_PATH=/usr/local/protobuf/lib/pkgconfig/

保存并执行下面语句,让添加的路径生效

source /etc/profile

同时在~/.profile中添加上面两行代码,否则会出现登录用户找不到protoc命令

3>配置动态链接库路径

sudovim /etc/ld.so.conf

插入:

/usr/local/protobuf/lib

4> su ldconfig   //root权限,让上一步的动态链接生效。

5>写消息文件:msg.proto

package Im;

message helloworld

{

required int32     id = 1;  // ID

required string    str = 2;  // str

optional int32     opt = 3;  //optional field

}

将消息文件msg.proto映射成cpp文件

protoc-I=. --cpp_out=. msg.proto

可以看到生成了

msg.pb.h和msg.pb.cc

下面写服务器端,server.cc

#include "msg.pb.h"
#include <iostream>
#include <string>
#include <stdio.h>
#include <errno.h>
#include <stdlib.h> #include <unistd.h>
#include <arpa/inet.h>
#include <sys/types.h>
#include <sys/socket.h> #define EXIT_ERR(m)\
do\
{\
perror(m);\
exit(EXIT_FAILURE);\
}while(0) int main(void)
{
Im::helloworld msg;
int listenfd;
//监听套接字
if((listenfd = socket(PF_INET, SOCK_STREAM, 0)) < 0)
{
EXIT_ERR("socket");
} struct sockaddr_in servaddr;
memset(&servaddr, 0, sizeof(servaddr)); //初始化地址,必须要有
servaddr.sin_family = AF_INET;
servaddr.sin_port = htons(5188);
servaddr.sin_addr.s_addr = inet_addr("127.0.0.1"); //允许套接口和一个正在使用的地址捆绑
int on = 1;
if(setsockopt(listenfd, SOL_SOCKET, SO_REUSEADDR, &on, sizeof(on)) <0)
EXIT_ERR("setsockopt"); //绑定端口和地址
if(bind(listenfd, (struct sockaddr*)&servaddr, sizeof(servaddr)) < 0)
EXIT_ERR("bind"); //建立连接套接字
int conn;
if(listen(listenfd, SOMAXCONN) < 0)
EXIT_ERR("listen"); //对方的地址
struct sockaddr_in peeraddr;
// memset(&peeraddr, 0, sizeof(peeraddr));
socklen_t len = sizeof(peeraddr); //接受连接
if((conn = accept(listenfd, (struct sockaddr*)&peeraddr, &len)) < 0)
EXIT_ERR("accept"); close(listenfd); //接受连接后可以关闭监听套接口 char recvbuf[1025] = {0};
while(1)
{
memset(recvbuf, 0, sizeof(recvbuf));
int ret = recv(conn, recvbuf, 1024, 0);
if(ret == 0)
{
std::cout<<"client close"<<std::endl;
break;
}
std::string data = recvbuf;
msg.ParseFromString(data);
std::cout<<msg.id()<<std::endl;
std::cout<<msg.str()<<std::endl;
} close(conn);
return 0;
}

客户端,client.cc

#include "msg.pb.h"
#include <iostream>
#include <string> #include <stdio.h>
#include <errno.h>
#include <stdlib.h> #include <arpa/inet.h>
#include <unistd.h>
#include <sys/types.h>
#include <sys/socket.h> #define EXIT_ERR(m)\
do\
{\
perror(m);\
exit(EXIT_FAILURE);\
}while(0) int main(void)
{
Im::helloworld msg;
int listenfd;
if((listenfd = socket(PF_INET, SOCK_STREAM, 0)) < 0)
EXIT_ERR("socket"); //要连接的对方的地址
struct sockaddr_in servaddr;
servaddr.sin_family = AF_INET;
servaddr.sin_port = htons(5188);
servaddr.sin_addr.s_addr = inet_addr("127.0.0.1"); //连接
if(connect(listenfd, (struct sockaddr*)&servaddr, sizeof(servaddr)) < 0)
EXIT_ERR("connect"); char sendbuf[1024] = {0};
int num;
std::string str;
std::string data;
while(1)
{
memset(sendbuf, 0, sizeof(sendbuf));
std::cout<<"input number: ";
std::cin>>num;
std::cout<<"input string: ";
std::cin>>str;
fflush(stdout);
msg.set_id(num);
msg.set_str(str);
msg.SerializeToString(&data);
strcpy(sendbuf, data.c_str());
if(send(listenfd, sendbuf, strlen(sendbuf), 0) <= 0)
{
EXIT_ERR("send");
break;
}
} close(listenfd);
return 0;
}
57,1-8 81%
1,1 顶端

分别编译两个文件

g++ msg.pb.cc server.cc -o server `pkg-config --cflags --libs protobuf` -lpthread

g++ msg.pb.cc client.cc -o client `pkg-config --cflags --libs protobuf` -lpthread

执行即可。

饮水思源:

http://download.csdn.net/detail/fairy_tale__________/4692551

Linux下安装protobuf并实现简单的客户端服务器端通信的更多相关文章

  1. 学会四招让你在linux下安装程序变得简单

    一.背景 由于最近想自己摸索一些linux下的东西,开始玩起了Linux系统,在安装软件的过程中有诸多的不解和困惑,现在终于搞明白了具体是怎么样的安装步骤和过程,先分享给你们同时也方便自己复习查阅. ...

  2. linux下安装protobuf及cmake编译

    一.protobuf 安装 protobuf版本:2.6.1 下载地址:https://github.com/google/protobuf/archive/v2.6.1.zip 解压之后进入目录 修 ...

  3. linux下安装oracle11g 64位最简客户端(转)

    安装环境 Linux服务器:SuSe11 sp1 64位           Oracle客户端:Oracle11gR2 64位(最简客户端) 部署流程 1.准备工作,首先在oracle官网下载最新的 ...

  4. linux下安装protobuf教程+示例(详细)

    (.pb.h:9:42: fatal error: google/protobuf/stubs/common.h: No such file or directory 看这个就应该知道是没有找到头文件 ...

  5. Intellij idea史上最简单的教程之Linux下安装与破解Intellij idea2017

    一.前言 这一节我们介绍在Linux下如何安装与破解Intellij idea2017.现在有很多公司开发环境都是Linux,所以掌握在Linux环境下使用Idea办公也是咱们必须得掌握的技能. 记住 ...

  6. Linux下安装cmake

    cmake是一个跨平台的编译工具,特点是语句简单,编译高效,相对于原有的automake更为高效,接下来说明在Linux下安装cmake工具的过程 首先去cmake官网下载cmake安装包,下载界面网 ...

  7. Linux下安装Apache并以mod_wsgi方式部署django站点

    源码编译方式安装Apache 首先下载Apache源码压缩包,地址为http://mirror.bit.edu.cn/apache/httpd/ 继续下载apr和apr-util压缩包,地址为http ...

  8. linux下安装python

    在Linux下安装Python的操作相当简单,按如下步骤操作即可: 命令: wget https://www.python.org/ftp/python/3.5.2/Python-3.5.2.tgzt ...

  9. linux下安装使用libuuid(uuid-generate)

    linux下安装使用libuuid(uuid-generate) linux下安装使用libuuid(uuid-generate) UUID简介 安装libuuid库 编写一个程序试一下 代码 编译运 ...

随机推荐

  1. 未能加载文件或程序集“XXXXXX”或它的某一个依赖项。试图加载格式不正确的程序。

    在本机WIN7机器上的WebService部署到Win2008R2上发现错误 “/”应用程序中的服务器错误. 未能加载文件或程序集“XXXXXX”或它的某一个依赖项.试图加载格式不正确的程序. 说明: ...

  2. 如何使用USB安装XenServer 6.x

    在XenServer 5.6以前我们能够很容易的通过一些工具,直接制作USB安装介质,然后快速安装XenServer,但是我们发现,到XenServer6.0以后,通过工具直接制作的XenServer ...

  3. AJAX overrideMimeType作用

    我们经常在AJAX代码中发现如下代码:   if (http_request.overrideMimeType) {    http_request.overrideMimeType("te ...

  4. 线上redis服务内存异常分析。

    项目中,新增了一个统计功能,用来统计不同手机型号的每天访问pv,看了下redis2.6有个setbit的功能,于是打算尝尝鲜把 redis从2.4更新到了2.6 因为是租了vps.服务器的内存只有4g ...

  5. ios 内存管理 心得

    - alloc, copy, retain会把引用计数+1 - release会把引用计数-1 - 局部变量如果初始化时不是autorelease的,要及时调用release释放,并且赋值为nil否则 ...

  6. 让jquery.tmpl.js支持index序号

    在写Web程序时,想简单处理会使用JS模板,常用的是Jquery的jquery.tmpl.js插件.整个插件还是比较好用的,后续有机会结合实际应用案例,分享下应用方法. 本次文章想分享的一点是其中的一 ...

  7. linux 为开机菜单加密码·

    首先是在/boot/grub/menu.lst 里面添加密码的,但是需要是加密过后的,否则人家直接跑到你的menu.lst里面查看密码不就行了.... 于是,可以使用grub提供的md5加密功能: # ...

  8. 指定URL,计算文件大小

    将http://www.baidu.com替换成指定的URL,就可以获得文件的大小. 文件大小已经转换为以KB为单位. url对象用openconnection()打开连接:获得URLConnecti ...

  9. storm流式大数据处理流行吗

    在如今这个信息高速增长的今天,信息实时计算处理能力已经是一项专业技能了,正是因为有了这些需求的存在才使得分布式,同时具备高容错的实时计算系统Storm才变得如此受欢迎,为什么这么说呢?下面看看新霸哥的 ...

  10. Google软件测试

    google测试相关的职位有三类:软件测试开发工程师.测试工程师以及测试工程经理. 软件测试开发工程师也是一个开发角色,只是工作重心在可测试性和通用测试框架上.他们参与设计评审,非常近距离地观察代码质 ...