You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

89 lines
3.2 KiB
C#

2 years ago
using Khd.Core.EntityFramework;
using Khd.Core.Wcs;
using Khd.Core.Wcs.Global;
using Masuit.Tools.Logging;
using Microsoft.EntityFrameworkCore;
2 years ago
using Microsoft.Extensions.Configuration;
using Microsoft.Extensions.DependencyInjection;
2 years ago
using Microsoft.Extensions.Hosting;
2 years ago
internal class Program
{
public static IHost _host;
private static void Main(string[] args)
{
init(); //初始化加载配置文件
AppDomain.CurrentDomain.UnhandledException += GlobalExceptionHandler; //全局异常捕获
try
{
bool ret;
System.Threading.Mutex mutex = new System.Threading.Mutex(true, "服务端", out ret);
if (ret)
{
IHost host = CreateHostBuilder(args).Build();
_host = host;
Console.WriteLine("系统启动开始 :" + DateTime.Now);
2 years ago
LogManager.Info("系统启动开始 ");
2 years ago
MainCentralControl main = new MainCentralControl(host);
main.Start();
//while (true)
//{
// Console.ReadLine();
//}
mutex.ReleaseMutex(); // 释放 Mutex
2 years ago
LogManager.Info("系统启动成功");
2 years ago
}
else
{
Console.Write("系统重复开启,请先关闭之前窗口");
}
}
catch (Exception ex)
{
Console.Write("系统启动异常:" + ex.Message + "\n" + ex.StackTrace);
}
}
private static void GlobalExceptionHandler(object sender, UnhandledExceptionEventArgs e)
{
Exception exception = e.ExceptionObject as Exception;
if (exception != null)
{
Console.WriteLine("全局异常捕获:");
Console.WriteLine(exception.Message);
Console.WriteLine(exception.StackTrace);
LogManager.Info("全局异常捕获:" + exception.Message);
}
else
{
Console.WriteLine("未知异常捕获:");
Console.WriteLine(e.ExceptionObject);
LogManager.Info("未知异常捕获:" + e.ExceptionObject);
}
}
/// <summary>
/// 初始化加载配置文件
/// </summary>
private static void init()
{
IConfigurationRoot configuration = new ConfigurationBuilder()
2 years ago
.SetBasePath(AppDomain.CurrentDomain.BaseDirectory)
.AddJsonFile("appsettings.json")
.Build();
2 years ago
2 years ago
StaticData.PlcConfigs = configuration.GetSection("PlcConfigs").Get<List<PlcConfig>>();
2 years ago
ConnectionStrings.ConnectionString = configuration["ConnectionStrings:DefaultConnection"].ToString();
}
static IHostBuilder CreateHostBuilder(string[] args) =>
Host.CreateDefaultBuilder(args)
.ConfigureServices((_, services) =>
{
//services.AddDbContext<DefaultDbContext>(options =>
// options.UseSqlServer(ConnectionStrings.ConnectionString));
services.AddDbContext<DefaultDbContext>(options =>
options.UseMySql(ConnectionStrings.ConnectionString, new MySqlServerVersion(new Version(8, 0, 31))));
});
}