首页 > 编程语言 >Taurus.MVC 微服务框架 入门开发教程:项目部署:1、微服务应用程序常规部署实现多开,节点扩容。

Taurus.MVC 微服务框架 入门开发教程:项目部署:1、微服务应用程序常规部署实现多开,节点扩容。

时间:2022-08-15 17:49:01浏览次数:82  
标签:教程 部署 端口 Taurus host MVC runUrl

系列目录:

本系列分为项目集成、项目部署、架构演进三个方向,后续会根据情况调整文章目录。

本系列第一篇:Taurus.MVC V3.0.3 微服务开源框架发布:让.NET 架构在大并发的演进过程更简单。

Taurus.MVC 微服务框架 入门开发教程:项目集成:1、服务端:注册中心、网关。

Taurus.MVC 微服务框架 入门开发教程:项目集成:2、客户端:ASP.NET(C#)编程语言项目集成:应用中心。

Taurus.MVC 微服务框架 入门开发教程:项目集成:3、客户端:其它编程语言项目集成:应用中心。

Taurus.MVC 微服务框架 入门开发教程:项目集成:4、默认安全认证与自定义安全认证。

Taurus.MVC 微服务框架 入门开发教程:项目部署:1、微服务应用程序常规部署实现多开,节点扩容。

Taurus.MVC 微服务框架 入门开发教程:项目部署:2、微服务应用程序Docker部署实现多开。

Taurus.MVC 微服务框架 入门开发教程:项目部署:3、微服务应用程序发布到Docker部署(上)。

Taurus.MVC 微服务框架 入门开发教程:项目部署:4、微服务应用程序发布到Docker部署(下)。

Taurus.MVC 微服务框架 入门开发教程:项目部署:5、微服务应用程序版本升级。

Taurus.MVC 微服务框架 入门开发教程:项目部署:6、让Kestrel支持绑定多个域名转发。

Taurus.MVC 微服务框架 入门开发教程:架构演进:1、从单应用程序简单过渡到负载均衡。

Taurus.MVC 微服务框架 入门开发教程:架构演进:2、负载均到模块拆分负载。

Taurus.MVC 微服务框架 入门开发教程:架构演进:3、模块拆分负载到多级负载均衡。

前言:

最近在写相关微服务教程时发现,要构建负载均衡,如果不做点其它处理:

对于同一台主机而言上的ASP.NET Core 应用程序而言,需要通过复制程序,才能运行多份应用运行。

对于ASP.NET Core发布的项目:

1、默认是绑定约定好的端口,因此程序无法多开。

2、将绑定端口设置为0,即随机端口,让程序允许多开。

不过仅是多开,还不够。

因为对于微服务程序,需要在程序启动时,自动将自身的访问地址告诉注册中心。

默认的随机端口,无法知晓自己的运行地址,便无法发送到注册中心去。

因此,需要提前获知运行的地址(给MicroService.App.RunUrl赋值,便于发送到注册中心)。

 

通过小小思考,可以先获取随机可用端口,再指定该端口,即可解决这个个问题。

下面看具体的实现:

1、修改配置文件,使用随机端口:

这里设置启动端口号,和绑定的端口号都为0,0即随机。

注册中心地址是固定的,因此直接写。

{
  "AppSettings": {
  
    "MicroService.Client.Name": "*",//注册所有模块
    "MicroService.Client.RegUrl": "http://192.168.188.95:9999",//注册中心的地址,这是固定的
"MicroService.App.RunUrl": "http://localhost:0",//设置当前运行的访问地址的随机端口0,代码运行时再替换该值 "Host": "http://*:0"//监听端口为随机,代码运行时再替换该值 } }

接下来,需要在启动程序里,把0这个随机端口提前修改为可用端口,并做端口替换。

2、修改启动代码:.NET5、NET6、NET7...系列的:Program.cs

using Microsoft.AspNetCore.Server.Kestrel.Core;
using System.Net;
using System.Net.Sockets;

var builder = WebApplication.CreateBuilder(args);
string host = CYQ.Data.AppConfig.GetApp("Host");
string runUrl = Taurus.Core.MicroService.Config.AppRunUrl;
if (host.Contains(":0"))//随机端口
{
    TcpListener tl = new TcpListener(IPAddress.Any, 0);
    tl.Start();
    int port = ((IPEndPoint)tl.LocalEndpoint).Port;//获取随机可用端口
    tl.Stop();
    host = host.Replace(":0", ":" + port);//替换监听端口号
    if (runUrl.Contains(":0"))
    {
        Taurus.Core.MicroService.Config.AppRunUrl = runUrl.Replace(":0", ":" + port);//替换设置启动路径的端口号
    }
}
builder.WebHost.UseUrls(host);
builder.Services.AddHttpContext();
builder.Services.Configure<KestrelServerOptions>(x => x.AllowSynchronousIO = true).Configure<IISServerOptions>(x => x.AllowSynchronousIO = true);

var app = builder.Build();
app.UseHttpContext();
app.UseTaurusMvc(app.Environment);
app.Run();

这里,先产生可用的监听端口,再用这个端口号赋值后再监听。

3、修改启动代码:ASP.NET Core 2.N到3.N系列:Program.cs

代码是一样的:

using System;
using Microsoft.AspNetCore;
using Microsoft.AspNetCore.Hosting;
using CYQ.Data;
using System.Net.Sockets;
using System.Net;
using Taurus.Core;

namespace Taurus.View
{
    public class Program
    {
        public static void Main(string[] args)
        {

            BuildWebHost(args).Run();

        }

        public static IWebHost BuildWebHost(string[] args) =>
            WebHost.CreateDefaultBuilder(args)
                .UseStartup<Startup>()
                .UseUrls(GetUrl())
                .Build();
        public static string GetUrl()
        {
            string host = AppConfig.GetApp("Host");
            string runUrl = MicroService.Config.AppRunUrl;
            if (host.Contains(":0"))//随机端口
            {
                TcpListener tl = new TcpListener(IPAddress.Any, 0);
                tl.Start();
                int port = ((IPEndPoint)tl.LocalEndpoint).Port;//获取随机可用端口
                tl.Stop();
                host = host.Replace(":0", ":" + port);
                if (runUrl.Contains(":0"))
                {
                    MicroService.Config.AppRunUrl = runUrl.Replace(":0", ":" + port);//设置启动路径
                }
            }
            return host;
        }
    }
}

4、修改启动代码:再优化一下,实现跨主机:

在上面的配置中:

    "MicroService.App.RunUrl": "http://localhost:0",//设置当前运行的访问地址的随机端口0,代码运行时再替换该值

如果指定了localhost,默认情况下,仅适合单主机运行,无法跨主机直接运行。

因此,代码可以再优化一下,把localhost替换成本机局域网IP:

public static string GetUrl()
        {
            string host = AppConfig.GetApp("Host");
            string runUrl = MicroService.Config.AppRunUrl;
            if (host.Contains(":0"))//随机端口
            {
                TcpListener tl = new TcpListener(IPAddress.Any, 0);
                tl.Start();
                int port = ((IPEndPoint)tl.LocalEndpoint).Port;//获取随机可用端口
                tl.Stop();
                host = host.Replace(":0", ":" + port);
                if (runUrl.Contains(":0"))
                {
                    runUrl = runUrl.Replace(":0", ":" + port);//替换启动路径
                }
                if (runUrl.Contains("localhost"))//替换成内网IP
                {
                    System.Net.IPAddress[] addressList = Dns.GetHostEntry(Dns.GetHostName()).AddressList;
                    foreach (var address in addressList)
                    {
                        if (!address.ToString().Contains(":"))
                        {
                            runUrl = runUrl.Replace("localhost", address.ToString());//替换启动路径
                            break;
                        }
                    }

                }
                MicroService.Config.AppRunUrl = runUrl;

            }
            
            return host;
        }

总结:

通过以上配置,发布后的应用程序,可以在任何主机上实现多开N次,就可以增加N个节点。

随时随地实现节点的动态新增扩容。

标签:教程,部署,端口,Taurus,host,MVC,runUrl
From: https://www.cnblogs.com/cyq1162/p/16554403.html

相关文章

  • Dt804ls国标部署说明
    Dt804ls国标部署说明正常安装ubuntu20.04的系统然后依次安装sudodpkg-icontainerd.io_1.4.12-1_amd64.debsudodpkg-idocker-ce-cli_20.10.12_3-0_ubuntu-focal_amd6......
  • linux 使用docker 容器部署sqlserver2019
    前提安装完docker,安装完docker-composedocker-compose.ymlversion:"2"services:sqlserver-2019:restart:always#容器名称container_name:sqlser......
  • MVC_jsp演变历史以及MVC详解
    MVC_jsp演变历史jsp演变历史1、早期只有servlet,只能使用response输出标签数据,非常麻烦2、后来有jsp,简化了Servlet的开发,如果过度使用jsp,在jsp中即写大量的java......
  • 使用MockMvcResultMatchers对返回值为List的接口进行断言
    在使用MockMvc进行单元测试的时候,我们经常使用andExpect(MockMvcResultMatchers.jsonPath(jsonKeyName).isNotEmpty())对Controller返回的结果进行断言,用以验证返回结果的......
  • MVC_jsp演变历史和详解
    MVC_jsp演变历史MVC: 开发模式(ModelViewController)1.jsp演变历史1.早期只有Servlet,只能使用response输出标签数据,非常麻烦2.后来又jsp,简化了Se......
  • activemq 安装部署
             ......
  • SpringMVC笔记
    SrpingMvcSSM:Spring+SpringMvc+MybatisMvc三层架构狂神说SSM框架系列笔记链接:http://dwz.date/ac271、回顾MVC1.1、什么是MVCMVC是模型(Model)、视图(View)、......
  • Nodemon 如何实时监听 TypeScript 项目下的文件并热部署?
    首先你的项目要安装ts-node和nodemon:npmi-Dts-nodenodemon在package.json文件中配置运行脚本:"dev":"nodemon--watchsrc/**/*.ts--exec\\\"ts-node\\\"src/ma......
  • podman的部署与应用
    目录部署podmanpodman的应用部署podman安装podman[root@node1~]#yum-yinstallpodmanLastmetadataexpirationcheck:8:06:25agoonSun14Aug202211:58:39......
  • Taurus.MVC WebAPI 入门开发教程8:WebAPI文档与自动化测试。
    系列目录1、Taurus.MVCWebAPI 入门开发教程1:框架下载环境配置与运行。2、Taurus.MVCWebAPI入门开发教程2:添加控制器输出HelloWorld。3、Taurus.MVCWebAPI入门开......