总结
三个工作日收到了offer,头条面试体验还是很棒的,这次的头条面试好像每面技术都问了我算法,然后就是中间件、MySQL、Redis、Kafka、网络等等。
- 第一个是算法
关于算法,我觉得最好的是刷题,作死的刷的,多做多练习,加上自己的理解,还是比较容易拿下的。
而且,我貌似是将《算法刷题LeetCode中文版》、《算法的乐趣》大概都过了一遍,尤其是这本
《算法刷题LeetCode中文版》总共有15个章节:编程技巧、线性表、字符串、栈和队列、树、排序、查找、暴力枚举法、广度优先搜索、深度优先搜索、分治法、贪心法、动态规划、图、细节实现题
《算法的乐趣》共有23个章节:
- 第二个是Redis、MySQL、kafka(给大家看下我都有哪些复习笔记)
基本上都是面试真题解析、笔记和学习大纲图,感觉复习也就需要这些吧(个人意见)
- 第三个是网络(给大家看一本我之前得到的《JAVA核心知识整理》包括30个章节分类,这本283页的JAVA核心知识整理还是很不错的,一次性总结了30个分享的大知识点)
1.2负载均衡
客户端发送多个请求到服务器,服务器处理请求,有一些可能要与数据库进行狡猾,服务器处理完毕之后,再将结果返回给客户端
普通请求和响应过程
图片
但是随着信息数量增长,访问量和数据量飞速增长,普通架构无法满足现在的需求
我们首先想到的是升级服务器配置,可以由于摩尔定律的日益失效,单纯从硬件提升性能已经逐渐不可取了,怎么解决这种需求呢?
我们可以增加服务器的数量,构建集群,将请求分发到各个服务器上,将原来请求集中到单个服务器的情况改为请求分发到多个服务器,也就是我们说的负载均衡
图解负载均衡
假设有15个请求发送到代理服务器,那么由代理服务器根据服务器数量,平均分配,每个服务器处理5个请求,这个过程就叫做负载均衡
1.3动静分离
为了加快网站的解析速度,可以把动态页面和静态页面交给不同的服务器来解析,加快解析的速度,降低由单个服务器的压力
动静分离之前的状态
图片
动静分离之后
图片
2. nginx如何在linux安装
===================
https://blog.csdn.net/yujing1314/article/details/97267369
3. nginx常用命令
=============
查看版本
./nginx -v
启动
./nginx
关闭(有两种方式,推荐使用 ./nginx -s quit)
./nginx -s stop
./nginx -s quit
重新加载nginx配置
./nginx -s reload
4.nginx的配置文件
============
配置文件分三部分组成
全局块
从配置文件开始到events块之间,主要是设置一些影响nginx服务器整体运行的配置指令
并发处理服务的配置,值越大,可以支持的并发处理量越多,但是会受到硬件、软件等设备的制约
图片
events块
影响nginx服务器与用户的网络连接,常用的设置包括是否开启对多workprocess下的网络连接进行序列化,是否允许同时接收多个网络连接等等
支持的最大连接数
图片
http块
诸如反向代理和负载均衡都在此配置
location指令说明
- 该语法用来匹配url,语法如下
location[ = | ~ | ~* | ^~] url{
}
-
=:用于不含正则表达式的url前,要求字符串与url严格匹配,匹配成功就停止向下搜索并处理请求
-
~:用于表示url包含正则表达式,并且区分大小写。
-
~*:用于表示url包含正则表达式,并且不区分大瞎写
-
^~:用于不含正则表达式的url前,要求ngin服务器找到表示url和字符串匹配度最高的location后,立即使用此location处理请求,而不再匹配
-
如果有url包含正则表达式,不需要有~开头标识
4.1 反向代理实战
配置反向代理
目的:在浏览器地址栏输入地址www.123.com跳转linux系统tomcat主页面
具体实现
先配置tomcat:因为比较简单,此处不再赘叙
并在windows访问
图片
具体流程
图片
修改之前
图片
配置
图片
再次访问
图片
反向代理2
1.目标
-
访问http://192.168.25.132:9001/edu/ 直接跳转到192.168.25.132:8080
-
访问http://192.168.25.132:9001/vod/ 直接跳转到192.168.25.132:8081
2.准备
配置两个tomcat,端口分别为8080和8081,都可以访问,端口修改配置文件即可。
图片
新建文件内容分别添加8080!!!和8081!!!
图片
图片
响应如下
图片
3.具体配置
图片
重新加载nginx
./nginx -s reload
访问
图片
图片
实现了同一个端口代理,通过edu和vod路径的切换显示不同的页面
4.2 反向代理小结
第一个例子:
浏览器访问www.123.com,由host文件解析出服务器ip地址
192.168.25.132 www.123.com
然后默认访问80端口,而通过nginx监听80端口代理到本地的8080端口上,从而实现了访问www.123.com,最终转发到tomcat 8080上去
第二个例子:
-
访问http://192.168.25.132:9001/edu/ 直接跳转到192.168.25.132:8080
-
访问http://192.168.25.132:9001/vod/ 直接跳转到192.168.25.132:8081
实际上就是通过nginx监听9001端口,然后通过正则表达式选择转发到8080还是8081的tomcat上去
4.3 负载均衡实战
1.修改nginx.conf
图片
图片
2.重启nginx
./nginx -s reload
3.在8081的tomcat的webapps文件夹下新建edu文件夹和a.html文件,填写内容为8081!!!!
4.在地址栏回车,就会分发到不同的tomcat服务器上
图片
图片
5.负载均衡方式
-
轮询(默认)
-
weight,代表权,权越高优先级越高
图片
- fair,按后端服务器的响应时间来分配请求,相应时间短的优先分配
图片
- ip_hash,每个请求按照访问ip的hash结果分配,这样每一个访客固定的访问一个后端服务器,可以解决session 的问题
图片
4.4 动静分离实战
什么是动静分离
把动态请求和静态请求分开,不是讲动态页面和静态页面物理分离,可以理解为nginx处理静态页面,tomcat处理动态页面
动静分离大致分为两种:
一、纯粹将静态文件独立成单独域名放在独立的服务器上,也是目前主流方案;
Java面试核心知识点笔记
其中囊括了JVM、锁、并发、Java反射、Spring原理、微服务、Zookeeper、数据库、数据结构等大量知识点。
Java中高级面试高频考点整理
最后分享Java进阶学习及面试必备的视频教学
什么是动静分离
把动态请求和静态请求分开,不是讲动态页面和静态页面物理分离,可以理解为nginx处理静态页面,tomcat处理动态页面
动静分离大致分为两种:
一、纯粹将静态文件独立成单独域名放在独立的服务器上,也是目前主流方案;
Java面试核心知识点笔记
其中囊括了JVM、锁、并发、Java反射、Spring原理、微服务、Zookeeper、数据库、数据结构等大量知识点。
[外链图片转存中…(img-bDr9bEab-1715578664644)]
Java中高级面试高频考点整理
[外链图片转存中…(img-ThX6BF4Z-1715578664645)]
[外链图片转存中…(img-kUSwPaAq-1715578664645)]
最后分享Java进阶学习及面试必备的视频教学
[外链图片转存中…(img-Pkgelfty-1715578664645)]