c++千万级别高并发网络编程(四)

本文介绍了在C++中处理千万级别高并发网络编程的方法,包括新增网络报文定义,服务器和客户端的登陆登出状态管理,以及针对网络原因导致的粘包和少包问题的解决策略。详细解析了代码实现,包括服务器整体代码、客户端整体代码以及修正后的代码部分。
摘要由CSDN通过智能技术生成

新增内容

  • 新增包头:描述本次传输数据的大小和作用。
  • 服务器和客户端新增对登陆登出的状态描述

网络报文定义

报文包括两个部分,是网络传输的基本消息单元

  • 包头:描述本次数据包的大小和作用
  • 包体:传输的数据

新增后的代码v1.0

服务器整体代码

#define WIN32_LEAN_AND_MEAN
#define SOCKET int  //VS2015已经定义好的,可以直接用
#include<WinSock2>
#include<windows.h>
#include<iostream>
#include<string.h>
using namespace std::cout;
//新增
enum CMD //里面包含cmd常见的命令
{
   
	CMD_LOGIN;
	CMD_LOGOUT;
	CMD_GETINFO;
};
struct DataHeader
{
   
	int dataLength;//描述数据长度
	int cmd;//描述数据包的作用
};
struct Login
{
   
	char username[32];
	char password[32];
};
struct LoginResult
{
   
	int res; 
};
struct LogoutResult
{
   
	int res; 
};
struct Logout
{
   
	char username[32];
};
struct DataPackage  //以最简单的情形为例,可以依据实际工程需求做自定义定制。
{
   
      int age;
      char name[32];
};
//*************************************
int main()
{
   
  WORD ver = MAKEWORD(2,2);//调用API2代创建2.x版本
  WSADATA dat;
  WSAStartup(ver,&dat);//启动
  //创建套接字
  SOCKET  seradd =socket(AF_INET,SOCK_STREAM,IPPROTO_TCP);
  //bind
  SOCKADDR_IN _sin = {
   };	
  _sin .sin_family = AF_INET;
//sin_port和sin_addr都必须是网络字节序(NBO),一般可视化的数字都是主机字节序。所以需要转换host to net unsigned.数字可改 
  _sin .sin_port = htons(1234);
  _sin.sin_addr_s_un.S_addr = INADDR_ANY;//访问本机任何网络地址都可以,具体也可以改为本机的某个特定地址
  if (SOCKET_ERROR == bind(seradd , (sockaddr *) &_sin , sizeof(_sin)))
  {
   
  	std::cout<<"绑定失败"<<endl;
  }
  //监听
  if (SOCKET_ERROR == listen(seradd,5))
  {
   
  	std::cout<<"绑定失败"<<endl;
  }
  //接受
  sockaddr_in clentAddr = {
   };//不用赋值了,因为是监听到的,不是给定的
  int nAddrLen = sizeof(sockaddr_in);//给定长度
  SOCKET _cSock = INVAID_SOCKET;
  //发送内容需要预先说定
  char msgbuf[] = "XXXXXXX";
  _cSock = accept(seradd,(sockaddr *) &clentAddr,nAddrLen);
  if(_cSock = INVAID_SOCKET)
  {
   
  		std::cout<<"获取失败"<<endl;
  }
  char _recvBuf[128] = {
   };
  while(true)
  {
   
  	//修正,先接受包头
  	DataHeader header = {
   };
  	int nLen = recv(_cSock,(char *) &header,sizeof(DataHeader),0);
  	 if(nLen <= 0)
  	 {
   
  	 		cout<<"客户端已经退出,任务结束"<<endl;
  	
这是一门linux下c++通讯架构实战课程,针对c/c++语言已经掌握的很熟并希望进一步深造以将来用c++在linux下从事网络通讯领域/网络服务器的开发和架构工作。这门课程学习难度颇高但也有着极其优渥的薪水(最少30K月薪,最高可达60-80K月薪),这门课程,会先从nginx源码的分析和讲解开始,逐步开始书写属于自己的高性能服务器框架代码,完善个人代码库,这些,将会是您日后能取得高薪的重要筹码。本课程原计划带着大家逐行写代码,但因为代码实在过于复杂和精细,带着写代码可能会造成每节课至少要4~5小时的超长时间,所以老师会在课前先写好代码,主要的时间花费在逐行讲解这些代码上,这一点望同学们周知。如果你觉得非要老师领着写代码才行的话,老师会觉得你当前可能学习本门课程会比较吃力,请不要购买本课程,以免听不懂课程并给老师差评,差评也会非常影响老师课程的销售并造成其他同学的误解。 这门课程要求您具备下面的技能:(1)对c/c++语言掌握的非常熟练,语言本身已经不是继续学习的障碍,并不要求您一定熟悉网络或者linux;(2)对网络通讯架构领域有兴趣、勇于挑战这个高难度的开发领域并期望用大量的付出换取高薪;在这门课程中,实现了一个完整的项目,其中包括通讯框架和业务逻辑框架,浓缩总结起来包括如下几点:(1)项目本身是一个极完整的多线程高并发的服务器程序;(2)按照包头包体格式正确的接收客户端发送过来的数据包, 完美解决收包时的数据粘包问题;(3)根据收到的包的不同来执行不同的业务处理逻辑;(4)把业务处理产生的结果数据包正确返回给客户端;本项目用到的主要开发技术和特色包括:(1)epoll高并发通讯技术,用到的触发模式是epoll中的水平触发模式【LT】;(2)自己写了一套线程池来处理业务逻辑,调用适当的业务逻辑处理函数处理业务并返回给客户端处理结果;(3)线程之间的同步技术包括互斥量,信号量等等;(4)连接池中连接的延迟回收技术,这是整个项目中的精华技术,极大程度上消除诸多导致服务器程序工作不稳定的因素;(5)专门处理数据发送的一整套数据发送逻辑以及对应的发送线程;(6)其他次要技术,包括信号、日志打印、fork()子进程、守护进程等等;
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值