项目主要实现的功能:注册,登陆,获取好友列表,一对一聊天,消息群发,离线消息缓存,下线。
需要的工具:libevent,json,mysql,memcached
开发平台:vmware
基本项目思路:
客户端:利用多线程实现,采取输入命令的方式让用户选择服务类型,根据不同的服务类型调用不同的处理函数,完成请求,利用json和自定义的上层协议完成和服务器端的数据的交互。在登陆成功之后启动一个线程用于接受服务器端的消息。
服务器端:利用多线程并行(与并发有区别),结合半同步半异步的网络模型完成线程之间的任务分工,利用socket_pair完成线程之间的数据交互。
主线程负责接收用户的连接并将套接字按照子线程压力分发给子线程监听,子线程利用libevent实现I/O复用监听客户端的套接字,利用MVC模式通过判断客户端的请求类型调用不同的视图处理用户请求。
利用MySQL数据库存储用户相关信息以及离线消息,利用memcached实现数据库和内存之间的高速缓存。
项目基本框图:
在开始项目之前,让我们来单独实现简单的libevent,json,mysql.
libevent的客户端:
#include#include#include#include#includeusing namespace std;
int main()
{
int fd = socket(AF_INET,SOCK_STREAM,0);
if( -1 == fd)
{
cerr<
libevent的服务器:
#include#include#include#include#includeusing namespace std;
void cli_cb(int fd,short event,void *arg)//接受数据
{
struct event_base*lib_base &#61; (struct event_base*)arg;
char buff[100] &#61; {0};
if(0{
cout<
json的客户端&#xff1a;
#include#include#include#include#include#includeusing namespace std;
int main()
{
int fd &#61; socket(AF_INET,SOCK_STREAM,0);
if(-1 &#61;&#61; fd)
{
cerr<&#61; send(fd,val.toStyledString().c_str(),strlen(val.toStyledString().c_str()),0))
{
cerr<
json的服务器&#xff1a;
#include#include#include#include#include#include#include#includeusing namespace std;
int main()
{
int fd &#61; socket(AF_INET,SOCK_STREAM,0);
if(-1 &#61;&#61; fd)
{
cerr<&#61; recv(clifd,buff,99,0))
{
cerr<
mysql:
#include#include#include#includeusing namespace std;
int main()
{
MYSQL *mpcon &#61; mysql_init((MYSQL *)0);
MYSQL_RES *mp_res;
MYSQL_ROW mp_row;
//连接mysql
if(!mysql_real_connect(mpcon,"127.0.0.1","root","123456",NULL,3306,NULL,0))
{
cerr<