国产精品电影_久久视频免费_欧美日韩国产激情_成年人视频免费在线播放_日本久久亚洲电影_久久都是精品_66av99_九色精品美女在线_蜜臀a∨国产成人精品_冲田杏梨av在线_欧美精品在线一区二区三区_麻豆mv在线看

Rust能不能做后端開發語言?

開發 前端
作為一個主要面向系統開發的語言,一開始的確會因為Rust的復雜度而有點無從下手,不過熟悉了之后的確能感覺到Rust的高開發效率特性。而且,作為編譯型語言來說,執行效率應該沒有任何問題,不過因為過于年輕,Rust下支持的第三方開發框架還不算穩定,可能會出現一些Bug。不過通過有限的幾個Demo開發來看,還是勝任一個普通項目的后端支持的。

ProjectX只是現在我在做的一個項目的名稱,我計劃在整個項目的過程中做更多的嘗試,并且盡可能的將過程記錄下來。如果感興趣可以關注我,非常歡迎給我或是ProjectX提提你的建議。

這次ProjectX在選擇后端開發語言的時候,我不會考慮我自己的熟悉程度和之前的積累,希望可以比較客觀的選擇一個適合的后端語言,我也可以通過這個過程了解更多后端語言。目前計劃嘗試的后端語言有:PHP、JAVA、Node.js、Go、Rust、Ruby、Python。沒有案例的分享都是耍流氓,我用這幾個語言統一做一個簡單的數據查詢返回的API接口,來從服務器支持、開發環境搭建、RESTful路徑設置、數據庫連接、語言結構和文檔社區豐富度六個方面來聊聊我自己的感受。

語言簡介

相對于其他語言來說,Rust屬于最新的一個成員。最早由Mozilla于2014年4月9日發布。Rust是一款高級通用語言,而且屬于少有的一款兼顧開發和執行效率的編程語言。Rust結合了腳本語言的語法結構和C語言編譯執行效率,并且具有類似垃圾回收和數據類型及所有權系統等功能,所以可靠性和高性能運行都屬于Rust的特色。雖然是一個非常年輕的編程語言,但是Rust可以算是最近幾年最流行的編程語言。5月發布的Stack Overflow 2020開發者調查中,Rust被86.1%開發者選擇為“最喜歡”的編程語言,比第二名TypeScript高出近20%。雖然Rust并不是一個專屬的網絡應用開發語言,但是作為一個以安全著稱的編輯語言,實際上是非常適合網絡開發的。而且因為是編譯型語言,編譯器也能在過程中就安全穩定的問題作出提醒,作為后端網絡開發還是不錯的一個優勢。

 

Rust能不能做后端開發語言?
來自mozilla的Rust

服務器支持

Rust的通用庫中已經包含了類似TcpListener這樣的網絡通訊庫,可以直接通過調用std : : net 下面的TcpListener來直接監聽Tcp端口,然后再處理Request。這點上與一些腳本型的編程語言比要自由得很多。Rust作為比較流行的編程語言,也有不少第三方HTTP庫來支持Web開發,可以不用再花時間從底層開發,比較熱門的庫像Hyper或者Tide都是被不少Web開發框架用到的。Rust下Web開發框架也不少,比較熱門的有Rocket、Actix-Web、Tower-web、Warp等等框架。因為初次接觸Rust,所以還是先從比較成熟的框架Rocket來作Demo的嘗試,相對文檔會比較完善一些。不過,根據網上的一些討論,Rocket或是Actix-Web雖然比較熱門,但是因為基于比較老的hyper庫,所以可能對于一些功能不支持,例如Rocket不支持Async/Wait功能。不過總的來說Rust對于服務器的支持還是不錯的,而且就算找不到合適的開發框架,也可以從底層開發,雖然比較浪費時間。

 

Rust能不能做后端開發語言?
Rocket

IDE VS Editor

 

Rust能不能做后端開發語言?
Rust基本支持主流的編輯器

Rust基本上沒有直接IDE,只是通過插件的方式集合在一些IDE或者編輯器中,Rust對于主流的編輯器基本都支持。因為對于VS Code比較熟悉也就直接通過VS Code安裝了Rust插件,然后結合通過以下的shell 安裝好Rust以及Cargo,就基本安裝好了開發環境。

  1. curl --proto '=https' --tlsv1.2 -sSf https://sh.rustup.rs | sh 

Rust會通過Cargo來處理依賴的庫,而且在編譯的時候來拉取的,因為一些眾所周知的網絡問題,拉取速度非常慢。需要將第三方庫的注冊表網站crates.io換成國內鏡像。修改成國內鏡像的方式,在cargo安裝文件夾下新建config文件,一般cargo的安裝位置如下:

  1. $HOME/.cargo 

然后在新建的config文件中加入國內鏡像的信息,例如使用gitee的鏡像的話,文件內容如下:

 

  1. [source.crates-io] 
  2. replace-with='crates-cn' 
  3. [source.crates-cn] 
  4. registry="https://gitee.com/crates/crates.io-index.git" 

不過使用之后,發現gitee的index并不是最新的,就像最新的Rocket版本0.4.5就沒有被收入,所以換成了中科大的鏡像,文件內容可以改成相應的git鏈接,如下

 

  1. [source.crates-io] 
  2. replace-with='ustc' 
  3.  
  4. [source.ustc] 
  5. registry="https://mirrors.ustc.edu.cn/crates.io-index" 

雖然說Rust沒有自己的專屬IDE,不過Editor+插件的方式基本可以雷同于IDE,而且整體開發環境的配置還是非常直觀的。

 

Rust能不能做后端開發語言?
VS Code的Rust插件

RESTful vs GraphQL

通過Rust實現RESTful規范的接口,整體來說還是比較直觀的,Rust下比較流行的第三方Web開發框架都會支持路由功能,雖然不同的框架支持的方式不同,不過本質上都是通過掛載一個根路徑,然后通過框架支持的Macro來將不同路徑來指向不同函數來處理,我是用Rocket來做這個RESTful接口的Demo的,除了Rocket服務器啟動和根目錄掛載基本上,就是三行如下的代碼就可以設置好一條路徑:

 

  1. #[get("/herb/<uid>")] 
  2. pub fn get_herb(uid:i32) -> Result<Json<Vec<Herb>>, String> { 
  3.     //數據連接和業務邏輯 

當然可以將所有路由放在一個模塊內,然后在主程序內調用,類似如下的啟動Rocket服務器就可以運行了

 

  1. fn main() { 
  2.     rocket::ignite() 
  3.         .mount("/", routes![ 
  4.             routes::get_herb 
  5.         ]) 
  6.         .launch(); 

 

Rust能不能做后端開發語言?
RESTful接口demo的測試結果

對于GraphQL來說設置上會稍微復雜一點,需要通過第三方的GraphQL庫來實現,我使用了Juniper,同時嘗試了另一個Web開發框架Actix-Web,整體開發效率還是非??斓?,主要還是得益于Rust的Macro機制,基本上很多方法都通過Macro來關聯到了相應的對象上,直接在需要的地方調用就可以了。不過對于GraphQL要多一步設置Schema的過程,不過對于處理函數的添加還是比較直觀的,比之前使用Go的時候要更便于維護。在設置完Schema之后,只需要在RootQuery中添加相應的函數就能實現不同的業務邏輯,如下面包含兩個函數,調用全部對象和查詢單一對象的函數:

 

  1. #[juniper::object] 
  2. impl QueryRoot { 
  3.     fn herbs() -> Vec<Herb> { 
  4.         use crate::schema::herbs::dsl::*; 
  5.         let connection = establish_connection(); 
  6.         herbs 
  7.           .limit(100) 
  8.           .load::<Herb>(&connection
  9.           .expect("Error loading members"
  10.     } 
  11.     fn herb(_uid:i32) -> Vec<Herb> { 
  12.         use crate::schema::herbs::dsl::*; 
  13.         let connection = establish_connection(); 
  14.         herbs 
  15.         .filter(uid.eq(_uid)) 
  16.           .load::<Herb>(&connection
  17.           .expect("Error loading herbs"
  18.     } 

 

Rust能不能做后端開發語言?
GraphQL接口demo的測試結果

經過這兩個不同規范的,Rust高開發效率的特性非常好的體現了,只要熟悉了Rust語言規范之后,整體開發效率還是非常高的,很多代碼會通過Macro機制省略了。如果選擇Rust的話,感覺使用GraphQL的機會會更高,畢竟RESTful和GraphQL之間的開發成本差不多,那么GraphQL的自由度就更高了。

數據庫連接

 

Rust能不能做后端開發語言?
Diesel使用起來還是比較方便的

我使用了Diesel這個比較流行的數據庫連接框架,是設置和初始化的過程中,體現出了Rust比較類似其他系統語言的地方,在安裝了Diesel命令行工具之后,只需要通過下面幾行命令行就能直接設置好數據庫以及migration的配置

 

  1. //安裝diesel_cli,最后的參數是根據使用的數據庫來設置的 
  2. >cargo install diesel_cli --no-default-features --features mysql 
  3.  
  4. //將數據庫連接數據添加到項目根目錄的.env文件中 
  5. >echo DATABASE_URL=mysql://username:password@localhost/database_name > .env 
  6.  
  7. //然后設置就可以了 
  8. >diesel setup 

這樣diesel會了連接到數據庫服務器,如果數據庫不存在的時候,會自動生成一個數據庫。然后通過新建一個migration來添加數據庫中的表

  1. >diesel migration generate migration_name 

這樣就會在項目根目錄下migrations文件下生成當前時間為前綴的文件夾,其中有兩個文件,up.sql 存放新建表需要的sql語句,down.sql存放up.sql內相關新建語句的銷毀語句,例如:

 

  1. //up.sql 
  2. CREATE TABLE IF NOT EXISTS herbs ( 
  3.   uid int PRIMARY KEY AUTO_INCREMENT, 
  4.   cn_name varchar(255) NOT NULL
  5.   en_name varchar(255) DEFAULT NULL
  6.   latin_name varchar(255) NOT NULL
  7.   botanic_name varchar(255) DEFAULT NULL
  8.   part_used varchar(255) NOT NULL
  9.   common_name json DEFAULT NULL
  10.   country_of_origin json DEFAULT NULL
  11.   description text, 
  12.   harvest_season varchar(255) DEFAULT NULL
  13.   grow_duration varchar(255) DEFAULT NULL 
  14.  
  15. //down.sql 
  16. DROP TABLE herbs 

添加好相應的SQL語句,在運行如下命令就基本上設置好了Diesel

  1. >diesel migration run 

也可以通過以下命令來重置數據庫

  1. >diesel migration redo 

Diesel會直接在項目根目錄下的schema.rs文件中根據數據庫表的結構生成好相應的數據結構。然后通過diesel支持的Macro,建立同樣結構的struct就可以直接調用數據庫中的數據條了。例如對于可以查詢的數據條,可以在struct定義之上添加如下的Macro

 

  1. #[derive(Queryable)] 
  2. struct Herb { 
  3.     uid: i32, 
  4.     cn_name: String, 
  5.     en_name: String, 
  6.     latin_name: String, 
  7.     botanic_name: String, 
  8.     part_used: String, 
  9.     common_name: String, 
  10.     country_of_origin: String, 
  11.     description: String, 
  12.     harvest_season: String, 
  13.     grow_duration: String, 

這樣就可以直接通過在相應的業務邏輯中通過filter,load等查詢函數了。

整體來說Diesel在開發過程中非常簡潔明了,就算初次接觸的話,也是能直接掌握,對于之后比較復雜的數據庫操作自由度不確定是否足夠,不過對于一般項目的數據操作還是足夠的。

語言結構

Rust的語言結構同時是優勢也是劣勢。對于初次接觸的時候,Rust的語言結構非常令人疑惑,主要是其中的一些調用符號,比如->, : :, <>等等,不過熟悉之后就會覺得這些符號也算比較直觀,而且在不同場景使用不同的符號讓代碼的可讀性反而提高了。

然后Rust高開發效率的特性也通過Macro機制體現的淋漓盡致。通過不同derive Macro設置可以直接將相應的抽象函數添加給struct,這樣可以少寫很多代碼。例如下面我給這個struct添加了數據庫查詢(Queryable)的同時,添加了JSON的Serialize和Deserialize的功能。這樣在查詢出數據條可以直接調用JSON的map函數來生成JSON字符串。

 

  1. #[derive(Serialize, Deserialize, Queryable)] 
  2. pub struct Herb { 
  3.     pub uid: i32, 
  4.     pub cn_name: String, 
  5.     pub en_name: String, 
  6.     pub latin_name: String, 
  7.     pub botanic_name: String, 
  8.     pub part_used: String, 
  9.     pub common_name: String, 
  10.     pub country_of_origin: String, 
  11.     pub description: String, 
  12.     pub harvest_season: String, 
  13.     pub grow_duration: String, 

這個對于RESTful接口非常有用,可以將數據庫的查詢結果直接map然后返回。

總的來說,一開始會覺得Rust是比較復雜的編程語言,不過熟悉了之后,還是非常喜歡Rust簡潔的代碼結構和高效的開發體驗。

文檔社區

作為一個比較熱門的編程語言,Rust的開發社區還算是比較活躍的,不過因為畢竟Rust還是一個非常年輕的編程語言,很多第三方框架也都比較年輕, 有些框架還都沒有完全達到1.0版本,而且文檔相對也是比較簡單的。不過Rust的穩定性應該會延展到第三方框架的開發上的,雖然大型項目可能不一定適合,但是絕大多數項目還是可以支持到的。

文檔也是同樣的問題,作為比較年輕的語言,除了官方文檔以外,文檔或是解決方案相對會少不少。而且很多文檔還是以英文為主還沒有中文化。但是以開發社區的活躍度來看,應該不需要多少時間就會出現很多文檔和問題解決方案出現。

總結

作為一個主要面向系統開發的語言,一開始的確會因為Rust的復雜度而有點無從下手,不過熟悉了之后的確能感覺到Rust的高開發效率特性。而且,作為編譯型語言來說,執行效率應該沒有任何問題,不過因為過于年輕,Rust下支持的第三方開發框架還不算穩定,可能會出現一些Bug。不過通過有限的幾個Demo開發來看,還是勝任一個普通項目的后端支持的。而且和Go一樣,作為比較年輕的編輯語言,未來的發展空間還是比較大的。雖然只是接觸了1個多星期,也沒有非常深入的開發過,但是我的確已經喜歡上這個語言了,不愧為Stack Overflow最受歡迎編程語言的殊榮。

責任編輯:未麗燕 來源: 今日頭條
相關推薦

2019-11-21 09:25:23

AI 數據人工智能

2016-05-19 17:10:27

銀行

2013-04-19 10:42:02

打車軟件大數據

2025-04-22 08:00:00

2022-10-20 08:00:37

機器人ZadigChatOps

2021-02-26 21:25:08

比特幣投資貨幣

2023-12-27 08:03:53

Go優化代碼

2010-04-13 10:02:16

索引

2020-12-21 15:09:23

人工智能安全人臉識別

2024-04-26 09:37:43

國產數據庫開發者

2012-06-13 11:01:59

英特爾

2022-04-24 11:52:04

元宇宙Web3去中心化

2023-04-06 06:55:24

ChatGPTGPT算力

2025-06-13 02:00:00

系統cookieURL

2022-12-09 08:22:26

Gradle編譯運行

2022-11-07 08:36:11

2021-06-15 11:33:48

監控微信聊天前端

2011-12-06 10:06:33

云存儲

2024-07-15 11:41:14

2011-08-09 16:08:53

數據庫連接
點贊
收藏

51CTO技術棧公眾號

色综合天天色综合| 亚洲www免费| 成人毛片视频在线观看| 牛牛精品成人免费视频| 成人福利视频网站| 欧美精品v日韩精品v国产精品| 精品一二三区| 国产精品福利一区二区| 久久男人资源站| 久热综合在线亚洲精品| 欧美日韩不卡一区| 中文字幕在线视频不卡| 日韩理论片一区二区| 国产精品高清在线| 欧美1区2区3区4区| 欧美激情视频播放| 黄色免费看网站| 国产精品入口麻豆九色| 国产一区在线播放| 亚洲人挤奶视频| 777国产偷窥盗摄精品视频| 清纯唯美激情亚洲| 亚洲成人免费看| 国产理论片免费观看| 欧美极品aⅴ影院| 1234区在线观看视频免费| 亚洲婷婷综合色高清在线| 男女18免费网站视频| 国产美女精品| 亚洲国产黄色片| 青春草视频在线| 国产视频精品一区二区三区| 亚洲第一会所001| 蜜臀久久99精品久久久无需会员 | 蜜臀精品一区二区三区在线观看| 日韩国产欧美一区| 国产高清一区日本| 国产九九在线视频| 五月婷婷激情综合| 黄色网址在线免费观看| 日韩电视剧在线观看免费网站| 中文字幕21页在线看| 国产精品久久久久久久久果冻传媒| 国产精品久久久毛片| 亚洲一区二区三区美女| 精品日韩在线播放| 三级小说欧洲区亚洲区| 7777精品伊人久久久大香线蕉经典版下载 | 久久婷婷麻豆| 18视频在线观看娇喘| 久久精品免费在线观看| 中文字幕av高清在线观看| 日韩欧美视频一区| 日本久久伊人| 999日本视频| 136福利精品导航| 国产日韩在线免费| 日韩电影免费在线看| 亚欧在线免费观看| 欧美丰满美乳xxx高潮www| 91麻豆精品国产91久久久更新资源速度超快| 51久久精品夜色国产麻豆| 中文在线一区| 亚洲人成无码www久久久| 奶水喷射视频一区| 国产美女网站在线观看| 第一福利永久视频精品| 色综合天天色| 精品国产三级电影在线观看| 国产精品日韩精品在线播放| 亚洲精品一区在线观看| 亚洲日本一区二区三区在线| 国产日韩二区| www日韩大片| 免费日本一区二区三区视频| 亚洲精品国产高清久久伦理二区| 成人性生交大片免费看午夜 | 亚洲制服少妇| 成人免费视频77777| 日韩欧美一区电影| 亚洲三级精品| 大陆极品少妇内射aaaaaa| 天天色综合成人网| 精品视频成人| 椎名由奈jux491在线播放| 亚洲电影一区二区| avtt久久| 天堂av免费看| 麻豆91在线播放| 午夜在线不卡| 最近2019中文字幕一页二页| 影院在线观看全集免费观看| 欧美高跟鞋交xxxxxhd| 日韩精品每日更新| 国产香蕉视频在线观看| 亚洲一区影音先锋| 亚洲精品555| 日本精品国语自产拍在线观看| 一区二区三区精品在线观看| 97秋霞电影网| 亚洲欧美在线x视频| 成人美女黄网站| 91免费在线观看网站| 欧美日韩精品免费观看视频完整| 国产精品亚洲αv天堂无码| 精品少妇一区二区三区| 99久久婷婷国产综合精品电影√| 黑人粗进入欧美aaaaa| 亚洲色图15p| 老司机一区二区三区| 久久精品色图| 国产精品久久中文| 中文字幕欧美日韩一区| 欧美日韩国产网站| 性欧美精品一区二区三区在线播放| 美女免费视频一区二区| 伊人国产在线| 91久久免费观看| 国产精品一区二区婷婷| 欧美日韩精品二区第二页| 国产精品一线天粉嫩av| 亚洲黄色小视频在线观看| 日韩中文字幕av| 国产一区二区三区蝌蚪| 欧美寡妇性猛交xxx免费| 精品一区在线播放| 欧美日韩一区视频| 91av久久| 视频一区二区综合| 日韩欧美电影在线| 亚洲影音一区| 国产一区久久精品| 欧美自拍资源在线| 精品美女在线播放| 久久精品国产一区二区三| 天堂√中文最新版在线| 99国产精品白浆在线观看免费| 成人视屏免费看| 亚洲free性xxxx护士白浆| 成人在线中文| 青春草在线视频免费观看| 日韩一级黄色片| 亚洲成人激情社区| 一本久久a久久精品vr综合 | 亚洲婷婷在线视频| 免费不卡中文字幕在线| 手机福利视频欧美| 成人动漫网站在线观看| 色综合天天综合给合国产| 亚洲大黄网站| www.射射射| 精品久久久久久亚洲精品| 欧美一二区在线观看| 蜜芽tv福利在线视频| 亚洲日本成人女熟在线观看| 国产一区二区三区免费看| 国模套图日韩精品一区二区| 欧日韩免费视频| 欧美激情精品久久久久久| 一区二区三区在线观看网站| 欧美午夜在线| 亚洲欧美电影| 蜜臀av免费观看| 成人在线视频福利| 精品国产污污免费网站入口 | 午夜影院免费在线| 久久国产精品久久久久久久久久| av网站一区二区三区| 中文字幕乱在线伦视频乱在线伦视频| 国产女精品视频网站免费| 欧美日韩国产欧美日美国产精品| 人人狠狠综合久久亚洲| 久久精品国产精品亚洲毛片| 亚洲free嫩bbb| 欧美一区二区三区在线看| 五月天亚洲一区| 国产在线观看网站| 在线观看污视频| 欧美一级电影在线| 欧美军同video69gay| 99久久精品免费观看| 久久久9色精品国产一区二区三区| 性欧美猛交videos| 88av.com| 日韩精品免费看| 中文字幕免费一区| 很黄很黄激情成人| 日韩久久99| 福利视频在线导航| 欧美国产日韩激情| 日韩一级在线观看| 99视频有精品| 欧美日韩亚洲一区二区三区在线| 欧美成人精品一区二区男人小说| 麻豆一区二区三区四区精品蜜桃| 日本一区二区精品视频| 久久久爽爽爽美女图片| 制服丝袜日韩国产| 自拍偷拍欧美精品| 久久99精品国产麻豆婷婷 |