🎉 国产开源 Servlet 容器的新机缘

来源: 投稿
2024-05-20 09:49:00

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 中给予一些项目基本信息提示。

而对于获得了正式授权的用户,这类限制将被释放。

这是一次尝试。倘若效果如预期,我们将在后续版本中逐步开放所有企业版功能源码。

期望这一天早日到来~

更新内容

  1. 优化 ServletContext#getMimeType 规范实现。

  2. 优化 ServletContext#addListener 规范实现。

  3. 优化 ServletContext#addServlet 规范实现。

  4. 优化 RequestDispatcher 规范实现。

  5. 优化监听器的启动流程

  6. web.xml 增加 mime-mappingsecurity-role-ref的解析

  7. favicon 图标更新

  8. 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 包的部署方式,也是生产环境中常用的一种形式。

扫描以下二维码限时体验企业版:

展开阅读全文
点击加入讨论🔥(12) 发布并加入讨论🔥
本篇精彩评论
smart-servlet 这类运行在服务器上的中间件只能是 ToB 收费,除非有足够理由放弃 Tomcat、Undertow、Jetty 否则商业价值点逻辑不成立,难以持续。
2024-05-21 16:27
1
举报
看意思是主打一个自主可控,填补空白。
2024-05-21 08:47
1
举报
12 评论
1 收藏
分享
返回顶部
顶部