我现在用的是eclipes+myeclipes+tomcat+....做jsp网站开发。前两天开会,在会上,我们经理问了我几个问题布置了一些任务,有些事情我很疑惑,说出来与大家分享一下。
1.tomcat5.5作为一个开源软件是否稳定?(我说稳定,有很多公司都在用。他就问我公司在用就一定稳定吗?有什么根据?)
2.在读取数据库信息时,我把结果存到了list中。他问我:list最大会占用多少内存,如果现在我要给你一台服务器,支持至少1000人同时在线,内存需要配多大的。
(不知道。无语...)
3.网站建完后,需要进行网站的压力测试,测试任务也落到了我一个人身上。请教各位大虾,有什么办法能让我一个人测试整个网站。
4.经理还让我把eclipes  myeclipes和tomcat的安装方法形成一个文档,目的是以  后如果有人要做的话,看着文档就可以完成所有安装配置.....。(我个人认为如果一个做java的 连这些最基本的东西都不会,他还编什么程...)。
顺便说一句,我是个今年才毕业开始搞JAVA的菜鸟,我现在的公司也只有我一个搞java的,其他技术人员都是搞C的...遇到问题只能上来问问各位大虾高人。身边没人指点,感觉很痛苦。

解决方案 »

  1.   

    楼主的情况和我差不多,很多东西得自己去摸索!
    对以上四个问题说一下个人的想法:
    1,tomcat5.5稳定性很不错的啦,相比其他容器,它是一个相当不错的选择啦!
    2,将数据查询的结果存在list里时,占用的内存和list里存的数据类型相关吧,还有就是查询到的数据结果有多少!
    3,压力测试暂时还没有弄过^!^
    4,环境的配置的确是很基本的东西,呵呵,而且类似文档网上也是相当多的!
      

  2.   

    压力测试 你可以去下个软件,loadrunner 好象是这个 
    你自己找找,可以模拟多人在线,你自己找找
      

  3.   

    eclipes+myeclipes+tomcat??!1、不能说很稳定,根据经验还是会有崩溃的时候的。还有另一种是,关闭服务的时候有时不能完全关闭。2、这要看你的程序是怎么写的?如果采用分页机制的话,每次只取出极少的纪录,就能支持更多的用户同时在线。3、如果是jsp页面写的话,还是比较容易的。写一个jsp页,模拟你在网站中使用到的所有请求。记录他们的返回时间。看看一秒内平均能处理多少事件。然后假设用户一般隔多长时间之行一次操作,除之。4、然也,不与评论。
      

  4.   

    to   hero_qx() 
    分页机制 是不是SQL分页机制,能不能 给我具体讲下,
    或者给我发个说明也行
      

  5.   

    1.肯定不如一些要钱的稳定,可是也不错了,不过需要根据项目的规模,要求进行优化
    2.不知道,看你的页面和数据量
    3.有很多测试工具,51test.com
    4.还是要做一个的,毕竟别人是做c的
      

  6.   

    1. 分页的前提是记录按id排序, 且不连续, 比如有些记录被删除,
       或者要分页显示查找结果, 这样就有了除分页外的条件$q
    2. 确定分页的方式:
    (1): 用简单的"页首, 上一页, 下一页".
    (2): 用"1,2,3,4,5,6,..........末尾"来指定跳到某页.
    3. 实现分析:
    (1) 如果先查询全部结果, 只显示其中的部分. 这种方式显然不好,
        会累坏server.
    (2) 对于用limit m,n实现分页, 有些不负责, 服务器在实际操作时还是
        按$q条件找出所有结果, 然后只返回m后的n条. server工作仍然很多.
    (3) 优化的办法是知道要显示页的起始$id, 查询
       "where $q and id>=$id order by id desc limit 0,$page_length"
       这样mysql 会先按id的索引找到符合条件的id, 然后再评估$q.
    (4) 那$id怎么来呢?
    (5) 对于显示方式1, 每页多查询一条,最后一个记录的$id就是啦
        "where $q and id>=$id order by id limit 0,$page_length+1"
        if (mysql_num_rows($result) > $page_length) echo "下一页"
       //(记住最后一条记录不要显示!)
       //如果不使用第二种分页方式, 到此结束.
    (5) 对于显示方式2, 后面$page_offset=6页的每页起始id要一次知道.
    "select id from xxxx where $q order by id desc limit 0,$page_length*$page_offset"
    for($i=0;$i*$page_length<$mysql_num_rows($result);$i++){
        $start=mysql_result($result,$i*$page_length,0);
        echo '<a href="xxxxx?pageno='.($i+1)."&id=$start\">";
        if ($id==$start) echo "<b>$i</b>"; //加重显示当前页号
        else echo $i;
        echo "</a>";
    }
    (6)也许有人要问server不是按$q条件把所有这几页都搜一遍了吗?
    和"limit 0,$page_length*$pageno"有什么区别? 直接用$pageno哪有$id这么麻烦?
    答案是可以利用session功能存起来这个结果, 如果$q没有变, 就可以直接调用,
    省得每次换页都折腾数据库.
    加上后续页面判断, 上面的例子就变成:
    //如果$q没有变化
    $page_offset=6;
    session_register($ids);
    if (!$ids){//后序页面不会执行
        "select id from xxxx where $q order by id desc limit 0,$page_length*$page_offset+1";//判断有无后序页面
        for($i=0;$i*$page_length<$mysql_num_rows($result);$i++){
            $ids[]=mysql_result($result,$i*$page_length,0);
        }
    }
    //有乐$ids......
    for ($i=0;$i<$page_offset;$i++){
        echo '<a href="xxxxx?id="$ids[$i].'">';
        if ($d==$ids[$i]) echo "<b>$i</b>"; //加重显示当前页号
        else echo $i;
        echo "</a>";
    }
    //下面这句自由发挥, 可以切换到分页模式1
    if ($ids[$page_offset])
        echo '<a href="xxxx?pageno='.($pageno+1).'&id='.$ids[$page_offset].">....</a>';
    (8) 以上结果稍加改动, 可以session_resiter($pageno), 来记录当前是第几
    大页. 类似快进功能.
    (7) 不知道php4正式版是否支持session中存放数组, 如果不行建议用
    implode/explode来变成字串保存.
    (8) 这种方式的优点应该是速度快, 但缺点是不知道总共符合$q条件的数量.
    对于搜索庞大的数据库应该有用.
    (9) 实现"跳至末尾", 可以在以上sql语句中 order by id, 不要desc. 同理可实现
    前面第N页.
    4 以上代码还都是设想, 希望各位多多指正.
    5 本文中心思想是利用id索引和id的偏移来快速查找后序内容, 节省数据库开销.不知道是否能看懂?
      

  7.   

    当然,上面的是php写的,希望你只看原理,实现就自己做做吧^_^
      

  8.   

    关于第一个问题
    tomcat5.5作为一个开源软件是否稳定?(我说稳定,有很多公司都在用。他就问我公司在用就一定稳定吗?有什么根据?)你可以增大虚礼内存来提高稳定性,不容易当机~~~~~~
      

  9.   

    规规矩矩地回答并没有用。这个问题的本质是你们的经理不懂行,你们公司其它技术人员又是搞C的。从公司成本上讲,他不打算又招一个JAVA程序员,同时他又需要你把你的工作做到能够随时走人(不论你想走,还是他想让你走)也不至于影响工作。一般这样的事情,你较真也行,不较真也行。只要整几个数据,就结了。
    窃以为在这样的事情上耗费精力,比较“弱”。
      

  10.   

    安装文档的事情,无非就是他自己想要的一个安装说明(如果他还对技术有尝试兴趣的话),更大的可能是给其它搞C的程序员看看,让他们没事尝试看看能否转型,他肯定更喜欢一个多面手,何况JAVA本来就是基于C演化来的。这个问题,你不必在心里嘀咕,直接按你所想的反问他就是了,语气适度,让他感觉一下这个问题有多愚蠢。
      

  11.   

    同意楼上的。我也认为你们经理不懂,出这么刁难的问题给你。1. TOMCAT5。5,用的好,肯定是稳定的。 高手用Hibernate+ Tomcat写的程序,完全可以让Oracle+ Weblogic下岗。就算你写的不好,JAVA不存在指针问题,也不会象C那样一个内存忘记释放就当机。
    另外,你们经理是个傻叉吗?100个公司里,90个公司用TOMCAT,你不用?就好象大家都用HIBERNATE,你就要自己写个持久层?2.1000人同时在线,也就指JSP容器有1000个session而已。而根据经验,并发操作也就是是200以下。作为TOMCAT服务器,内存1G足够了。WEBLOGIC我不知道。 
    LIST是一种数据结构,叫它链表也可以,长度是随着内容的增长而增长的。而占用的内存应该是根据类型的大小而定。(具体多少需要测试)。目前的JAVA5中,java.util.*这个包的类,都已经写的在性能和速度上很完善了。而你们经理要把数据类型进行优化,我认为是工夫用错地方了。目前J2EE领域影响性能的,是各个线程的并发,而不是数据类型的使用。线程设计的好,TOMCAT足够了。线程设计的差,这个项目做上2年3年,运行起来早晚都会死一次机,就算给WEBLOGIC 30万给你打个补丁,一样死机。(这个是我听说的真实事件。)3.有专门进行压力测试的软件,我没测试过,你baidu一下,很多的。4.刁你们经理。就这水平,连JAVA都不懂,还来指导你工作?你跟领导反映一下,让你一个人负责这个项目,不要让不懂JAVA的人来管理你。记得啊, 否则以后你会很郁闷的。顺便说一句,JAVA程序员,普遍工资不如C程序员。但是我认为C程序员比不上我们的优势,就是每个不错的JAVA程序员,都具备很强的学习能力。同水平的C程序员只知道一个MVC,而JAVA程序员就会知道AOP,IOC,和其他很多框架。C语言发展这么多年,基本已经成型了。而JAVA呢?96年才出来,到现在不过10年,要走的路还很长!要发展成C的规模,还要很久!所以,我们要多多学习!!!不要把宝押在你公司的老程序员身上,何况他们不是用JAVA的。少加班,多看书,多学习!再遇到这样的SB经理,直接把他给炒了!