.net core Api 部署到Linux的方法步驟
1..net開(kāi)發(fā)環(huán)境:asp.net core 3.12.Linux環(huán)境:CentOS Linux release 7.9.2009 (Core)3.Swagger: Swashbuckle.AspNetCore6.04.開(kāi)發(fā)工具:VS2019,xShell7,xFtp7
二.搭建API2.1使用vs2019新建一個(gè)API項(xiàng)目
選擇上面的工具--》NuGet包管理器--》管理解決方案的管理包

搜索Swashbuckle.AspNetCore,并安裝即可
Swashbuckle.AspNetCore

找到項(xiàng)目的中Startup.cs 文件,修改內(nèi)容如下:

代碼如下:
public void ConfigureServices(IServiceCollection services) { services.AddSwaggerGen(options => { options.SwaggerDoc('v1', new OpenApiInfo { Title = 'My API', Version = 'v1' }); // 獲取xml文件名 var xmlFile = $'{Assembly.GetExecutingAssembly().GetName().Name}.xml'; // 獲取xml文件路徑 var xmlPath = Path.Combine(AppContext.BaseDirectory, xmlFile); // 添加控制器層注釋,true表示顯示控制器注釋 options.IncludeXmlComments(xmlPath, true); }); services.AddControllers(); } // This method gets called by the runtime. Use this method to configure the HTTP request pipeline. public void Configure(IApplicationBuilder app, IWebHostEnvironment env) { if (env.IsDevelopment()) { app.UseDeveloperExceptionPage(); } //啟用中間件服務(wù)生成Swagger作為JSON終結(jié)點(diǎn) app.UseSwagger(c=> { c.PreSerializeFilters.Add((doc,item)=> { doc.Servers = new List<OpenApiServer> { new OpenApiServer{ Url=$'{item.Scheme}://{item.Host.Value}/{item.Headers['X-Forwarded-Prefix']}' } }; }); }); //啟用中間件服務(wù)對(duì)swagger-ui,指定Swagger JSON終結(jié)點(diǎn) app.UseSwaggerUI(c => { c.ShowExtensions(); c.SwaggerEndpoint('/swagger/v1/swagger.json', 'My API V1'); c.DocExpansion(DocExpansion.None); c.RoutePrefix = string.Empty; //如果跟目錄顯示SwaggerUI加上這句 }); app.UseHttpsRedirection(); app.UseRouting(); app.UseAuthorization(); app.UseEndpoints(endpoints => { endpoints.MapControllers(); }); }2.4設(shè)置生成的API文檔

首先啟動(dòng)項(xiàng)目,之后會(huì)生成一個(gè)Demo1.xml文件,如下圖所示,單擊文件Demo.xml文件,修改復(fù)制到輸出目錄: 如果較新則復(fù)制

選擇項(xiàng)目名稱,右鍵選擇發(fā)布

選擇文件夾,之后選擇下一步,選擇完成即可。

點(diǎn)擊發(fā)布按鈕即可

使用Xftp軟件,把本地發(fā)布的文件上傳到Linux系統(tǒng)中

到此,API已經(jīng)創(chuàng)建,也上傳到服務(wù)器了。
四.啟動(dòng)項(xiàng)目使用Xshell工具,連接到我們的Linux操作系統(tǒng),使用cd path 命令進(jìn)入到之前上傳的文件夾中。
進(jìn)入目錄:cd /home/www/test
查看文件列表:ls

輸入命令:dotnet Demo1.dll,如下圖所示,這是成功的在Linux中啟動(dòng)了我們發(fā)布的API項(xiàng)目。

192.168.6.130:把你Linux的IP替換我的這個(gè)192.168.6.130,在訪問(wèn)
在你的瀏覽器中輸入:http://192.168.6.130:5000/index.html

到此,我們就完成一個(gè)Asp.net core發(fā)布的API,部署到Linux系統(tǒng)中,成功啟動(dòng)運(yùn)行。
五.總結(jié)通過(guò)如上操作,也只是簡(jiǎn)單粗糙的在Linux中啟動(dòng)WebApi,讓我學(xué)習(xí)了.net core也是可以跨平臺(tái)的,也是總結(jié)一下踩坑的經(jīng)驗(yàn),比如說(shuō)部署Api中如果有Swagger,正常的部署是無(wú)法訪問(wèn),需要修改配置西信息查看2.3 Swagger配置,后面計(jì)劃繼續(xù)深入,把API部署到Dokcer中,使用nginx來(lái)實(shí)現(xiàn)反向代理。雖然這些在工作中完全用不到,就是想學(xué)習(xí)了解,這個(gè)技術(shù)能幫我解決什么問(wèn)題,只能了解更多,遇到問(wèn)題才能有多個(gè)解決方法。加油,干飯人!
到此這篇關(guān)于.net core Api 部署到Linux的文章就介紹到這了,更多相關(guān).net core Api 部署到Linux內(nèi)容請(qǐng)搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持好吧啦網(wǎng)!
作者:喜歡吃魚(yú)的青年出處:https://home.cnblogs.com/u/2828sea/
相關(guān)文章:
1. 怎么讓Dock欄只顯示已打開(kāi)的應(yīng)用程序?Dock欄只顯示已打開(kāi)的應(yīng)用程序的方法2. win7系統(tǒng)中提示未授予用戶在此計(jì)算機(jī)上的請(qǐng)求登錄類型的具體處理方法3. 三國(guó)群英傳7win10 打不開(kāi)怎么解決4. Win10系統(tǒng)chrome擴(kuò)展程序安裝一直提示檢查怎么處理?5. Win8系統(tǒng)無(wú)線網(wǎng)絡(luò)服務(wù)怎么開(kāi)啟?Win8系統(tǒng)開(kāi)啟無(wú)線網(wǎng)絡(luò)服務(wù)的方法6. 怎么更新顯卡驅(qū)動(dòng)win10 win10如何更新顯卡驅(qū)動(dòng)程序7. 解決Windows XP安裝ACDSee6.0之怪現(xiàn)象8. Linux 5.10.10正式發(fā)布:修復(fù) NULL 指針不正確等9. win7任務(wù)欄風(fēng)格更改教程10. 處理win10全面戰(zhàn)爭(zhēng)幕府將軍2打不開(kāi)的方法

網(wǎng)公網(wǎng)安備