手机端小强原创文章,java小强个人博客站点
当前位置: 首页 >> 手机 >> 移动端与服务器通信,HTTP OR UDP

移动端与服务器通信,HTTP OR UDP

31870 手机 | 2014-11-17

服务器每次宕机都和日志记录有关系,这里的日志记录,是指手机端需要把一些错误日志上传到服务器,而每次发生稍微量大点的上传,就会出现宕机。

我在过滤器增加了每个请求的时间统计(http://www.javacui.com/service/56.html),发现很多请求都要好几分钟才能处理完,除了上传占用宽带以外,我开始怀疑HTTP请求是否适合与当前业务场景。

于是我开始考虑直接使用UDP进行文件上传(http://www.javacui.com/java/207.html),关于UDP的一些其他内容可以参考我的博客。

 

大家知道,使用UDP就是为了应和信号不稳定的场合,之前在做铁路方面系统时,列车上的数据是需要实时下地入库的,可是高速列车行驶中信号是不稳定的,需要就要采用UDP方式发送,且要实时重复发送直到成功。不成功的记录还要记录到本地数据库,有信号时要及时再次发送出去。

虽然现在已经开始普及4G网络,但是不要忽略还有一些低端手机,山寨手机,信号不稳定区段等特殊情况存在,如果此时仍然使用HTTP连接方式,那必然会出现连接突然中断,或长久占用连接的情况。

 

之前记录日志的方式代码如下:

/**
 * 记录日志
 */
@RequestMapping(value="/markLog")
@ResponseBody
public ResponseEntity<String> markLog(
  @RequestParam(value="orderId")String orderId,
  @RequestParam(value="extensionName")String extensionName,
  HttpServletRequest req) throws Exception{
 //1.记录日志
 if(!StringUtil.isNull(orderId) && !StringUtil.isNull(extensionName)){
  StringUtil.saveFile(extensionName, orderId, req);
 }
 return new ResponseEntity<String>(ConstantValueUtil.RETURN_VALUE_OK,HttpStatus.OK);
}

 

流程处理方法如下:

/**
 * 将输入流的内容保存在指定路径中
 */
public static int saveFile(String extensionName, String orderId, HttpServletRequest req) {
 OutputStream bos = null;
 String path = null;
 InputStream stream = null;
 try {
  stream = req.getInputStream();
  String pathname = getLogFileWritePath(extensionName, orderId, req);
  pathname = pathname.replaceAll("\\\\", "/");
  path = pathname.substring(0, pathname.lastIndexOf("/"));
  java.io.File dir = new java.io.File(path);
  if (!dir.isDirectory())
   dir.mkdirs();// 创建不存在的目录
  File file = new File(pathname);
  if (!file.exists()) {
   file.createNewFile();
  }
  // writeln the file to the file specified
  bos = new FileOutputStream(pathname);
  int bytesRead = 0;
  byte[] buffer = new byte[8192];
  while ((bytesRead = stream.read(buffer, 0, 8192)) != -1) {
   bos.write(buffer, 0, bytesRead);
  }
 } catch (FileNotFoundException e) {
  return -1;
 } catch (IOException e) {
  return -2;
 } catch (Exception e) {
  return -3;
 } finally {
  try {
   if(null != bos) bos.flush();
   if(null != bos) bos.close();
   if(null != stream) stream.close();
  } catch (IOException e) {
   logger.error("", e);
  }
 }
 return 0;
}

 

注意以上代码不是我写的,是我拿来给大家参考的。

可以看到,日志文件内容是从InputStream里面读取的,如此以来,一旦发生信号不稳定的情况,这个方法就有很大的风险了。

 

关于UDP的其他内容

UDP DUP超时UPD端口UDP到底有没有状态(http://www.javacui.com/java/198.html

UDP 多线程服务端 和 简单客户端(http://www.javacui.com/java/199.html

一个简单的UDP服务端和客户端示例(http://www.javacui.com/java/200.html

更多内容,网上也有很多示例,欢迎大家提出宝贵意见和建议。

推荐您阅读更多有关于“ HTTP 通信 UDP 移动 手机端 连接 4G ”的文章

上一篇:域名冲突如何注销网站备案 下一篇:每天一篇博文

猜你喜欢

发表评论:

个人资料
blogger

java小强
没有思考,人生的路会越走越难!

搜索
分类
最新微语
  • 每个人的一生都是不同的,我们都需要负重前行。每一种生活都是不同的,我们都需要真实面对。所经历的,让我学会一件事,顺其自然。人,总有很多自己想要的,总有很多困难要面对,总有很多人要去爱,我们不断思考人生,却总是迷失自己。如今,我们最缺的不是金钱和时间,而是忘记了自己的初衷。

    2018-09-28 14:42

  • 车也学了,年也过了,生日也过了,村里的会也赶了,这次,是真的,年过去了。不过我没回京,也没有在家找工作,我在等什么吗?反正现在正合了我这个懒人的要求,不过,我歇不住,思考下人生。

    2018-03-20 00:11

  • 8月1日,我已离开奋斗多年的北京。不知道是暂时的离开,还是永久的离别,反正已经离职在家,告别每日上班,每天苦累的煎熬,过一段属于自己的生活。以前是专职工作,现在专职生活。

    2017-08-18 12:47

  • 又弄完一个项目,累成狗,但是感觉又进步不少,除了很多坑已经踩过,做起来也是轻车熟路。同时也认识到,程序不在于你多牛逼,而是在乎你的细节把控度,而细节的关注,是一个优秀程序员必须要注意的。另外,要相信自己,勇敢向前,没人生下来就是成功的,而且,成功的路,比成功本身更重要。

    2017-06-30 09:46

  • 今日北京再次沙尘暴来袭,吃了几年细粮,终于能来口粗粮了,不过大早上看见这场景,还是吓我一跳,不过随后就平静了,毕竟是老朋友了。进公司又发现一股烤糊的味道,真是祸不单行啊,例外都是污染。发了两个口罩,开启保护模式。

    2017-05-04 10:16

  • 更多»

最新文章
热门文章
随机文章