内容简介:An ongoing experiment usingSo far using a thread pool and channels to communicate with the Warp route handler. The goal is to get a full Node-likeNode outperforms QuickJS by a wide margin. Especially with enough cores and memory. However, QuickJS is very s
Fast Vue SSR with Rust and QuickJS
An ongoing experiment using Rust , Warp and QuickJS to server-side render Vue.js applications.
use renderer::RendererPool;
#[tokio::main]
pub async fn main() -> io::Result<()> {
let pool = Arc::new(Mutex::new(RendererPool::new(64)));
let renderer = warp::path::full().map(move |path: FullPath| {
let renderer = Arc::clone(&pool);
let s = path.as_str().to_string();
// Currently only passing path to renderer is possible
// Full Request object is a WIP
let result = renderer.lock().unwrap().render(s);
result
});
let routes = warp::path::full()
.and(renderer)
.map(|_, result| reply::html(result));
So far using a thread pool and channels to communicate with the Warp route handler. The goal is to get a full Node-like IncomingMessage
object available as $ssrContext.req
. It already includes a /static
handler and serves a code-splitted build on the client via Rollup.
Node outperforms QuickJS by a wide margin. Especially with enough cores and memory. However, QuickJS is very small and has very low memory consumption, so running it threaded in a Rust shell makes it possible to have very high throughput using very few resources in comparison.
Inspired by Xinjiang Shao's experiment .
Running
- Install Rust .
-
npm install -
npm test
Or npm run build
for generating the Rust binary.
以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 码农网
猜你喜欢:本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
突破——程序员如何练就领导力
刘朋 / 电子工业出版社 / 2018-8-31 / 55.00元
内容简介: 在今日中国如雨后春笋般出现的各种新兴的互联网和软件公司中,有越来越多的技术达人凭借在技术上的优异表现而被晋升为技术团队的管理者和领导者。然而,从技术到管理——从单枪匹马的个人贡献者到一呼百应的技术团队领导者——注定是“惊险的一跃”。对于刚走上技术团队管理岗位的技术专家,你一定遇到过和本书作者当年一样的各种困惑和不适“症状”: ——我能处理好人“机”关系,但是如何处理好人际关......一起来看看 《突破——程序员如何练就领导力》 这本书的介绍吧!