技术选型Rust——事后分析

引言

最近使用Rust写了一个消费企业GitHub评论事件的微服务。本文记录自己选择Rust编写而不是Python的一些思考,如稍微花时间的点。

微服务要做的事情很简单:暴露一个接收post请求的http接口。每当收到payload的时候,如果是我感兴趣的消息,那么就提取相应的信息,发送给另外一个服务器。

我预先估计使用Rust会需要4天(每天有效工作时间4个小时,4*4=16小时),而如果使用Python会需要2天。

实际共花费了2天,大致时间分布如下,

  1. 1.5天编写完成Rust代码和单元测试
  2. 0.5天部署到kubenetes和GitHub完全打通。

完成的微服务的架构如下,

技术选型Rust——事后分析_第1张图片

使用Rust需要额外思考的点

这是我用Rust编写的第2.5个项目,第一个是 https:// github.com/Celthi/symbo l-service

使用Rust写代码过程中,遇到了一些可能Rust独有的需要稍微花点时间的问题

全局可变变量

web模块收到消息后,要存放到消息队列里面。而web模块是一个接收特定参数的函数,那么它提取消息以后,怎么访问消息队列呢?

消息队列不能从参数传进来,那么只能使用全局变量了。

全局变量使用lazy_static这个库。但是现在要创建一个可变的channel,类似于下面的代码

let (tx, rx) = mpsc::channel();

    thread::spawn(move || {
        let val = String::from("hi");
        tx.send(val).unwrap();
    });

    let received = rx.recv().unwrap();
    pr

你可能感兴趣的:(JAVA,程序员,计算机,rust,开发语言,后端)