有什么做任務(wù)得傭金的網(wǎng)站/站長(zhǎng)之家app
文章目錄
- 前言
- 環(huán)境準(zhǔn)備
- 依賴
- 代碼
- 運(yùn)行
- 使用
- 最后
前言
你好,我是醉墨居士,最近準(zhǔn)備花一些時(shí)間來使用Rust語言實(shí)現(xiàn)一個(gè)智能助手,希望能夠幫助到你。
環(huán)境準(zhǔn)備
- 安裝Rust語言環(huán)境,你可以從官網(wǎng)下載安裝包安裝。
- 安裝Ollama,你可以在官網(wǎng)下載安裝包安裝。(我這里暫時(shí)qwen2.5:0.5b模型)
- 安裝PostgreSQL數(shù)據(jù)庫(kù)。
依賴
ollama-rs = "0.2.2"
tokio = { version = "1.43.0", features = ["full"] }
tokio-stream = { version = "0.1.17" }
axum = "0.8.1"
代碼
use std::{collections::HashMap, sync::OnceLock};use axum::{extract::Query, routing::get, Json, Router
};
use ollama_rs::{generation::completion::request::GenerationRequest, Ollama
};#[derive(Debug)]
struct Context {ollama: Ollama,
}static CONTEXT: OnceLock<Context> = OnceLock::new();impl Context {fn global() -> &'static Self {CONTEXT.get_or_init(|| {println!("Initializing Ollama...");Context {ollama: Ollama::default(),}})}
}#[tokio::main]
async fn main() {let app = Router::new().route("/", get(chat));let listener = tokio::net::TcpListener::bind("0.0.0.0:3000").await.unwrap();axum::serve(listener, app).await.unwrap();
}async fn chat(Query(mut query): Query<HashMap<String, String>>) -> Json<String> {let prompt = if let Some(prompt) = query.remove("prompt") {prompt} else {return Json("Error: prompt not provided".to_string());};let req = GenerationRequest::new("qwen2.5:0.5b".into(), prompt);let res = Context::global().ollama.generate(req).await;Json(if let Ok(res) = res {res.response} else {"Error".to_string()})
}
運(yùn)行
cargo run
使用
打開瀏覽器,訪問http://localhost:3000?prompt=你好,即可得到AI回復(fù)
最后
我是醉墨居士,這篇博客就先到這里,后續(xù)我會(huì)繼續(xù)更新,歡迎你提出寶貴意見,互相交流,共同進(jìn)步