日期:2014-05-18  浏览次数:20822 次

一个捆扰了小弟很久的问题了,今天终于想说出来,网站的维护问题!!!
现在小弟用jsp做了一个电子商务(卖花的)
    但是偶一直想不通,如果挂到互联网上去,
    很多人访问的话,服务器受得了吗/?
    难道是用多线程吗?   \
每个人访问网站的话就个他一个线程
    希望大家能帮我解决这个疑惑!!

------解决方案--------------------
程序开发是一方面,系统架构设计(硬件+网络+软件)是另一方面。
中国的网络分南北电信和网通,访问的ip就要区分南北进入不同的网络;
然后是集群,包括应用服务器集群和web服务器集群,应用服务器集群可以采用apache+tomcat集群和weblogic集群等,web服务器集群可以用反向代理,也可以用NAT的方式,或者多域名解析都可以;Squid也可以,反正方法很多,可以根据情况选择;
软件架构方面,做网站首先需要很多web服务器存储静态资源,比如图片、视频、静态页等,千万不要把静态资源和应用服务器放在一起;
页面数据调用更要认真设计,一些数据查询可以不通过数据库的方式,实时性要求不高的可以使用lucene来实现,即使有实时性的要求也可以用lucene,lucene+compass还是非常优秀的;
不能用lucene实现的可以用缓存,分布式缓存可以用memcached,如果有钱的话用10来台机器做缓存,> 10G的存储量相信存什么都够了;如果没钱的话可以在页面缓存和数据缓存上下功夫,多用OSCACHE和EHCACHE,SWARMCACHE也可以,不过据说同步性不是很好;
然后很重要的一点就是数据库,大型网站要用oracle,数据方面操作尽量多用存储过程,绝对提升性能;同时要让DBA对数据库进行优化,优化后的数据库与没优化的有天壤之别;同时还可以扩展分布式数据库,以后这方面的研究会越来越多;
新闻类的网站可以用静态页存储,采用定时更新机制减轻服务器负担;首页每个小模块可以使用oscache缓存,这样不用每次都拉数据;
最后是写程序了,一个好的程序员写出来的程序会非常简洁、性能很好,一个初级程序员可能会犯很多低级错误,这也是影响网站性能的原因之一。
------解决方案--------------------
用不上多线程的,那tomcat来说
每一个用户访问的时候tomcat就给开了一个线程的
不过重要的是数据库的设计,在你代码中应该体现用户操作完数据库立即关闭等一些工作。
最好用连接池。

------解决方案--------------------
呵呵,你多虑了。TOMCAT会开多线程的。对于网页来说,浏览器下载到本地之后,线程就已经结束,这个过程是很快的,随便一个网站都能承受。

确实,如果访问量很大的话,服务器的承受能力是个问题。那时个,需要各个方面的升级。只是,如果你的IP达不到1W/天的话,似乎这个问题并不严重。

当然了,如果IP能达到1W/天,你大概每天都能收入1W了,估计你相当长时间内还不用操这个心。
------解决方案--------------------
Apache 似乎是启动时候启动 254 个线程,Tomcat 不清楚。
------解决方案--------------------
TO nlysailor() ( )

如果被攻击呢?
------解决方案--------------------
那不是你要考虑的问题,你只要把他开发出来就好