.Net Core WebApi(二)在Windows服务器上部署

  上一篇学习到了如何简单的创建.Net Core Api和Swagger使用,既然写了接口,那么就需要部署到服务器上才能够正式使用。服务器主要用到了两种系统,Windows和Linux,.Net和Windows都是属于微软爸爸的,那么这一篇就先从部署到Windows服务器系统开始吧。

一、准备服务器

  首先,我们需要一台装了Windows Server的云服务器,但是我没有。那么,到这里就结束了。(╮( ̄▽ ̄)╭开玩笑的)

  言归正传,我们没有云服务器怎么办,那当然是要买一台了。有人会说有点贵,确实,便宜的一个月都好几十,不过那是在连续不间断使用的情况下的,既然我们是学习那么就不需要一直用,所以我们只需要买【按量计费】的就行了。

  到阿里云购买服务器却发现:

  嗯,要100元才能买,果断转战其他平台。

  然后发现腾讯云没有这个限制,果然腾讯亲民啊。(疯狂暗示)

 

  经过我一系列的操作,发现成都地区的最便宜,一个小时只需要2毛钱,比去网吧上网便宜多了。(不要告诉我你买不起,抢QQ红包都能抢够,更何况是花在学习上的钱,那叫投资(~ ̄▽ ̄)~ )

  按照图下,选择【按量计费】,选地区(我用的最便宜的成都地区),选机型(最便宜的,够用)。

.Net Core WebApi(二)在Windows服务器上部署_第1张图片

  选择公共镜像,【Windows Server 2012 R2 数据中心版 64位中文版】,当然如果你英语好,也可以选英文版的。

  系统盘最低50GB,不用改了。

  免费分配独立公网IP(重要,必须√上,不然就失去了主要的意义了)

  选择【按带宽计费】(因为你保不准用多少流量)

.Net Core WebApi(二)在Windows服务器上部署_第2张图片

  下一步设置主机,选择【新建安全组】,然后下拉框选【放通全部端口】(因为我们是学习临时使用,不用在意什么安全性的问题了)

.Net Core WebApi(二)在Windows服务器上部署_第3张图片

  然后【设置密码】,这个不用我多说了吧。

  【定时销毁】这个要看你用不用,你也可以选择用完之后手动销毁,但是如果你忘记的话,会按时间继续扣钱的。(定时销毁一定要设置好时间,要不然你会发现用着用着突然就没了)

.Net Core WebApi(二)在Windows服务器上部署_第4张图片

  确认信息,没啥说的,开通。

.Net Core WebApi(二)在Windows服务器上部署_第5张图片

  两毛钱一小时,随便你折腾,是不是很划算。

  开通后自动跳转到控制台实例页面,可以看到我们的公网IP了。

.Net Core WebApi(二)在Windows服务器上部署_第6张图片

  然后我们进行远程桌面连接。

.Net Core WebApi(二)在Windows服务器上部署_第7张图片

  如果出现无法连接的错误。

.Net Core WebApi(二)在Windows服务器上部署_第8张图片

  回到我们的控制台,在操作列中点击【登录】。 

  弹出提示微信扫码操作,打开微信扫码,确定。

  确定之后,弹出登录Windows实例窗口,用其他方式(VNC)点击【立即登录】。

.Net Core WebApi(二)在Windows服务器上部署_第9张图片

  弹出新网页,提示按Ctrl+Alt+Delete登录。然后你直接在键盘上按Ctrl+Alt+Delete,却发现打开了你自己电脑的安全窗口╮( ̄▽ ̄)╭,其实是要点发送远程命令来操作的。

.Net Core WebApi(二)在Windows服务器上部署_第10张图片

  右上角打开【发送远程命令】,点击【Ctrl-Alt-Delete】登录。

.Net Core WebApi(二)在Windows服务器上部署_第11张图片

  输入账号密码登录之后,打开系统属性,把【仅允许运行使用网络网络级别身份验证的远程桌面的计算机连接】的勾去掉。

.Net Core WebApi(二)在Windows服务器上部署_第12张图片

  之后退出页面,重新进行远程桌面连接,就可以了。

  输入用户名密码登录进去,搞定。

.Net Core WebApi(二)在Windows服务器上部署_第13张图片

  好了,云服务买好了,接下来该进入我们的正题了。

二、环境搭建及发布

  首先,我们需要在服务器上下载.NET Core Runtime,下面附上链接。

  https://dotnet.microsoft.com/download/dotnet-core

  选择我们的.NET Core版本,我的是2.2的。

.Net Core WebApi(二)在Windows服务器上部署_第14张图片

  如图所示,下载最新的。

.Net Core WebApi(二)在Windows服务器上部署_第15张图片

  下载完成后,执行exe文件,勾选同意安装,然后等待安装完成就行了。

.Net Core WebApi(二)在Windows服务器上部署_第16张图片

  然后回到我们之前的项目中,右键项目,选择发布。

.Net Core WebApi(二)在Windows服务器上部署_第17张图片

  选取发布目标,选择文件夹,选择路径(我用的默认路径),然后点击发布。

.Net Core WebApi(二)在Windows服务器上部署_第18张图片

  然后找到你发布的文件夹,拷贝该文件夹到服务器上。

.Net Core WebApi(二)在Windows服务器上部署_第19张图片

  拷贝到服务器上,重命名为项目名称,便于区分。

.Net Core WebApi(二)在Windows服务器上部署_第20张图片

  内容如下。

.Net Core WebApi(二)在Windows服务器上部署_第21张图片

三、程序部署

  我这里有两种部署方法,第一种是执行命令行运行,第二种是通过IIS部署。推荐使用第二种常用的IIS部署方式,第一种作为了解使用,当然你要用也是可以的。

第一种方式执行命令行:

  按住Shift键不送,鼠标右键空白处,弹出的右键菜单有【在此处打开命令窗口】,点击它打开命名窗口。

.Net Core WebApi(二)在Windows服务器上部署_第22张图片

  会发现我们cmd的路径直接在该文件夹里,然后执行下面的命令(FirstApi是你的项目名,也就是上图中FirstApi.dll文件)。

  dotnet FirstApi.dll

  会发现有一个地址,监听本地的5000端口。

.Net Core WebApi(二)在Windows服务器上部署_第23张图片

  然后输入该地址就能访问了。诶,怎么内部错误了 o(゚Д゚)っ!

.Net Core WebApi(二)在Windows服务器上部署_第24张图片

  看一下我们的命令窗口,原来是缺少文件。这个文件是Swagger生成的xml注释文件,vs发布的时候没有包含在里面,所以我们要手动将该文件拷过来。

.Net Core WebApi(二)在Windows服务器上部署_第25张图片

  找到该xml文件拷贝到服务器文件夹下。

.Net Core WebApi(二)在Windows服务器上部署_第26张图片

  重新运行,访问地址就能看到了。但这个是localhost本地的,我们想要在外网访问需要改一下代码(当然你也可以用反向代理)。

.Net Core WebApi(二)在Windows服务器上部署_第27张图片 

  打开我们的项目,点击Program文件。

.Net Core WebApi(二)在Windows服务器上部署_第28张图片

  在箭头所指的位置加入图中的代码,5555是你自己指定的端口。

.Net Core WebApi(二)在Windows服务器上部署_第29张图片

  加入后Program类文件代码如下。

using System;
using System.Collections.Generic;
using System.IO;
using System.Linq;
using System.Threading.Tasks;
using Microsoft.AspNetCore;
using Microsoft.AspNetCore.Hosting;
using Microsoft.Extensions.Configuration;
using Microsoft.Extensions.Logging;

namespace FirstApi
{
    public class Program
    {
        public static void Main(string[] args)
        {
            CreateWebHostBuilder(args).Build().Run();
        }

        public static IWebHostBuilder CreateWebHostBuilder(string[] args) =>
            WebHost.CreateDefaultBuilder(args).UseUrls("http://*:5555")
                .UseStartup();
    }
}

  然后重新生成将dll文件拷贝到服务器上覆盖,按照之前的方式运行。

.Net Core WebApi(二)在Windows服务器上部署_第30张图片

  输入在自己电脑上输入公网ip加上端口,就能成功访问了。

.Net Core WebApi(二)在Windows服务器上部署_第31张图片

  我们可以测试一下。执行第一个试试,成功返回结果。

.Net Core WebApi(二)在Windows服务器上部署_第32张图片

  接下来进入我们的第二种方法。

第二种方式通过IIS部署:

  首先,打开服务器管理器。(注:因为我是紧跟着第一个方式操作的,请保证已将xml文件拷到服务器文件夹下,不然部署完成了也会出错)

.Net Core WebApi(二)在Windows服务器上部署_第33张图片

  在管理里点击【添加角色和功能】

.Net Core WebApi(二)在Windows服务器上部署_第34张图片

  到选择服务器角色,勾选【Web服务器(IIS)】。

.Net Core WebApi(二)在Windows服务器上部署_第35张图片

  然后选择角色服务器,根据需求勾选。(我都勾上了,为了避免出现问题,反正用不用都先加上没多大坏处(~ ̄▽ ̄)~ )。

.Net Core WebApi(二)在Windows服务器上部署_第36张图片

  安装完成之后,打开我们的IIS管理器。

.Net Core WebApi(二)在Windows服务器上部署_第37张图片

  右键网站,选择添加网站。输入网站名称,选择文件路径,输入端口。

.Net Core WebApi(二)在Windows服务器上部署_第38张图片

  然后点击【应用程序池】,点开编辑我们刚刚创建的。

.Net Core WebApi(二)在Windows服务器上部署_第39张图片

  将.NET CLR版本的下拉框选择为【无托管代码】,确定。

.Net Core WebApi(二)在Windows服务器上部署_第40张图片

  然后打开网站,又报错了(ŎдŎ;),查了一下是缺少了【AspNetCoreModule】托管模块。

.Net Core WebApi(二)在Windows服务器上部署_第41张图片

  选择根节点的服务器,打开【模块】这一项。

.Net Core WebApi(二)在Windows服务器上部署_第42张图片

  发现没有找到叫做【AspNetCoreModule】的托管模块,emmmmm好像是漏掉了。

.Net Core WebApi(二)在Windows服务器上部署_第43张图片

  重新打开我们下载的安装程序,点击【Repair】重新安装。

.Net Core WebApi(二)在Windows服务器上部署_第44张图片

  等待重新安装完成之后,重启IIS管理器,再次打开【模块】,发现已经有了。

.Net Core WebApi(二)在Windows服务器上部署_第45张图片

  然后我们访问网站,成功出现Swagger文档页面,大功告成。

.Net Core WebApi(二)在Windows服务器上部署_第46张图片

  OK,.Net Core WebApi在Windows服务器上部署到这里就告一段落了,相信各位也会了吧,觉得不错的小伙伴可以在右边→点一下推荐(〃^ω^) ,不足的地方也请大家提出来,多多关照。接下来是在Linux服务器上的部署,其实是和上面的第一种方式差不多,但是为了区分,单独写一篇(其实是为了水一篇)来记录如何搭建,想要了解的小伙伴可以关注我哟⁄(⁄⁄•⁄ω⁄•⁄⁄)⁄。

你可能感兴趣的:(.Net Core WebApi(二)在Windows服务器上部署)