用Rust搭建React Server Components 的Web服务器(一)

简介: 用Rust搭建React Server Components 的Web服务器(一)

凡心所向,素履以往,生如逆旅,一苇以航

大家好,我是柒八九

前言

在前面的文章中,我们介绍过ReactRSCRust

而如果想使用RSC,就需要使用Next.js的最新版本。而今天,我们做一次技术尝试。

Rust搭建适配RSC的Web服务器

我们在致所有渴望学习Rust的人的信中也介绍过,RustWeb开发中也能大放异彩。

image.png

最近,在评论区,有些人说Rust在国内的工作岗位少,其实如果大家细心去找的话,还是有些区块链或者类似的公司都有招聘计划。

image.png

从我个人角度来看的话,Rust其实不是啥屠龙术,更多的是给自己的另外一种机会。

好了,天不早了,干点正事哇。

你能所学到的知识点

  1. 前置知识点
  2. 服务端渲染
  3. Server components
  4. 页面响应交互事件
  5. 新增 <Suspense />特性

前置知识点

前置知识点,只是做一个概念的介绍,不会做深度解释。因为,这些概念在下面文章中会有出现,为了让行文更加的顺畅,所以将本该在文内的概念解释放到前面来。如果大家对这些概念熟悉,可以直接忽略


同时,由于阅读我文章的群体有很多,所以有些知识点可能我视之若珍宝,尔视只如草芥,弃之如敝履。以下知识点,请酌情使用

Tokio.rs

你没看错,这个单词和小日子有关。

Tokio.rs(通常称为Tokio)是一个用于异步编程的Rust编程语言的库和运行时系统。它提供了一个基于futuresasync/await的高性能异步编程框架,使开发者能够编写高效、非阻塞的网络应用程序和系统服务。

  1. 异步编程
  • Tokio.rs的核心特性是异步编程。它利用Rustasync/await语法来编写异步代码,使得编写非阻塞的程序更加直观和容易。
  • 异步编程可以在单个线程上处理大量的并发连接和I/O操作,从而提高了应用程序的性能和资源利用率。
  1. 事件驱动
  • Tokio基于事件驱动的模型,应用程序被构建成响应事件的方式,例如,网络套接字上的数据到达、定时器触发等。
  • 这种模型使得应用程序可以有效地管理多个并发任务,而不必为每个任务分配一个独立的线程,从而减少了资源开销。
  1. 核心组件
  • tokio-core:提供了异步基础设施,包括异步任务的调度和基本的I/O操作。
  • tokio-io:提供了对网络和文件I/O的高级异步支持。
  • tokio-tcptokio-udp:用于构建异步TCP和UDP网络应用程序的库。
  • tokio-timer:用于创建和管理定时器的库。
  • tokio-sync:提供了各种异步的同步原语,如通道(channels)和锁(locks)。
  • tokio-async-await:用于支持Rust的async/await语法的库。
  1. 生态系统
  • Tokio.rs有一个丰富的生态系统,包括许多第三方库和插件,用于构建各种类型的应用程序,从Web服务器到分布式系统。
  • 一些流行的Web框架,如Actixwarp,都建立在Tokio.rs之上。
  1. 性能
  • Tokio.rs被设计成高性能的异步运行时系统,通过有效地管理事件循环和任务调度,使得应用程序能够处理大量并发连接而不会出现性能瓶颈。
  1. 安全性
  • Rust的内存安全性和线程安全性特性也适用于Tokio.rs应用程序,帮助开发者避免了许多常见的并发和内存错误。
  1. 使用场景
  • Tokio.rs广泛用于构建高性能的网络服务器、代理、数据库连接池、消息队列等异步应用程序。
  • 它也适用于需要大规模并发处理的任务,如网络爬虫和实时数据处理。

下图是用简单的命令,构建了一个服务器。

image.png

更详细的介绍,可以参考tokio.rs 官网

Axum.rs

Axum.rs(通常简称为Axum)是一个用于构建异步Rust应用程序的Web框架。它专注于提供简单而强大的工具,使得开发者能够构建高性能、可维护的异步Web服务。

  1. 异步和性能
  • Axum.rs是一个异步的Web框架,它利用Rustasync/await语法来编写非阻塞的Web应用程序
  • 异步编程模型允许应用程序有效地处理大量并发请求,提高性能和资源利用率。
  1. 基于Actix和Hyper
  • Axum.rs构建在ActixHyper之上,这两个项目都是Rust生态系统中非常受欢迎的Web框架和HTTP库。
  • 它继承了Actix的优秀特性,如Actor模型和中间件支持,以及Hyper的高性能HTTP请求处理能力。
  1. 简洁和模块化
  • Axum的设计目标之一是提供清晰、模块化的API,使得开发者能够轻松构建和维护Web应用程序。
  • 它鼓励将应用程序划分为各种小模块,每个模块负责处理特定的请求和响应。
  1. 中间件支持
  • Axum支持中间件,这些中间件可以用于处理请求和响应,例如身份验证、日志记录、跨域资源共享(CORS)等。
  • 这使得开发者可以轻松地扩展和自定义应用程序的行为。
  1. 路由
  • Axum提供了强大的路由功能,可以根据不同的HTTP请求路径和HTTP方法来映射到处理程序(handlers)。
  • 开发者可以定义多个路由,并且可以通过宏来声明路由和处理程序。
  1. Type-Safe
  • Axum.rs是类型安全的,它利用Rust的类型系统来防止常见的编程错误,如空指针和数据竞争。
  1. 生态系统
  • 虽然Axum.rs是相对较新的项目,但它已经开始吸引了一些关注,并且正在建立一个生态系统,包括与数据库连接、模板引擎和其他常见Web开发工具的集成。
  1. 使用场景
  • Axum.rs适用于构建高性能的Web服务,特别是需要处理大量并发请求的应用程序,如实时通信服务、游戏服务器、物联网后端等。

下面是利用axum简单的构建了一个web应用。访问localhost:3000/就会返回Hello Rust

use axum::{
    routing::{get, post},
    Router,
};
use std::net::SocketAddr;
#[tokio::main]
async fn main() {
    // 初始化tracing
    tracing_subscriber::fmt::init();
    // 构建我们的应用程序,包括一个路由
    let app = Router::new()
        .route("/", get(root));
    // 使用hyper运行我们的应用程序,在全局监听端口3000
    let listener = tokio::net::TcpListener::bind("0.0.0.0:3000").await.unwrap();
    axum::serve(listener, app).await.unwrap();
}
// 基本的处理函数,响应一个静态字符串
async fn root() -> &'static str {
    "Hello, Rust!"
}

更详细的内容,可以参考axum官网

rscx 的介绍

image.png

下面的代码是用类似JSX语法构建页面结构的例子。

use rscx::{component, html, props, CollectFragment};
#[tokio::main]
async fn main() {
    let app = app().await;
    println!("{}", app);
}
async fn app() -> String {
    let s = "ul { color: red; }";
    html! {
        <!DOCTYPE html>
        <html>
            <head>
                <style>{s}</style>
            </head>
            <body>
                <Section />
                <Section title="Hello">
                    <Items />
                </Section>
            </body>
        </html>
    }
}
#[component]
fn Section(
    #[builder(default = "Default title".into(), setter(into))] 
    title: String,
    #[builder(default)] 
    children: String,
) -> String {
    html! {
        <div>
            <h1>{ title }</h1>
            { children }
        </div>
    }
}
#[component]
async fn Items() -> String {
    let data = load_data_async().await;
    html! {
        <ul>
            {
                data
                    .into_iter()
                    .map(|item| html! { <li>{ item }</li> })
                    .collect_fragment() // helper method to collect a list of components into a String
            }
        </ul>
    }
}
async fn load_data_async() -> Vec<String> {
    vec!["a".to_string(), "b".to_string(), "c".to_string()]
}

更多内容,可以参考rscx 官网

CURL

curl(全称:Client for URLs)是一个用于传输数据的命令行工具和库,广泛用于各种操作系统中,包括LinuxUnixmacOSWindows。它支持多种协议,包括HTTPHTTPSFTPFTPS等,因此可以用来与各种远程服务器进行数据交互。

  1. 功能特点
  • 数据传输curl可以用于上传和下载文件,发送和接收数据。
  • 多协议支持:支持多种协议,使其适用于各种网络通信需求。
  • 命令行工具curl是一个命令行工具,可以通过终端或脚本来使用。
  • 跨平台:可在多种操作系统上运行,包括LinuxUnixmacOSWindows
  • 开源curl是开源软件,可以自由使用和修改。
  1. 基本用法
  • 下载文件:curl -O URL,例如:curl -O https://www.example.com/file.txt,将会下载文件到当前目录。
  • 发送HTTP请求:curl -X GET/POST/PUT/DELETE URL,可以发送不同类型的HTTP请求。
  • 基本认证:curl -u username:password URL,用于进行基本的HTTP认证。
  • 保存响应到文件:curl -o output.txt URL,将服务器响应保存到指定文件中。
  1. 高级用法
  • 自定义请求头:通过-H选项可以添加自定义的HTTP请求头。
  • 表单提交:可以使用-d选项发送表单数据,例如-d "key1=value1&key2=value2"
  • 文件上传:使用-F选项可以上传文件,例如-F "file=@path/to/file"
  • 代理服务器:通过--proxy选项可以设置代理服务器。
  • SSL选项:支持HTTPS,可以使用--insecure选项来跳过SSL证书验证。
  • 断点续传:使用-C -选项可以实现断点续传,继续之前的下载。
  • Cookie管理:通过-b-c选项可以发送和保存Cookie信息。
  • 并发下载:使用-O URL1 -O URL2可以并发下载多个文件。

总之,curl是一个功能强大且灵活的工具,可用于各种网络通信需求。它的命令行界面和丰富的选项使其成为开发人员和系统管理员的重要工具之一。

相关文章
|
2月前
|
弹性计算 运维 监控
slb后端服务器组(Backend Server Group)关联
阿里云SLB的后端服务器组提供逻辑分组、精细化路由、端口隔离、权重分配与会话保持等功能,便于资源管理、流量控制和故障隔离。通过监听规则、健康检查、标签和API关联,实现灵活的后端资源配置,适应多变的业务需求,确保服务稳定性和资源利用率。
22 1
|
5天前
|
网络协议 安全
ensp中nat server 公网访问内网服务器
ensp中nat server 公网访问内网服务器
|
5天前
|
开发框架 JavaScript 安全
WIndows Server 2016 部署 Web服务(简单篇)
WIndows Server 2016 部署 Web服务(简单篇)
|
12天前
|
网络协议 Windows
Windows Server 各版本搭建 DNS 服务器实现域名正反向解析
Windows Server 各版本搭建 DNS 服务器实现域名正反向解析
|
2月前
|
运维 JavaScript 前端开发
发现了一款宝藏学习项目,包含了Web全栈的知识体系,JS、Vue、React知识就靠它了!
发现了一款宝藏学习项目,包含了Web全栈的知识体系,JS、Vue、React知识就靠它了!
|
2月前
|
存储 Windows
windows server 2019 云服务器看不见硬盘的解决方案
windows server 2019 云服务器看不见硬盘的解决方案
|
2月前
|
数据安全/隐私保护 Windows
Windows Server 各版本搭建终端服务器实现远程访问(03~19)
左下角开始➡管理工具➡管理您的服务器,点击添加或删除角色点击下一步勾选自定义,点击下一步蒂埃涅吉终端服务器,点击下一步点击确定重新登录后点击确定点击开始➡管理工具➡计算机管理,展开本地用户和组,点击组可以发现有个组关门用来远程登录右键这个组点击属性,点击添加输入要添加的用户名,点击确定添加成功后点击确定打开另一台虚拟机(前提是在同一个局域网内),按 WIN + R 输入 mstsc 后回车输入 IP 地址后点击连接输入用户名及密码后点击确定连接成功!
|
19天前
|
前端开发 测试技术 开发工具
探索前端框架React Hooks的优势与应用
本文将深入探讨前端框架React Hooks的优势与应用。通过分析React Hooks的特性以及实际应用案例,帮助读者更好地理解和运用这一现代化的前端开发工具。
|
11天前
|
开发框架 Dart 前端开发
【Flutter前端技术开发专栏】Flutter与React Native的对比与选择
【4月更文挑战第30天】对比 Flutter(Dart,强类型,Google支持,快速热重载,高性能渲染)与 React Native(JavaScript,庞大生态,热重载,依赖原生渲染),文章讨论了开发语言、生态系统、性能、开发体验、学习曲线、社区支持及项目选择因素。两者各有优势,选择取决于项目需求、团队技能和长期维护考虑。参考文献包括官方文档和性能比较文章。
【Flutter前端技术开发专栏】Flutter与React Native的对比与选择