socket类型怎么保存在SQL数据里? 60
我想自己做一个简单服务器,数据保存是用SQL数据库,用的是MFC做的。每次有客户连接,下面的这个函数都会返回一个新的套接字描述符s1=::accept(s,(sockad...
我想自己做一个简单服务器,数据保存是用SQL数据库,用的是MFC做的。
每次有客户连接,下面的这个函数都会返回一个新的套接字描述符
s1=::accept (s,(sockaddr *)&addr2,&lenth);
而这个s1,后面是客户端发送和服务器接收都要用到的。
::recv (s1,cs,100,0);
::send(s1,m_ms,m_ms.GetLength() ,0)
如果把s1放在内存里,那么如果有大量客户端连接的话,就太耗内存了。
所以我想这道要怎么把s1这个新的套接字描述符放在数据库里!
希望有大神指点,谢谢了! 展开
每次有客户连接,下面的这个函数都会返回一个新的套接字描述符
s1=::accept (s,(sockaddr *)&addr2,&lenth);
而这个s1,后面是客户端发送和服务器接收都要用到的。
::recv (s1,cs,100,0);
::send(s1,m_ms,m_ms.GetLength() ,0)
如果把s1放在内存里,那么如果有大量客户端连接的话,就太耗内存了。
所以我想这道要怎么把s1这个新的套接字描述符放在数据库里!
希望有大神指点,谢谢了! 展开
2个回答
展开全部
很少见有这么做过的,一般情况下都是存放在内存里,一个List或者一个其他的容器里边,容易调用。实际上存放在什么地方需要你试具体的情况而定。如果客户端并发数3,50类的,没有必要考虑到内存消耗多少,现在的机器内存已经不像以前那么弥足珍贵了。
如果并发数确实特别高,特别消耗内存,就可以考虑采用分布式部署的方式来解决。一个服务端程序不够用,大不了多部署几个程序嘛。
我用JAVA开发SOCKET服务端程序,支持70-100客户端连接,允许每秒1M+的数据包交互,使用了多线程技术,启动的时候也就是把JVM的最大内存设置成了1G,一样跑的嗖嗖的。新增一批客户端连接,我就再启动一个程序。服务器的内存是16G的,可以跑好几个这样的程序。
如果并发数确实特别高,特别消耗内存,就可以考虑采用分布式部署的方式来解决。一个服务端程序不够用,大不了多部署几个程序嘛。
我用JAVA开发SOCKET服务端程序,支持70-100客户端连接,允许每秒1M+的数据包交互,使用了多线程技术,启动的时候也就是把JVM的最大内存设置成了1G,一样跑的嗖嗖的。新增一批客户端连接,我就再启动一个程序。服务器的内存是16G的,可以跑好几个这样的程序。
追问
多开几个服务端程序程序,这些多开的程序用的都是同一个端口吗?
展开全部
可以使它序列化,然后存入数据库。
更多追问追答
追问
MFC里面的序列化好像是写入到一个文件。是吗?
然后再把文件里的内容变成char类型放到数据库?
追答
public static byte[] SerializeObject2Bytes(object pToBeSerialzeObj)
{
IFormatter formatter = new BinaryFormatter();
MemoryStream ms = new MemoryStream();
byte[] returnBytes;
try
{
//先将对象序列化到流中
formatter.Serialize(ms, pToBeSerialzeObj);
//声明字节的数据,用于存放二进制数据
returnBytes = new byte[ms.Length];
//设定从头开始读取数据
ms.Position = 0;
//将流信息存放到二进制数据中
ms.Read(returnBytes, 0, returnBytes.Length);
//返回二进制数据
return returnBytes;
}
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询