apache+tomcat +负载平衡,Android高级工程师每日面试题精选

前言

刚从阿里面试回来,想和大家分享一些我的面试经验,以及面试题目。

这篇文章将会更加聚焦在面试前需要看哪些资料,一些面试技巧以及一些这次的面试考题。

1、负载平衡:

每台服务器都是独立的,只是对请求的负载进行平衡,而不对状态(SESSION)进行复制。状态复制(集群):先进行负载平衡,再在各服务器间复制应用状态。

2、apache负载均衡的原理:

mod_jk负载平衡原理:

使用mod_jk默认的以轮循方式进行平衡负载,假设有四个服务器节点,有10个请求,则

第一个节点会得到1,5,9请求;

第二个节点会得到2,6,10请求;

第三个节点会得到3,7请求;

第四个节点会得到4,8请求;

Mod_JK2负载均衡与故障复原:

Apache httpd是当成web服务器,使用mod_jk2将请求传送给Tomcat,就可以使用mod_jk2的负载均衡与容错功能。带有 mod_jk2的Apache(httpd)可以做的事情包括:

A、将请求分配至一或多个Tomcat实例上你可以在mod_jk2的workers.properties文件中,设定许多Tomcat实例,并赋于每个实例一个lb_factor值,以作为请求分配的加权因子

B、侦测Tomcat实例是否失败当Tomcat实例的连接器服务不再响应时,mod_jk2会及时侦测到,并停止将请求送给它。其他的Tomcat 实例则会接受失效实例的负载。

C、侦测Tomcat实例在失效后的何时恢复因连接器服务失效,而停止将请求分配给Tomcat实例之后,mod_jk2会周期性地检查是否已恢复使用性,并自动将其加入现行的Tomcat实例池中。

实践证明,在各应用服务器之间不需要状态复制的情况下,负载平衡可以达到性能的线性增长及更高的并发需求。

集群原理:

集群方式也是使用这种方法进行平衡。Tomcat中的集群原理是通过组播的方式进行节点的查找并使用TCP连接进行会话的复制

集群与负载均衡的优缺点:

不足:

集群不同于负载平衡的是,由于集群服务需要在处理请求之间不断地进行会话复制,复制后的会话将会慢慢变得庞大,因此它的资:

源占用率是非常高的,如果在并发量大的应用中,复制的会话大小会变得相当大,而使用的总内存更是会迅速升高。

优点:

但集群的会话复制,增加了系统的高可用性。由于在每台服务器都保存有用户的Session信息,如果服务器群中某台当机,应用可以自动切换到其它服务器上继续运行,而用户的信息不会丢失,这提高了应用的冗错性

需要文件:

jakarta-tomcat-connectors-1.2.14-src.tar.gz

httpd-2.2.19.tar.bz2

apache-tomcat-7.0.19.tar(windows和linux下的都需要)

我是在win7下进行配置的,安装 Vmware7.1+RedHat6.1。

win7下,安装tomcat7

在RedHat下面安装tomcat7+apache2.2

在RedHat安装jakarta-tomcat-connectors-1.2.14-src.tar.gz

1、修改httpd.cnf

在apache安装目录下conf目录中找到httpd.conf,在文件最后加上下面两句话就可以了

LoadModule jk_module modules/mod_jk.so

include /apache2.2/conf/mod_jk.conf

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-78E2ouqK-1649664065577)(http://hi.csdn.net/attachment/201108/2/0_1312299927J236.gif)]

2、http.conf 同目录下新建mod_jk.conf文件,内容如下(或直接将此内容写到上面的文件中也可)

#加载mod_jk Module

LoadModule jk_module modules/mod_jk-apache-2.0.55.so

#指定 workers.properties文件路径

JkWorkersFile conf/workers.properties

#指定那些请求交给tomcat处理,"controller"为在workers.propertise里指定的负载分配控制器

JkMount /*.jsp controller

也可以根据需要添加,如:

JkMount /servlet/* controller

JkMount /*.do controller

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-eWZibves-1649664065579)(http://hi.csdn.net/attachment/201108/2/0_1312300047c7hZ.gif)]

3、 在http.conf同目录下新建 workers.properties文件,内容如下

worker.list = controller,tomcat1,tomcat2 #server 列表

#tomcat1

worker.tomcat1.port=8009 #ajp13 端口号,在tomcat下server.xml配置,默认8009

worker.tomcat1.host=192.168.124.134 #tomcat的主机地址,如不为本机,请填写ip地址

worker.tomcat1.type=ajp13

worker.tomcat1.lbfactor = 1 #server的加权比重,值越高,分得的请求越多

#tomcat2

worker.tomcat2.port=8009 #ajp13 端口号,在tomcat下server.xml配置,默认8009

worker.tomcat2.host=192.168.137.3 #tomcat的主机地址,如不为本机,请填写ip地址

worker.tomcat2.type=ajp13

worker.tomcat2.lbfactor = 1 #server的加权比重,值越高,分得的请求越多

#controller,负载均衡控制器

worker.controller.type=lb

worker.controller.balanced_workers=tomcat1,tomcat2 #指定分担请求的tomcat

worker.controller.sticky_session=1 #此处指定集群是否需要会话复制,如果设为true,则>表明为会话粘性,不进行会话复制,当某用户的请求第一次分发到哪台,Tomcat后,后继的请求会一>直分发到此Tomcat服务器上处理;如果设为false,则表明需求会话复制。

4、修改tomcat配置文件server.xml

修改TOMCAT_HOME/conf/server.xml文件,为了避免冲突,其中一个tomcat就行了,但是要与 workers.properties文件的ip和端口号保持一致 ;

注意:

如果是同一台电脑上安装两个tomcat那么改一个server.xml文件端口号,避免冲突(3外位置需要修改);但我是在虚拟机里安装的就不需要改了。

—改为—

<Connector port=“8080” protocol=“HTTP/1.1”

connectionTimeout=“20000”

redirectPort=“8443” />

《Android学习笔记总结+最新移动架构视频+大厂安卓面试真题+项目实战源码讲义》开源

Android优秀开源项目:

  • ali1024.coding.net/public/P7/Android/git

总结

作为一名从事Android的开发者,很多人最近都在和我吐槽Android是不是快要凉了?而在我看来这正是市场成熟的表现,所有的市场都是温水煮青蛙,永远会淘汰掉不愿意学习改变,安于现状的那批人,希望所有的人能在大浪淘沙中留下来,因为对于市场的逐渐成熟,平凡并不是我们唯一的答案!

资料.png
资料图.jpg
/public/P7/Android/git**

总结

作为一名从事Android的开发者,很多人最近都在和我吐槽Android是不是快要凉了?而在我看来这正是市场成熟的表现,所有的市场都是温水煮青蛙,永远会淘汰掉不愿意学习改变,安于现状的那批人,希望所有的人能在大浪淘沙中留下来,因为对于市场的逐渐成熟,平凡并不是我们唯一的答案!

[外链图片转存中…(img-np1A2Y2O-1649664065579)]
[外链图片转存中…(img-z8Xjsb45-1649664065580)]

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值