搞定 Web 容器,就能在 Java 领域风生水起?

如果你是一个热衷于技术的 Java 程序员,今天为你分享一位大佬的学习经历,可以让你在众多 Java 开发人员中脱颖而出。


这位大佬,我介绍一下:


李号双,eBay 技术主管,2009 年毕业后加入惠普,先后负责分布式企业级应用的开发与架构设计,以及容器化上云。


2018 年加入 eBay, 参与 eBay 付款系统 2.0 的设计与研发,负责可靠性和高可用部分,系统采用定制版的 Tomcat 运行大规模微服务实例,并且通读过 Tomcat 源码,具有丰富的线上问题定位和调优经验。


以下是他的分享:


很多「过来人」都会告诫新人,编程没有捷径可走,不花费几年时间经过大量的实践和刻意练习怎么能领悟编程的精髓呢?


我曾经也是一名“刻苦”的新人,直到后面才体会到,其实在 Java 的学习上,同样也逃不开”二八原则“,即掌握 20% 的知识,就能解决 80% 的问题


这一点也是我工作很久之后才悟出来的,这种思维方式让我在之后的 Java 学习路上受益很大。


我先来讲讲自己的经历。


十年前,我在实习做嵌入式系统开发,开发语言是 C 和 C++。出于我个人兴趣爱好,当时我想转 Java,学了一段时间后,发 现 Java 上手还挺快,API 比较齐全,也不需要自己来管理内存,感觉比 C 语言高级。


毕业后我顺利地找到了一个 Java 开发的工作,入职后我的工作主要是实现一些小模块,很多时候通过代码的复制粘贴,再稍微改改就能完成功能,这样的状态大概持续了一年。


博主认为:工作前三年对于咱们技术人成长非常关键,CRUD 不应该是常态。


在这个过程中,我对 Java 语法更加熟悉了,也“背”过一些设计模式,用过一些 Web 框架,但是很少有机会将一些 Java 的高级特性运用到实际项目中,因此对它们的理解也是模糊的


那时候如果让我独立设计一个系统,我会感到非常茫然,不知道从哪里下手;对于 Web 框架,我也只是知道这样用是可以的,但却不知道它背后的原理是什么。


而且,在我脑子里没有一张 Java Web 开发的全景图,举个例子,我不知道浏览器的请求是怎么跟 Spring 中的代码联系起来的。


博主认为:80% 新人都会有的困境,可惜只有 20% 找到了方法,大部分人在工作早期没有高手带路,走了很多弯路。


后来我分析发现,我的知识体系在广度和深度上都有问题。然而 Java 知识体系很庞大,我到底该专注于哪一方面?


接着,我注意到了像 Tomcat 和 Jetty 这样的 Web 容器,觉得它们很神奇,只需要把 Web 应用打成 WAR 包放到它的目录下,启动起来就能通过浏览器来访问了。


那 Web 容器究竟是如何工作的?带着这份好奇心,我决定选择 Tomcat 来深入研究


学习了Tomcat的原理之后,我发现Servlet技术是Web开发的原点,几乎所有的Java Web框架(比如Spring)都是基于Servlet的封装,从Servlet规范的角度来看,Spring应用其实就是一个Servlet,而Tomcat和Jetty这样的Web容器,负责加载和运行Servlet。


你可以通过下面这张图来理解 Tomcat/Jetty 在 Web 开发中的位置:


640?wx_fmt=png


随着学习的深入,我还发现 Tomcat 和 Jetty 中用到不少 Java 高级技术,比如 Java 多线程并发编程、Socket 网络编程以及反射等等。


之前我仅仅只是了解这些技术,为了面试也背过一些题,但是总感觉“知道”和“会用”之间存在一道鸿沟。


通过对 Tomcat 和 Jetty 源码的学习,我学会了在什么样的场景下去用这些技术,这一点至关重要


在理解了 Web 容器以及 JVM 的工作原理后,我开始解决线上的疑难杂症,并且尝试对线上的 Tomcat 进行调优。性能的提升也是实实在在的成果,我也因此得到了同事们的认可


总之,在这个过程中,我逐渐建立起了自己的知识体系,也开始独立设计一个系统,独立解决技术难题,也就是说我渐渐具备了独当一面的能力,而这正是高级程序员或者架构师的特质。


概括一下,独当一面的能力,离不开技术的广度和深度


后来我才发现,这种能力其实是我在深入学习 Tomcat 的过程中才逐渐拥有的,这就是回归到我开头说的观点:掌握 20% 的知识,就能解决 80% 的问题


人的精力是有限的,广度和深度该如何权衡呢?我建议找准一个点先突破深度,而 Tomcat 和 Jetty 就是非常好的选择。


以上就是李号双的 Java 学习之路,希望对大家有所启发。


李号双最近跟极客时间合作推出了《深入拆解 Tomcat & Jetty》这门课程,把他当年学习 Java 的这种思维方式沉淀成一套可复制的实战方法。市面上 Tomcat 的靠谱资料太少了,终于等来极客时间上了这门课。


博主认为:Tomcat 的确是非常经典的开源系统,并且运用了方方面面的 Java 技术,如果能从中领略到这些大牛设计者是如何思考问题的,站在巨人的肩膀上,你能走的更快更好。

640?wx_fmt=png

还是老规矩,通过我的二维码,扫码购买后加我微信,xmtxtt,返现24元


这个专栏的设计路线共分为四个阶段(很吸引我):


第一阶段:重学 Tomcat 和 Jetty 的必备基础


首先要学习一些基础知识,比如操作系统、计算机网络、Java 语言,面向对象设计、HTTP 协议以及 Servlet 规范等,帮你重新理解 HTTP 协议和Servlet 规范。


第二阶段:深刻掌握 Tomcat 和 Jetty 的整体架构


从 Tomcat 的 Jetty 的总体架构全貌逐步深入到各个组件,在这个过程中,重点关注组件的工作原理和设计思路,比如这个组件为什么设计成这样,设计者们当时是怎么考虑这个问题的。


然后通过源码的剖析,加深你的理解。更重要的是,帮你学会在真实的场景下如何运用 Java 技术


第三阶段:深入讲解连接器、容器和通用组件的详细设计和工作原理


连接器:

→ Tomcat 如何实现非阻塞和异步 I/O 通信、如何扩展 Java 原生线程池、如何支持 WebSocket;

→ 详解 Jetty 的线程策略 EatWhatYouKill;

→ 总结 Tomcat 和 Jetty 的对象池技术以及高并发高性能之道。

容器:

→ 讨论 Tomcat 的热加载热部署、类加载机制、Web 应用的隔离以及如何实现 Servlet 规范、如何实现异步 Servlet;

→ 探讨 Jetty 如何实现带有上下文信息的责任链;

→ 通过 Jetty 与 Tomcat 的对比,比较它们各自的设计特点,让你对选型有更深的理解。并且通过思考和总结,帮你从中提炼一些通用的设计原则,以及实现高性能高并发的思路。

通用组件:

→ 包括日志组件、Session 管理组件和集群通信组件。


第四阶段:从实战出发,解决工作中最常见的性能问题


在深入了解 Tomcat 和 Jetty 的工作原理之后,接着会从实战出发,带你看看如何监控 Tomcat 的性能,以及怎么从内存、线程池和 I/O 三个方面进行调优。


同时我还会分析和解决一些你在实际工作中可能会碰到的棘手问题,让你的 Web 程序飞起来


在这个过程中,还会解读 Servlet 最新技术及实际应用,比如 WebSocket 和异步 Servlet 等,会重点分析这些新技术是从何而来,以及 Tomcat/Jetty 是如何支持的。这些都是 Web 技术的最新动向,你可以在自己的工作中根据需要选用这些新技术


博主认为:弄懂了 Tomcat 和 Jetty,Java Web 开发对你来说就已经毫无“秘密”可言


并且,你能体会到大神们是如何设计 Tomcat 和 Jetty 的,体会他们如何思考问题、如何写代码,教会你在真实的场景下如何运用 Java 技术,这些都能快速增加你的经验值。


如果你正在 Java Web 开发这条路上向着架构师的方向狂奔,相信有了它,你将会走的更快更好!


从我这里订阅有什么优惠?


限时 68元原价 99元,立省 31元!


640?wx_fmt=png

△还是老规矩,通过我的二维码,扫码购买后加我微信,xmtxtt,返现24元


两倍咖啡的价格,

提升你的开发效率两倍以上!

640?wx_fmt=jpeg

深入 Tomcat,提升 Java 开发广度,成为 20% 领先的技术人!

?点击「阅读原文」,免费试看!

爬虫(Web Crawler)是一种自动化程序,用于从互联网上收集信息。其主要功能是访问网页、提取数据并存储,以便后续分析或展示。爬虫通常由搜索引擎、数据挖掘工具、监测系统等应用于网络数据抓取的场景。 爬虫的工作流程包括以下几个关键步骤: URL收集: 爬虫从一个或多个初始URL开始,递归或迭代地发现新的URL,构建一个URL队列。这些URL可以通过链接分析、站点地图、搜索引擎等方式获取。 请求网页: 爬虫使用HTTP或其他协议向目标URL发起请求,获取网页的HTML内容。这通常通过HTTP请求库实现,如Python中的Requests库。 解析内容: 爬虫对获取的HTML进行解析,提取有用的信息。常用的解析工具有正则表达式、XPath、Beautiful Soup等。这些工具帮助爬虫定位和提取目标数据,如文本、图片、链接等。 数据存储: 爬虫将提取的数据存储到数据库、文件或其他存储介质中,以备后续分析或展示。常用的存储形式包括关系型数据库、NoSQL数据库、JSON文件等。 遵守规则: 为避免对网站造成过大负担或触发反爬虫机制,爬虫需要遵守网站的robots.txt协议,限制访问频率和深度,并模拟人类访问行为,如设置User-Agent。 反爬虫应对: 由于爬虫的存在,一些网站采取了反爬虫措施,如验证码、IP封锁等。爬虫工程师需要设计相应的策略来应对这些挑战。 爬虫在各个领域都有广泛的应用,包括搜索引擎索引、数据挖掘、价格监测、新闻聚合等。然而,使用爬虫需要遵守法律和伦理规范,尊重网站的使用政策,并确保对被访问网站的服务器负责。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值