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

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

18860 手机 | 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小强
没有思考,人生的路会越走越难!

搜索
分类
最新微语
  • 今天同学问我,最近还在写代码吗?我想了想,这个问题怎么回答呢,我好像确实很长时间,虽然写了一些,但是主要内容已经不是写代码了。然后再想想,自己也7年多了,这么多年了,我收获了什么,我的目标到底是什么。眼看就奔三了,人生啊,开启感叹模式。

    2017-03-30 22:52

  • 也许大家都已经注意到了,今年的房价,好多地方都是翻了一番,跟着就是,各地房东开始变相涨租。今年之所以搬走,就是为此,这两天同学也是如此。很多房东只认钱,别谈感情,伤钱。而对于这个城市来说,你怎么定位自己,你真把自己当成她的一份子?你来此为何?将来何去何从?自己掂量清楚。

    2016-12-05 10:03

  • 为什么一直不写了呢?因为当爸爸了,没空了。今年的冬天,有些寒冷,除了这寒冬带来的不适,更有因乐视公司遇到危机,而带来的同事别离。送别同事,看着空旷的工位,心中有些悲凉。临近年关,此时此刻,该怎么做,似乎不再是脑子一热那么简单了。

    2016-11-24 11:28

  • 已经请假,加上国庆,要很长一段时间不在北京了。919加班,搞的现在有点心累,胸闷,身体不适。看来,我要好好休息一下了。这几天有些冷,2016的冬天,一步步来了,各位亲友,记得添衣加粗啊。

    2016-09-23 17:29

  • 现在是真的有秋天的感觉了,晚上也不热了,白天也凉快了。再来点风,那酸爽,就有一种想出去防风的冲动了。不过因为最近广州的事情压着,我也没办法,搞的特别累,以前是天天加班不想有自由,现在是因为有事情了,被限制了自由。加上公司的一些事情,感觉日子特别的无聊。

    2016-08-31 17:39

  • 更多»

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