免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 6110 | 回复: 8
打印 上一主题 下一主题

[其他] 用java做socket(TCP/IP协议)开发应用执行效率怎么样?这样做的多么? [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2014-11-05 12:20 |只看该作者 |倒序浏览
本帖最后由 wsx1011 于 2014-11-05 12:28 编辑

用java做socket(TCP/IP协议)开发应用执行效率怎么样?这样做的多么?

就是想让用tomcat+jsp+java 做的web服务器通过socket与另一个操作数据库的server通讯,获取查询结果后再传给客户端浏览器,这样执行效率会怎么样?

论坛徽章:
59
2015年亚洲杯之约旦
日期:2015-01-27 21:27:392015年亚洲杯之日本
日期:2015-02-06 22:09:41拜羊年徽章
日期:2015-03-03 16:15:432015年辞旧岁徽章
日期:2015-03-03 16:54:152015年迎新春徽章
日期:2015-03-04 09:50:282015元宵节徽章
日期:2015-03-06 15:50:392015年亚洲杯之阿联酋
日期:2015-03-19 17:39:302015年亚洲杯之中国
日期:2015-03-23 18:52:23巳蛇
日期:2014-12-14 22:44:03双子座
日期:2014-12-10 21:39:16处女座
日期:2014-12-02 08:03:17天蝎座
日期:2014-07-21 19:08:47
2 [报告]
发表于 2014-11-05 12:31 |只看该作者
不知道多不多啊。

要看业务情况。

用java写socket没什么问题。

论坛徽章:
15
射手座
日期:2014-11-29 19:22:4915-16赛季CBA联赛之青岛
日期:2017-11-17 13:20:09黑曼巴
日期:2017-07-13 19:13:4715-16赛季CBA联赛之四川
日期:2017-02-07 21:08:572015年亚冠纪念徽章
日期:2015-11-06 12:31:58每日论坛发贴之星
日期:2015-08-04 06:20:00程序设计版块每日发帖之星
日期:2015-08-04 06:20:00程序设计版块每日发帖之星
日期:2015-07-12 22:20:002015亚冠之浦和红钻
日期:2015-07-08 10:10:132015亚冠之大阪钢巴
日期:2015-06-29 11:21:122015亚冠之广州恒大
日期:2015-05-22 21:55:412015年亚洲杯之伊朗
日期:2015-04-10 16:28:25
3 [报告]
发表于 2014-11-05 15:59 |只看该作者
本帖最后由 yulihua49 于 2014-11-05 16:12 编辑
wsx1011 发表于 2014-11-05 12:20
用java做socket(TCP/IP协议)开发应用执行效率怎么样?这样做的多么?

就是想让用tomcat+jsp+java 做的 ...

好主意。可以采用SDBC交易中间件。 到SDBC群下载。
就是用JAVA版的SDBC客户端,呼叫C的数据库服务端,支持ORACLE,DB2,MYSQL,SYBASE。
与JDBC的区别,更安全,更高效。
除了数据库的基本操作,还可以在服务端定义自己所需的操作。即,可以加入任何业务逻辑插件。

论坛徽章:
0
4 [报告]
发表于 2014-11-05 17:03 |只看该作者
一般这种情况用HTTP比较多,类似soap。 jsp,或者asp,php,python等都可以直接发http get或post的,接口灵活。
如果是纯粹的网络程序,java的socket通信比起c/c++还是稍弱了一些,毕竟,中间要经过java虚拟机。还有,如果做图像处理,视频等对内存要求比较大的时候,JAVA也有麻烦。

论坛徽章:
4
水瓶座
日期:2013-09-06 12:27:30摩羯座
日期:2013-09-28 14:07:46处女座
日期:2013-10-24 14:25:01酉鸡
日期:2014-04-07 11:54:15
5 [报告]
发表于 2014-11-06 14:40 |只看该作者
可以用RPC库或者自己裸写SOCKET搞定,操作数据库这种偏IO,用JAVA没什么问题。

论坛徽章:
0
6 [报告]
发表于 2014-11-06 21:36 |只看该作者
回复 3# yulihua49

有个难题,SQL语句怎么传才能让对方正确识别?比如查询一个表里的name和age字段,对方收到后怎么知道是查询这两个字段?


   

论坛徽章:
15
射手座
日期:2014-11-29 19:22:4915-16赛季CBA联赛之青岛
日期:2017-11-17 13:20:09黑曼巴
日期:2017-07-13 19:13:4715-16赛季CBA联赛之四川
日期:2017-02-07 21:08:572015年亚冠纪念徽章
日期:2015-11-06 12:31:58每日论坛发贴之星
日期:2015-08-04 06:20:00程序设计版块每日发帖之星
日期:2015-08-04 06:20:00程序设计版块每日发帖之星
日期:2015-07-12 22:20:002015亚冠之浦和红钻
日期:2015-07-08 10:10:132015亚冠之大阪钢巴
日期:2015-06-29 11:21:122015亚冠之广州恒大
日期:2015-05-22 21:55:412015年亚洲杯之伊朗
日期:2015-04-10 16:28:25
7 [报告]
发表于 2014-11-06 22:13 |只看该作者
本帖最后由 yulihua49 于 2014-11-06 22:21 编辑
wsx1011 发表于 2014-11-06 21:36
回复 3# yulihua49

有个难题,SQL语句怎么传才能让对方正确识别?比如查询一个表里的name和age字段,对 ...

发完整的SQL语句,返回时结果集序列化,如采用JSON格式,自带列名。
如采用prepare方式,可以分批返回结果集,但是形成了有状态服务。
即:
发prepare 语句,返回游标(cursor) --- 进入状态。
发 Fetch指令,返回一组结果 --- 继续状态
继续发Fetch指令,再返回一组结果 --- 继续状态
。。。。。
发close cursor指令     ---------结束状态。
这个序列只有SDBC交易中间件支持。其他交易中间件如TUXEDO、东方通等不支持。

一般的webservice是不支持状态的。

论坛徽章:
0
8 [报告]
发表于 2014-11-06 22:38 |只看该作者
回复 7# yulihua49

如果对方是用C语言写的服务器呢?

   

论坛徽章:
15
射手座
日期:2014-11-29 19:22:4915-16赛季CBA联赛之青岛
日期:2017-11-17 13:20:09黑曼巴
日期:2017-07-13 19:13:4715-16赛季CBA联赛之四川
日期:2017-02-07 21:08:572015年亚冠纪念徽章
日期:2015-11-06 12:31:58每日论坛发贴之星
日期:2015-08-04 06:20:00程序设计版块每日发帖之星
日期:2015-08-04 06:20:00程序设计版块每日发帖之星
日期:2015-07-12 22:20:002015亚冠之浦和红钻
日期:2015-07-08 10:10:132015亚冠之大阪钢巴
日期:2015-06-29 11:21:122015亚冠之广州恒大
日期:2015-05-22 21:55:412015年亚洲杯之伊朗
日期:2015-04-10 16:28:25
9 [报告]
发表于 2014-11-07 09:53 |只看该作者
本帖最后由 yulihua49 于 2014-11-07 10:08 编辑
wsx1011 发表于 2014-11-06 22:38
回复 7# yulihua49

如果对方是用C语言写的服务器呢?

SDBC就是C的服务器+C的客户端+JAVA的客户端。
其中预置了数据库服务,和文件传送服务,还可以自己添加所需的服务。
当然,SDBC实现的功能,其他方法理论上也可以实现。但是要做许多的工作。

看看JAVA调ORACLE存储过程的代码,有状态服务,返回游标:
  1. public int test_rpc()
  2.         {
  3.                 int i,pos;
  4.                 SdbcClient sqlc=new SdbcClient(mid);
  5.                 BUS bus=new BUS(pattern);
  6.                 PAGE page=new PAGE(pattern);
  7.                 byte[] result;
  8.                 Rowno rowno=new Rowno(pattern);
  9.                 String rpccmd="test_buspage.datapage(' ',1,20,' ',:cursor,:char(100),:cursor,:char(100))";
  10.                 StringBuffer retval=new StringBuffer(100);
  11.                 int nrets[]=new int[1];
  12.                 i=sqlc.RPC(rpccmd, retval, nrets, 2);
  13.                 if(i==0) {
  14. //     retval= "1|2|2||"
  15.                         System.out.println("retval="+retval+",nrets="+nrets[0]);
  16.                         String s[]=retval.toString().split("\\|");
  17. //第一个游标                       
  18.                         int cursor= Integer.parseInt(s[0]);
  19.                         sqlc.Fetch(cursor, retval, 0);
  20.                         System.out.println(retval.toString()+",rows="+sqlc.Rows);
  21. //                        System.out.println("这么大的一堆,让我怎么解析呢?下边演示用SdbcPack类解析:");
  22.                         result=retval.toString().getBytes();
  23.                         pos=0;
  24.                         for(i=0;i<sqlc.Rows;i++) {
  25.                                 pos=SdbcPack.unpack(bus,result , pos);
  26. //比表结构多了一个rowno
  27.                                 pos=SdbcPack.unpack(rowno,result,pos);
  28. //现在可以使用这个bus啦
  29.                                 System.out.println("BUS["+rowno.getRow_no()+"]="+Jorm.objectToJsonString(bus));
  30.                         }
  31.                         sqlc.Close_Cursor(cursor);
  32. //第二个游标
  33.                         cursor= Integer.parseInt(s[2]);
  34.                         sqlc.Fetch(cursor, retval, 0);
  35.                         System.out.println(retval.toString()+",rows="+sqlc.Rows);
  36.                         result=retval.toString().getBytes();
  37.                         pos=0;
  38.                         for(i=0;i<sqlc.Rows;i++) {
  39.                                 pos=SdbcPack.unpack(page, result, pos);
  40.                                 pos=SdbcPack.unpack(rowno,result,pos);
  41. //现在可以使用这个page啦
  42.                                 System.out.println("PAGE["+rowno.getRow_no()+"]="+Jorm.objectToJsonString(page));
  43.                         }
  44.                         sqlc.Close_Cursor(cursor);
  45.                 }
  46.                 return 0;
  47.         }
复制代码
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP