Merge pull request #847 from zongzi531/hotfix/practice

fix: typo in third-party-libs
pull/848/head
Sunface 3 years ago committed by GitHub
commit 8ec0ca6d19
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23

@ -18,36 +18,36 @@
## 日常开发常用Rust库
### Web/HTTP
* HTTP客户端
* [reqwest](https://github.com/seanmonstar/reqwest) 一个简单又强大的HTTP客户端`reqwest`是目前使用最多的HTTP库
* [reqwest](https://github.com/seanmonstar/reqwest) 一个简单又强大的HTTP客户端`reqwest`是目前使用最多的HTTP库
* Web框架
* [axum](https://github.com/tokio-rs/axum) 基于Tokio和Hyper打造模块化设计较好目前口碑很好值得使用Ergonomic and modular web framework built with Tokio, Tower, and Hyper
* [Rocket](https://github.com/SergioBenitez/Rocket) 功能强大API简单的Web框架但是主要开发者目前因为个人原因无法进行后续开发未来存在不确定性
* [actix-web](https://github.com/actix/actix-web) 性能极高的Web框架就是团队内部有些问题未来存在一定的不确定性
* [axum](https://github.com/tokio-rs/axum) 基于Tokio和Hyper打造模块化设计较好目前口碑很好值得使用Ergonomic and modular web framework built with Tokio, Tower, and Hyper
* [Rocket](https://github.com/SergioBenitez/Rocket) 功能强大API简单的Web框架但是主要开发者目前因为个人原因无法进行后续开发未来存在不确定性
* [actix-web](https://github.com/actix/actix-web) 性能极高的Web框架就是团队内部有些问题未来存在一定的不确定性
* 总体来说上述三个web框架都有很深的用户基础其实都可以选用如果让我推荐顺序如下: `axum` > `Rocket` > `actix-web`。 不过如果你不需要多么完善的web功能只需要一个性能极高的http库那么`actix-web`是非常好的选择,它的性能非常非常非常高!
### 日志监控
* 日志
[[crates.io](https://crates.io/keywords/log)] [[github](https://github.com/search?q=rust+log)]
* [tokio-rs/tracing](https://github.com/tokio-rs/tracing) 强大的日志框架同时还支持OpenTelemetry格式无缝打通未来的监控
* [rust-lang/log](https://github.com/rust-lang/log) 官方日志库事实上的API标准, 但是三方库未必遵循
* [estk/log4rs](https://github.com/estk/log4rs) 模仿JAVA `logback`和`log4j`实现的日志库, 可配置性较强
* 在其它文章中也许会推荐slog但是我们不推荐一个是因为近半年未更新一个是`slog`自己也推荐使用`tracing`。
* [tokio-rs/tracing](https://github.com/tokio-rs/tracing) 强大的日志框架同时还支持OpenTelemetry格式无缝打通未来的监控
* [rust-lang/log](https://github.com/rust-lang/log) 官方日志库事实上的API标准, 但是三方库未必遵循
* [estk/log4rs](https://github.com/estk/log4rs) 模仿JAVA `logback`和`log4j`实现的日志库, 可配置性较强
* 在其它文章中,也许会推荐`slog`,但是我们不推荐,一个是因为近半年未更新,一个是`slog`自己也推荐使用`tracing`。
* 监控
* [OpenTelemetry](https://github.com/open-telemetry/opentelemetry-rust) `OpenTelemetry`是现在非常火的可观测性解决方案提供了协议、API、SDK等核心工具用于收集监控数据最后将这些metrics/logs/traces数据写入到`prometheus`, `jaeger`等监控平台中。最主要是,它后台很硬,后面有各大公司作为背书,未来非常看好!
* [vectordotdev/vector](https://github.com/vectordotdev/vector) 一个性能很高的数据采集agent采集本地的日志、监控等数据发送到远程的kafka、jaeger等数据下沉端它最大的优点就是能从多种数据源(包括Opentelemetry)收集数据,然后推送到多个数据处理或者存储等下沉端。
* [OpenTelemetry](https://github.com/open-telemetry/opentelemetry-rust) 是现在非常火的可观测性解决方案提供了协议、API、SDK等核心工具用于收集监控数据最后将这些metrics/logs/traces数据写入到`prometheus`, `jaeger`等监控平台中。最主要是,它后台很硬,后面有各大公司作为背书,未来非常看好!
* [vectordotdev/vector](https://github.com/vectordotdev/vector) 一个性能很高的数据采集agent采集本地的日志、监控等数据发送到远程的kafka、jaeger等数据下沉端它最大的优点就是能从多种数据源(包括Opentelemetry)收集数据,然后推送到多个数据处理或者存储等下沉端。
### SQL客户端
* 通用
* [launchbadge/sqlx](https://github.com/launchbadge/sqlx) 异步实现、高性能、纯Rust代码的SQL库支持`PostgreSQL`, `MySQL`, `SQLite`,和 `MSSQL`.
* ORM
* [rbatis/rbatis](https://github.com/rbatis/rbatis) 国内团队开发的ORM异步、性能高、简单易上手
* [diesel-rs/diesel](https://github.com/diesel-rs/diesel) 安全、扩展性强的Rust ORM库支持`MySQL`、`PostgreSQL`、`SQLLite`
* [rbatis/rbatis](https://github.com/rbatis/rbatis) 国内团队开发的ORM异步、性能高、简单易上手
* [diesel-rs/diesel](https://github.com/diesel-rs/diesel) 安全、扩展性强的Rust ORM库支持`MySQL`、`PostgreSQL`、`SQLLite`
* MySQL
* [blackbeam/rust-mysql-simple](https://github.com/blackbeam/rust-mysql-simple) 纯Rust实现的MySQL驱动,提供连接池
* [blackbeam/mysql_async](https://github.com/blackbeam/mysql_async) 基于Tokio实现的异步MySQL驱动
* [blackbeam/rust-mysql-simple](https://github.com/blackbeam/rust-mysql-simple) 纯Rust实现的MySQL驱动,提供连接池
* [blackbeam/mysql_async](https://github.com/blackbeam/mysql_async) 基于Tokio实现的异步MySQL驱动
* 上面两个都是一个团队出品前者文档更全、star更多建议使用前者
* PostgreSQL
@ -63,7 +63,7 @@
* Canssandra
* [krojew/cdrs-tokio](https://github.com/krojew/cdrs-tokio) [[cdrs-tokio](https://crates.io/crates/cdrs-tokio)] 生产可用的Cassandra客户端异步、纯Rust实现就是个人项目 + star较少未来不确定会不会不维护
* [scylla-rust-driver](https://github.com/scylladb/scylla-rust-driver) ScyllaDB提供的官方库支持cql协议由于背靠大山未来非常可期
* [scylla-rust-driver](https://github.com/scylladb/scylla-rust-driver) ScyllaDB提供的官方库支持cql协议由于背靠大山未来非常可期
* MongoDB
* [mongodb/mongo-rust-driver](https://github.com/mongodb/mongo-rust-driver) 官方MongoDB客户端闭着眼睛选就对了
@ -75,8 +75,8 @@
#### 消息队列
* Kafka
* [fede1024/rust-rdkafka](https://github.com/fede1024/rust-rdkafka) Rust Kafka客户端基于C版本的Kafka库[librdkafka]实现,文档较全、功能较为全面
* [kafka-rust/kafka-rust](https://github.com/kafka-rust/kafka-rust) 相比上一个库它算是纯Rust实现文档还行支持Kafka0.8.2及以后的版本但是对于部分0.9版本的特性还不支持。同时有一个问题:最初的作者不维护了,转给了现在的作者,但是感觉好像也不是很活跃
* [fede1024/rust-rdkafka](https://github.com/fede1024/rust-rdkafka) Rust Kafka客户端基于C版本的Kafka库[librdkafka]实现,文档较全、功能较为全面
* [kafka-rust/kafka-rust](https://github.com/kafka-rust/kafka-rust) 相比上一个库它算是纯Rust实现文档还行支持Kafka0.8.2及以后的版本但是对于部分0.9版本的特性还不支持。同时有一个问题:最初的作者不维护了,转给了现在的作者,但是感觉好像也不是很活跃
* Nats
* [nats-io/nats.rs](https://github.com/nats-io/nats.rs) Nats官方提供的客户端
@ -84,7 +84,7 @@
### 网络、通信协议
* WebSocket
* [snapview/tokio-tungstenite](https://github.com/snapview/tokio-tungstenite) 更适合Web应用使用的生产级Websocket库它是异步非阻塞的基于下面的`tungstenite-rs`库和tokio实现
* [rust-websocket](https://github.com/websockets-rs/rust-websocket) 老牌Websocket库提供了客户端和服务器端实现但是。。。很久没更新了
* [rust-websocket](https://github.com/websockets-rs/rust-websocket) 老牌Websocket库提供了客户端和服务器端实现但是。。。很久没更新了
* [snapview/tungstenite-rs](https://github.com/snapview/tungstenite-rs) 轻量级的Websocket流实现该库更偏底层例如你可以用来构建其它网络库
* gRPC
@ -97,16 +97,16 @@
* [quinn-rs/quinn](https://github.com/quinn-rs/quinn) 提供异步API调用纯Rust实现同时提供了几个有用的网络库
* MQTT
* [bytebeamio/rumqtt](https://github.com/bytebeamio/rumqtt) MQTT3.1.1/5协议库同时实现了客户端与服务器端broker
* [ntex-rs/ntex-mqtt](https://github.com/ntex-rs/ntex-mqtt) 客户端与服务端框架支持MQTT3.1.1与5协议
* [eclipse/paho.mqtt.rust](https://github.com/eclipse/paho.mqtt.rust) 老牌MQTT框架对MQTT支持较全, 其它各语言的实现也有
* [bytebeamio/rumqtt](https://github.com/bytebeamio/rumqtt) MQTT3.1.1/5协议库同时实现了客户端与服务器端broker
* [ntex-rs/ntex-mqtt](https://github.com/ntex-rs/ntex-mqtt) 客户端与服务端框架支持MQTT3.1.1与5协议
* [eclipse/paho.mqtt.rust](https://github.com/eclipse/paho.mqtt.rust) 老牌MQTT框架对MQTT支持较全, 其它各语言的实现也有
### 异步网络编程
* [tokio-rs/tokio](https://github.com/tokio-rs/tokio) 最火的异步网络库除了复杂上手难度高一些外没有其它大的问题。同时tokio团队提供了多个非常优秀的Rust库整个生态欣欣向荣用户认可度很高
* [async-std](https://async.rs/) 跟标准库API很像的异步网络库相对简单易用但是貌似开发有些停滞还有就是功能上不够完善。但是对于普通用户来说这个库非常值得一试它在功能和简单易用上取得了很好的平衡
* [actix](https://github.com/actix/actix) 基于Actor模型的异步网络库但这个库的开发貌似已经停滞他们团队一直在专注于`actix-web`的开发
* [mio](https://github.com/tokio-rs/mio) 严格来说MIO与之前三个不是同一个用途的MIO = Meta IO是一个底层IO库往往用于构建其它网络库当然如果你对应用网络性能有非常极限的要求 可以考虑它,因为它的层次比较低,所带来的抽象负担小,所以性能损耗小
* [mio](https://github.com/tokio-rs/mio) 严格来说MIO与之前三个不是同一个用途的MIO = Meta IO是一个底层IO库往往用于构建其它网络库当然如果你对应用网络性能有非常极限的要求可以考虑它因为它的层次比较低所带来的抽象负担小所以性能损耗小
* 如果你要开发生产级别的项目,我推荐使用`tokio`,稳定可靠,功能丰富,控制粒度细;自己的学习项目或者没有那么严肃的开源项目,我推荐`async-std`简单好用值得学习当你确切知道需要Actor网络模型时就用`actix`
@ -116,22 +116,22 @@
* [elastic/elasticsearch](https://github.com/elastic/elasticsearch-rs) 官方es客户端目前第三方的基本都处于停滞状态所以不管好坏用呗
* Rust搜索引擎
* [Tantivy](https://github.com/quickwit-inc/tantivy) Tantivy是Rust实现的本地搜索库功能对标`lucene`如果你不需要分布式那么引入tantivy作为自己本地Rust服务的一个搜索是相当不错的选择该库作者一直很活跃而且最近还创立了搜索引擎公司感觉大有作为. 该库的优点在于纯Rust实现性能高(lucene的2-3倍),资源占用低(对比java自然不是一个数量级),社区活跃。
* [Tantivy](https://github.com/quickwit-inc/tantivy) Tantivy是Rust实现的本地搜索库功能对标`lucene`如果你不需要分布式那么引入tantivy作为自己本地Rust服务的一个搜索是相当不错的选择该库作者一直很活跃而且最近还创立了搜索引擎公司感觉大有作为该库的优点在于纯Rust实现性能高(lucene的2-3倍),资源占用低(对比java自然不是一个数量级),社区活跃。
* Rust搜索平台
* [quickwit](https://github.com/quickwit-inc/quickwit) 对标ElasticSearch一个通用目的的分布式搜索平台目前还在起步阶段(0.2版本),未来非常可期,目前还不建议使用
* [MeiliSearch](https://github.com/meilisearch/MeiliSearch) 虽然也是一个搜索平台,但是并不是通用目的的,`MeiliSearch`目标是为终端用户提供边输入边提示的即刻搜索功能因此是一个轻量级搜索平台不适用于数据量大时的搜索目的。总之如果你需要在网页端或者APP为用户提供一个搜索条然后支持输入容错、前缀搜索时就可以使用它。
*
### 代码Debug
* GDB
* [gdbgui](https://github.com/cs01/gdbgui) 提供浏览器支持的gdb debug工具支持CC++Rust和Go.
* [gdbgui](https://github.com/cs01/gdbgui) 提供浏览器支持的gdb debug工具支持CC++Rust和Go.
* LLDB
* [CodeLLDB](https://marketplace.visualstudio.com/items?itemName=vadimcn.vscode-lldb) 专门为VSCode设计的LLDB Debug扩展
* [CodeLLDB](https://marketplace.visualstudio.com/items?itemName=vadimcn.vscode-lldb) 专门为VSCode设计的LLDB Debug扩展
### 性能优化
* [bheisler/criterion.rs](https://github.com/bheisler/criterion.rs) 比官方提供的benchmark库更好目前已经成为事实上标准的性能测试工具
* [Bytehound](https://github.com/koute/bytehound) Linux下的内存分析工具可以用来分析内存泄漏、内存分配、调用栈追踪甚至它还有一个浏览器UI! 懂的人都懂性能测试工具的UI服务是多么稀缺和珍贵
* [Bytehound](https://github.com/koute/bytehound) Linux下的内存分析工具可以用来分析内存泄漏、内存分配、调用栈追踪甚至它还有一个浏览器UI懂的人都懂性能测试工具的UI服务是多么稀缺和珍贵
* [llogiq/flame](https://github.com/llogiq/flame) 专为Rust打造的火焰图分析工具可以告诉你程序在哪些代码上花费的时间过多非常适合用于代码性能瓶颈的分析。与`perf`不同,`flame`库允许你自己定义想要测试的代码片段,只需要在代码前后加上相应的指令即可,非常好用
* [sharkdp/hyperfine](https://github.com/sharkdp/hyperfine) 一个命令行benchmark工具支持任意shell命令支持缓存清除、预热、多次运行统计分析等尽量保证结果的准确性
@ -142,7 +142,7 @@
* [BurntSushi/rust-csv](https://github.com/BurntSushi/rust-csv) 高性能CSV读写库支持[Serde](https://github.com/serde-rs/serde)
* JSON
* [serde-rs/json](https://github.com/serde-rs/json) 快到上天的JSON库也是Rust事实上的标准JSON库你也可以使用它的大哥[serde](https://github.com/serde-rs/serde),一个更通用的序列化/反序列化库
* [serde-rs/json](https://github.com/serde-rs/json) 快到上天的JSON库也是Rust事实上的标准JSON库你也可以使用它的大哥[Serde](https://github.com/serde-rs/serde),一个更通用的序列化/反序列化库
* MsgPack
* [3Hren/msgpack-rust](https://github.com/3Hren/msgpack-rust) 纯Rust实现的MessagePack编解码协议

Loading…
Cancel
Save