从第一次写GPS的服务端到现在,已经过去了八年时光。一直是用.net修修改改,从自己写的socket服务,到suppersocket,都是勉强在坚持着,没有真正的稳定过。
最近一段时间,服务端又出了两个问题:
1、UDP服务:System.Net.Sockets.SocketException (0x80004005): 当该操作在进行中,由于保持活动的操作检测到一个故障,该连接中断。
2、数据库操作:System.Data.SqlClient.SqlException (0x80131904): 事务(进程 ID 54)与另一个进程被死锁在 锁 资源上,并且已被选作死锁牺牲品。请重新运行该事务。
第一点估计真的是.net socket框架的问题,尝试过网上搜索的解决方案都没有解决,同样的程序在另外一台服务器正常,唯独其中一台隔三差五的就出现这个问题 。以下是服务端部分代码:
1 /// <summary> 2 /// 初始化监听 3 /// </summary> 4 private void InitServer() 5 { 6 server = new Socket(AddressFamily.InterNetwork, SocketType.Dgram, ProtocolType.Udp); 7 uint IOC_IN = 0x80000000; 8 uint IOC_VENDOR = 0x18000000; 9 uint SIO_UDP_CONNRESET = IOC_IN | IOC_VENDOR | 12; 10 server.IOControl((int)SIO_UDP_CONNRESET, new Byte[] { Convert.ToByte(false) }, null);//不知道这句有没有用。 11 string hostName = Dns.GetHostName(); //获取本机名 12 IPHostEntry localhost = Dns.GetHostEntry(hostName); 13 IPAddress[] ips = localhost.AddressList; 14 IPAddress localaddr = null; 15 foreach (IPAddress ip in ips) 16 { 17 if (ip.IsIPv6LinkLocal || ip.IsIPv6Teredo) 18 { 19 continue; 20 } 21 localaddr = ip; 22 } 23 24 state = new State(server); 25 server.Bind(new IPEndPoint(localaddr, _config.Port)); 26 server.BeginReceiveFrom(state.Buffer, 0, state.Buffer.Length, SocketFlags.None, ref state.RemoteEP, new AsyncCallback(ReceiveCallBack), state); 27 }