百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术文章 > 正文

基于Net6的开源通用管理平台,支持Saas模式

ccwgpt 2024-10-26 08:39 39 浏览 0 评论

Admin.NET简介

  • 基于.NET 6实现的通用管理平台。整合最新技术,模块插件式开发前后端分离,开箱即用;
  • 后台基于Furion框架,前端基于vue2;
  • 集成EF Core、多租户、缓存、数据校验、鉴权、事件总线、动态API、通讯、远程请求、任务调度、gRPC等众多黑科技;
  • 核心模块包括:用户、角色、职位、组织机构、菜单、字典、日志、应用管理、文件管理、定时任务等功能;
  • 代码简洁、易扩展!

模块/插件化开发

  • 按照 Furion 框架脚手架或者本框架脚手架初始化工程;
  • 创建自己业务的 Dll 插件库工程,引用 Furion.Extras.Admin.NET 包,编写自己的业务代码包括实体、服务等;
  • 在 XXX.Web.Entry 层里面的 appsettings.json 配置此插件 Dll 的路径;
  • 此时框架和自己业务实体可以同时做数据迁移,耦合度最低。也可以自行将数据库分系统库、业务库等;
  • 将自己业务前端代码包括view和api文件复制到前端工程相应目录即可。

多租户简介

框架目前采用基于共享数据库TenantId的方式实现,后期可无缝迁移转换到基于多库或者Schema模式。

  • 平台超管对租户进行增删改查操作,对各租户进行权限(菜单)的分配;
  • 租户管理员根据平台分配的权限再对本租户内用户进一步权限划分;
  • 针对新开发的业务功能,平台超管可以针对性分配给各租户(比如某租户购买后才有此功能菜单等)

分层说明

├─Admin.NET.Application             ->业务应用层,在此写您具体业务代码
├─Admin.NET.Core                    ->框架核心层,实体类
├─Admin.NET.Database.Migrations     ->架构维护层,主要存放迁移中间文件
├─Admin.NET.EntityFramework.Core    ->EF Core配置层,主要配置数据库及相关
├─Admin.NET.Web.Core                ->Web核心层,主要是服务注册及鉴权
├─Admin.NET.Web.Entry               ->Web入口层/启动层,可任意更换
├─Furion.Extras.Admin.NET           ->封装的框架核心层

快速安装

  1. 使用git下载源码
git clone https://gitee.com/zuohuaijun/Admin.NET.git

源代码结构如下图所示,backend文件夹为服务端程序源码,frontend文件夹为前端程序源码。

2.数据库初始化

项目默认是SqlLite数据库,使用其他数据库可通过基于EF Core的CodeFirst初始化,这里我们采用MySql5.7来进行初始化。

使用vs2022打开服务端源码,Admin.NET.EntityFramework.Core项目下修改dbsettings.Development.json配置文件下的DefaultConnection(业务数据库)和MultiTenantConnection(租户数据库)两项数据库连接字符串和账户密码。

修改DefaultDbContext.cs(业务数据库上下文)和MultiTenantDbContext.cs(租户数据库上下文)中的DbProvider为MySql,并使用nuget安装对应的包:Pomelo.EntityFrameworkCore.MySql。

设置项目启动项为Admin.NET.Web.Entry,默认项目为Admin.NET.Database.Migrations

手动创建两个空数据库并依次执行如下命令初始化数据库,等待初始化成功。

    Add-Migration Init -Context DefaultDbContext
    update-database Init -Context DefaultDbContext 
    Add-Migration Init -Context MultiTenantDbContext
    update-database Init -Context MultiTenantDbContext

3.服务端运行

编译Admin.NET.Web.Entry项目,成功后进入编译程序,执行命令运行服务端(前端默认连接的服务端端口为5566)。

dotnet Admin.NET.Web.Entry.dll --urls="http://*:5566"

4.前端编译运行

前端默认端口为81

npm install
npm run start

启动成功后访问http://localhost:81

  • 超级管理员:superAdmin
  • 系统管理员:admin
  • 普通用户:zuohuaijun
  • 以上默认密码:123456

系统通用的功能主要有

  1. 主控面板、控制台页面,可进行工作台,分析页,统计等功能的展示。
  2. 用户管理、对企业用户和系统管理员用户的维护,可绑定用户职务,机构,角色,数据权限等。
  3. 应用管理、通过应用来控制不同维度的菜单展示。
  4. 机构管理、公司组织架构维护,支持多层级结构的树形结构。
  5. 职位管理、用户职务管理,职务可作为用户的一个标签,职务目前没有和权限等其他功能挂钩。
  6. 菜单管理、菜单目录,菜单,和按钮的维护是权限控制的基本单位。
  7. 角色管理、角色绑定菜单后,可限制相关角色的人员登录系统的功能范围。角色也可以绑定数据授权范围。
  8. 字典管理、系统内各种类型的维护。
  9. 访问日志、用户的登录和退出日志的查看和管理。

10. 操作日志、用户操作业务的日志的查看和管理。

11. 服务监控、服务器的运行状态,CPU、内存、网络等信息数据的查看。

12. 在线用户、当前系统在线用户的查看。

13. 公告的管理、系统的公告的管理。

14. 文件管理、文件的上传下载查看等操作,文件可使用本地存储,阿里云oss,腾讯cos接入,支持拓展。

15. 定时任务、定时任务的维护,通过cron表达式控制任务的执行频率。

16. 系统配置、系统运行的参数的维护,参数的配置与系统运行机制息息相关。

17. 邮件发送功能。

18. 短信发送、短信发送功能,可使用阿里云sms,腾讯云sms,支持拓展。

Admin.NET 遵循 Apache-2.0 开源协议。

相关推荐

十分钟让你学会LNMP架构负载均衡(impala负载均衡)

业务架构、应用架构、数据架构和技术架构一、几个基本概念1、pv值pv值(pageviews):页面的浏览量概念:一个网站的所有页面,在一天内,被浏览的总次数。(大型网站通常是上千万的级别)2、u...

AGV仓储机器人调度系统架构(agv物流机器人)

系统架构层次划分采用分层模块化设计,分为以下五层:1.1用户接口层功能:提供人机交互界面(Web/桌面端),支持任务下发、实时监控、数据可视化和报警管理。模块:任务管理面板:接收订单(如拣货、...

远程热部署在美团的落地实践(远程热点是什么意思)

Sonic是美团内部研发设计的一款用于热部署的IDEA插件,本文其实现原理及落地的一些技术细节。在阅读本文之前,建议大家先熟悉一下Spring源码、SpringMVC源码、SpringBoot...

springboot搭建xxl-job(分布式任务调度系统)

一、部署xxl-job服务端下载xxl-job源码:https://gitee.com/xuxueli0323/xxl-job二、导入项目、创建xxl_job数据库、修改配置文件为自己的数据库三、启动...

大模型:使用vLLM和Ray分布式部署推理应用

一、vLLM:面向大模型的高效推理框架1.核心特点专为推理优化:专注于大模型(如GPT-3、LLaMA)的高吞吐量、低延迟推理。关键技术:PagedAttention:类似操作系统内存分页管理,将K...

国产开源之光【分布式工作流调度系统】:DolphinScheduler

DolphinScheduler是一个开源的分布式工作流调度系统,旨在帮助用户以可靠、高效和可扩展的方式管理和调度大规模的数据处理工作流。它支持以图形化方式定义和管理工作流,提供了丰富的调度功能和监控...

简单可靠高效的分布式任务队列系统

#记录我的2024#大家好,又见面了,我是GitHub精选君!背景介绍在系统访问量逐渐增大,高并发、分布式系统成为了企业技术架构升级的必由之路。在这样的背景下,异步任务队列扮演着至关重要的角色,...

虚拟服务器之间如何分布式运行?(虚拟服务器部署)

  在云计算和虚拟化技术快速发展的今天,传统“单机单任务”的服务器架构早已难以满足现代业务对高并发、高可用、弹性伸缩和容错容灾的严苛要求。分布式系统应运而生,并成为支撑各类互联网平台、企业信息系统和A...

一文掌握 XXL-Job 的 6 大核心组件

XXL-Job是一个分布式任务调度平台,其核心组件主要包括以下部分,各组件相互协作实现高效的任务调度与管理:1.调度注册中心(RegistryCenter)作用:负责管理调度器(Schedule...

京东大佬问我,SpringBoot中如何做延迟队列?单机与分布式如何做?

京东大佬问我,SpringBoot中如何做延迟队列?单机如何做?分布式如何做呢?并给出案例与代码分析。嗯,用户问的是在SpringBoot中如何实现延迟队列,单机和分布式环境下分别怎么做。这个问题其实...

企业级项目组件选型(一)分布式任务调度平台

官网地址:https://www.xuxueli.com/xxl-job/能力介绍架构图安全性为提升系统安全性,调度中心和执行器进行安全性校验,双方AccessToken匹配才允许通讯;调度中心和执...

python多进程的分布式任务调度应用场景及示例

多进程的分布式任务调度可以应用于以下场景:分布式爬虫:importmultiprocessingimportrequestsdefcrawl(url):response=re...

SpringBoot整合ElasticJob实现分布式任务调度

介绍ElasticJob是面向互联网生态和海量任务的分布式调度解决方案,由两个相互独立的子项目ElasticJob-Lite和ElasticJob-Cloud组成。它通过弹性调度、资源管控、...

分布式可视化 DAG 任务调度系统 Taier 的整体流程分析

Taier作为袋鼠云的开源项目之一,是一个分布式可视化的DAG任务调度系统。旨在降低ETL开发成本,提高大数据平台稳定性,让大数据开发人员可以在Taier直接进行业务逻辑的开发,而不用关...

SpringBoot任务调度:@Scheduled与TaskExecutor全面解析

一、任务调度基础概念1.1什么是任务调度任务调度是指按照预定的时间计划或特定条件自动执行任务的过程。在现代应用开发中,任务调度扮演着至关重要的角色,它使得开发者能够自动化处理周期性任务、定时任务和异...

取消回复欢迎 发表评论: