1、smart-servlet 简介
smart-servlet 是目前 Gitee、Github 平台上首款,也是 唯一的全栈核心技术自研 的国产开源的 Servlet 容器项目。
产品特色
-
国产血统:核心技术 100% 全栈自研。
-
性能优越:搭载最新版通信微内核 smart-socket。
-
安全可靠:严格遵循协议规范;支持加密传输方式。
-
极致轻量:发行包不足 800KB。
-
简洁易用:支持 War 包、springboot、maven-plugin 等多种运行模式,使用体验 100% 兼容 Tomcat。
版本比较
功能 | 开源版 | 企业版 |
---|---|---|
目标用户 | 个人 | 企业 |
Servlet 基础能力 | ✅ | ✅ |
Websocket 规范 | ❌ | ✅ |
异步规范 | ❌ | ✅ |
JSP | ❌ | ❌ |
2、 版本更新
这个版本主要带来两方面的更新。
第一方面,通过适配 Jakarta TCK 套件,我们已经将 smart-servlet 的单侧用例通过数提升至了 360 个。
很多人可能对 Jakarta TCK 比较陌生,这是一套用于检验容器厂商对于 Java EE 规范实现完整性的测试套件。
虽然整个 Java 生态离不开 Servlet 容器的支撑,但从事这方面开发的人却极其稀少,因此网上几乎没有 Jakarta TCK 的相关资料。
本人也是在一年多前无意中找到这个项目,花了很大精力才将 smart-servlet 与其进行融合。也正是在它的加持下,smart-servlet 在过去一年发展尤为顺利。
另一方面,出于项目发展需要,smart-servlet 选择了一种商业不友好的开源模式。这种“不友好”对于真正的企业用户,其实无关痛痒的。但却会触碰到很多个体开发者敏感的神经。
大家习惯将开源同免费画上等号,但凡某个国产项目试图从开源中获利,便会被被钉在中国开源项目的耻辱柱上。偏偏对其进行审判的这类群体,更多时候并不是开源项目的目标用户,这就显得尤为讽刺。
但从开源作者视角而言,商业不友好的开源模式,只要没有获得实质性的收益,其实是更大的资源消耗。仅仅是维护两套代码,便额外增加了不少工作量,更何况还得承受来自社区的诸多负面言论。之所以还选择这条吃力不讨好的路,无非是博一个微小的可能性。
smart-servlet 前期通过开放不同的功能来区分开源版和企业版,的确有些简单粗暴。本人也一直在思考如何在开放全部功能的前提下,能够让企业愿意给项目提供一些正向回馈。
目前想到的一种方式是:在未获得授权的情况下,favicon 图标固定为 smartboot 组织的 logo;http 响应的 header 中给予一些项目基本信息提示。
而对于获得了正式授权的用户,这类限制将被释放。
这是一次尝试。倘若效果如预期,我们将在后续版本中逐步开放所有企业版功能源码。
期望这一天早日到来~
更新内容
-
优化
ServletContext#getMimeType
规范实现。 -
优化
ServletContext#addListener
规范实现。 -
优化
ServletContext#addServlet
规范实现。 -
优化
RequestDispatcher
规范实现。 -
优化监听器的启动流程
-
web.xml 增加
mime-mapping
、security-role-ref
的解析 -
favicon 图标更新
-
smart-http 升级至
v1.4.2
3、快速上手
我们提供了三种方式启用 smart-servlet,您可根据实际情况选择其中适用的一种。
方式一:maven 插件
这是一种类似:tomcat-maven-plugin
的使用方式,通常应用于 Java Web 工程的本地开发环境。集成该插件只需在 pom.xml 中加入以下代码,便可以在 IDE 中启动 servlet 服务。
<build> <plugins> <plugin> <groupId>org.smartboot.servlet</groupId> <artifactId>smart-servlet-maven-plugin</artifactId> <version>{最新版}</version> <configuration> <port>8080</port> <path>/portal</path> </configuration> </plugin> </plugins></build>
插件的版本建议采用最新版本,另外主要的配置项包括:
-
port:servlet 服务启动的监听端口
-
path:Servlet 容器上下文路径,即 ContextPath,通常以 / 表示。当然也支持自定义,但必须以 / 开头 完成配置后在控制台输入:
mvn package smart-servlet:run
即可。
方式二:smart-servlet-spring-boot-starter
用过 springboot 的 spring-boot-starter-tomcat
或者 spring-boot-starter-undertow
的朋友应该对此不陌生。
smart-servlet-spring-boot-starter
本质上就是 smart-servlet 对 spring-boot-starter-web 的另一种适配。
只需按照以下方式调整 springboot 工程中 pom.xml 文件的配置,便可将 springboot 的默认 Servlet 容器替换成 smart-servlet。
<dependencys> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-web</artifactId> <exclusions> <!-- Exclude the Tomcat dependency --> <exclusion> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-tomcat</artifactId> </exclusion> </exclusions> </dependency> <!-- Use smart-servlet instead --> <dependency> <groupId>org.smartboot.servlet</groupId> <artifactId>smart-servlet-spring-boot-starter</artifactId> <version>{最新版}</version> </dependency></dependencys>
扫描以下二维码限时体验企业版:
方式三:发行包
发行包适用于 War 包的部署方式,也是生产环境中常用的一种形式。
扫描以下二维码限时体验企业版: