站点平台技术架构
系统架构部署思维导图
平台模块分配:
1.账号模块
2.权限模块
3.站点模块
4.配置模块
5.系统升级
6.日志模块
一、前期工作
1.系统保持一致性方案:
GIT版本控制:通过总控端向租户端发送一个更新同步请求,租户端收到请求后执行GIT PULL 命令,执行完成命令后会进行获取当前版本指定的SQL文件,进行同步更新数据库结构。
具体实现逻辑:
(1)前端页面:
点击“系统升级”按钮,同时生成系统升级日志,并且向每个租户的前端接口发送一个请求。界面大概如下图所示:
(2)后端逻辑:
1、向租户前端接口发送一个系统升级的请求(若请求的站点过多,可能导致超时的话,则使用队列方式进行执行)
2、租户接口接受到请求之后PHP程序使用exce在项目的根目录执行git pull命令。
3、程序等待git pull 命令执行完毕,执行完毕后检测是否包含有update.sql文件,若有update.sql文件则直接更新改文件里面的SQL语句。
4、完成系统升级后进行将结果返回给总控后台,然后将结果入库到日志当中。若中间系统更新失败,则捕获系统的报错信息,并将报错的结果返回给总控后台并将报错信息记录到对应的日志当中。
2.站点权限配置方案
思维导图
(1)新增/编辑账号
包含字段:用户名、昵称(中文/英文)、密码(MD5)、邮箱、电话、性别、状态、站点ID。
(2)新增/编辑角色组
包含字段:名称、描述、创建者、创建时间、编辑时间、修改者、状态、权限ID
(3)分配站点
描述:一个账号可以分配多个站点。
(4)站点分配角色组
一个站点可以分配多个角色组
一、总控端新增/编辑账号、新增/编辑用户组、分配站点:
系统管理员从“总控后台登陆页面”进入到总控后台系统(后台包含) => 新增/编辑用户组和站点权限、新增/账号设置账号的用户组和可操作站点。
二、新增/编辑用户组: 给每个类型的用户组设置租户后台的可操作和界面权限。
说明:下图所示的站点权限是指租户后台的菜单权限等功能!
三、添加/编辑人员账号:在新增/编辑时给账户设置用户组、赋值此账号对应的可操作的站点ID,如下图所示:
四、登陆站点后台,站点后台页面显示已经给的权限页面和操作(若账号在登陆到未获得权限的站点时,系统会禁止登陆)!
总结:一套系统需要连接多个数据库,需要配置每个站点的对应的数据库信息!
三、
相关文章:
![](https://img-blog.csdnimg.cn/0efb4e158edd495fba3deaec5b1d7bfd.png)
站点平台技术架构
系统架构部署思维导图 平台模块分配: 1.账号模块 2.权限模块 3.站点模块 4.配置模块 5.系统升级 6.日志模块 一、前期工作 1.系统保持一致性方案: GIT版本控制:通过总控端向租户端发送一个更新同步请求,租户端收到请求后执行GI…...
![](https://www.ngui.cc/images/no-images.jpg)
一个以太坊合约的漏洞分析-重入攻击
请找出下列合约漏洞,并说明如何盗取ContractB 中的数字资产,并修复合约。中说明:ContractB 的contract_a接口为ContractA 地址 pragma solidity ^0.8.21; interface ContractA {function get_price() external view returns (uint256); }int…...
![](https://img-blog.csdnimg.cn/3ef362e7eeb548b28b095aad5fc605b1.png#pic_center)
测试先行:探索测试驱动开发的深层价值
引言 在软件开发的世界中,如何确保代码的质量和可维护性始终是一个核心议题。测试驱动开发(TDD)为此提供了一个答案。与传统的开发方法相比,TDD鼓励开发者从用户的角度出发,先定义期望的结果,再进行实际的开发。这种方法不仅可以确保代码满足预期的需求,还可以在整个开…...
![](https://img-blog.csdnimg.cn/6216dbe8c2e546d8920a9056aea74b72.png)
如何用Dockerfile部署LAMP架构
目录 构建LAMP镜像(Dockerfile) 第一步 创建工作目录 第二步 编写dockerfile文件 Dockerfile文件配置内容 第三步 编写网页执行文件 第四步 编写启动脚本 第五步 赋权并且构建镜像 第六步 检查镜像 第七步 创建容器 第八步 浏览器测试 构建LA…...
![](https://img-blog.csdnimg.cn/img_convert/8a05294d4f9c2df21962ad0801d5b77d.png)
基于量子粒子群算法(QPSO)优化LSTM的风电、负荷等时间序列预测算法(Matlab代码实现)
💥💥💞💞欢迎来到本博客❤️❤️💥💥 🏆博主优势:🌞🌞🌞博客内容尽量做到思维缜密,逻辑清晰,为了方便读者。 ⛳️座右铭&a…...
![](https://img-blog.csdnimg.cn/img_convert/a7f36c30afbe31d76ab53e1a03f1e66a.jpeg)
SQL Server软件安装包分享(附安装教程)
目录 一、软件简介 二、软件下载 一、软件简介 SQL Server是一种关系型数据库管理系统,由美国微软公司开发。它被设计用于存储、管理和查询数据,被广泛应用于企业级应用、数据仓库和电子商务等场景。 以下是SQL Server软件的主要特点和功能࿱…...
![](https://img-blog.csdnimg.cn/4d39480d603d425585cdabfdf0a02995.png)
基于Django的博客管理系统
1、克隆仓库https://gitee.com/lylinux/DjangoBlog.git 若失效:https://gitee.com/usutdzxy/DjangoBlog.git 2、环境安装 pip install -Ur requirements.txt3、修改djangoblog/setting.py 修改数据库配置,其他的步骤就按照官方文档。 DATABASES {def…...
![](https://img-blog.csdnimg.cn/f443be02668f4e01b6fc3e1a364ee664.png)
windows系统依赖环境一键安装
window系统程序依赖库,可以联系我获取15958139685 脚本代码如下,写到1. bat文件中,双击直接运行,等待安装完成即可 Scku.exe -AVC.exe /SILENT /COMPONENTS"icons,ext\reg\shellhere,assoc,assoc_sh" /dir%1\VC...
![](https://www.ngui.cc/images/no-images.jpg)
centos7安装nacos
解决 Nacos 国内下载速度缓慢的问题 方案 1. 选择相应的版本源码下载 1.1 依次点击 1、2、3 选中我们的最新稳定版本 1.4.0 1.2 点击下载 ZIP、或者 clone 也行,这里都可以 2. 本地编译 2.1 预备环境准备 2.2 解压编译 3. 启动验证 3.1 解压 3.2 启动服务器 3…...
![](https://img-blog.csdnimg.cn/f76a26371c0440e9906578cf6186d6d2.png)
【python】python智能停车场数据分析(代码+数据集)【独一无二】
👉博__主👈:米码收割机 👉技__能👈:C/Python语言 👉公众号👈:测试开发自动化【获取源码商业合作】 👉荣__誉👈:阿里云博客专家博主、5…...
![](https://www.ngui.cc/images/no-images.jpg)
如何使用Redis来防止穿透、击穿和雪崩问题
推荐阅读 AI文本 OCR识别最佳实践 AI Gamma一键生成PPT工具直达链接 玩转cloud Studio 在线编码神器 玩转 GPU AI绘画、AI讲话、翻译,GPU点亮AI想象空间 资源分享 史上最全文档AI绘画stablediffusion资料分享 AI绘画关于SD,MJ,GPT,SDXL百科全书 「java、python面试题」…...
![](https://img-blog.csdnimg.cn/dd39ff0126e84bd9ac1d3180c542cf2c.png)
以getPositionList为例,查找接口函数定义及接口数据格式定义
job-app-master/pages/index/index.vue中299行 async getPositionList(type refresh, pulldown false) {this.status 请求中;if (type refresh) {this.query.page 1;} else {this.query.page;}let res await this.$apis.getPositionList(this.query);if (res) {if (type …...
![](https://img-blog.csdnimg.cn/bd2d7051bec94e86a453fa5a780d310a.png)
一生一芯8——在github上添加ssh key
为在github上下载代码框架,这里在github上使用ssh key进行远程连接,方便代码拉取 参照博客https://blog.csdn.net/losthief/article/details/131502734 本机 系统ubuntu22.04 git 版本2.34.1 本人是第一次配置,没有遇到奇奇怪怪的错误&…...
![](https://www.ngui.cc/images/no-images.jpg)
2023年6月电子学会Python等级考试试卷(一级)答案解析
青少年软件编程(Python)等级考试试卷(一级) 一、单选题(共25题,共50分) 1. 可以对Python代码进行多行注释的是?( ) A. #...
![](https://img-blog.csdnimg.cn/d0130e3f83094af893909c41046ea90a.png)
ppt如何转pdf文档?用这个方法可将ppt转pdf
在现代社会中,PPT(幻灯片)已成为一种常见的演示工具,被广泛应用于学术、商务、培训等领域。然而,PPT文件的使用和分享存在一些问题,例如文件格式不兼容、内容修改易被篡改等。为了解决这些问题,将PPT转换为PDF格式已成…...
![](https://img-blog.csdnimg.cn/img_convert/31ccd95c2bedd8c38e0473ae05d78455.jpeg)
Hope.money:新兴DeFi项目如何重新定义稳定币生态的未来?
联储加息导致金融市场紧缩,Terra、3AC、FTX等知名中心化机构未能妥善应对而暴雷,并重创了整个加密货币市场,导致参与者损失惨重。这些事件揭示了中心化机构的局限,投资者对其资产掌控权的担忧愈发强烈。 自2018年首个DeFi协议Com…...
![](https://img-blog.csdnimg.cn/img_convert/afa6829765f84b6436572d32b837e78d.png)
使用 S3 生命周期精确管理对象生命周期
在亚马逊工作这些年,我发现 S3 的生命周期配置是管理对象生命周期的重要但复杂的工具。在这篇文章中,我将利用实战经验,深入剖析生命周期,从核心概念到实际应用。 亚马逊云科技开发者社区为开发者们提供全球的开发技术资源。这里有技术文档、开发案例、技术专栏、培训视频、活…...
![](https://img-blog.csdnimg.cn/240579a55b1748e698ea665c5e8ce1c6.png)
RocketMQ零拷贝原理
1 PageCache ●由内存中的物理page组成,其内容对应磁盘上的block。 ●page cache的大小是动态变化的。 ●backing store:cache缓存的存储设备。 ●一个page通常包含多个block,而block不一定是连续的。 1.1读Cache ●当内核发起一个读请求时&#x…...
![](https://www.ngui.cc/images/no-images.jpg)
HTML <tbody> 标签
实例 带有 thead、tbody 以及 tfoot 元素的 HTML 表格: <table border="1"><thead><tr><th>Month</th><th>Savings</th></tr></thead><tfoot><tr><td>Sum</td><td>$180<…...
![](https://img-blog.csdnimg.cn/42ea5131f1c0433a93e103ced6c3c1c2.png)
4.22 TCP 四次挥手,可以变成三次吗?
目录 为什么 TCP 挥手需要四次呢? 粗暴关闭 vs 优雅关闭 close函数 shotdown函数 什么情况会出现三次挥手? 什么是 TCP 延迟确认机制? TCP 序列号和确认号是如何变化的? 在一些情况下, TCP 四次挥手是可以变成 T…...
![](https://www.ngui.cc/images/no-images.jpg)
鲁棒性简述
鲁棒性(Robustness)是指系统或算法对于异常情况或不良条件的抵抗能力和适应能力。一个鲁棒性强的系统能够在面对异常、噪声、错误或意外情况时,仍能够保持高效的运行或输出可接受的结果。 鲁棒性是在设计和开发系统时要考虑的一个重要特性&am…...
![](https://www.ngui.cc/images/no-images.jpg)
复习leetcode
460. LFU 缓存 31. 下一个排列 322. 零钱兑换 662. 二叉树最大宽度 43. 字符串相乘...
![](https://www.ngui.cc/images/no-images.jpg)
从聚类(Clustering)到异常检测(Anomaly Detection):常用无监督学习方法的优缺点
一、引言 无监督学习是机器学习的一种重要方法,与有监督学习不同,它使用未标记的数据进行训练和模式发现。无监督学习在数据分析中扮演着重要的角色,能够从数据中发现隐藏的模式、结构和关联关系,为问题解决和决策提供有益的信息。…...
![](https://www.ngui.cc/images/no-images.jpg)
git仓库提交流程
拉取最新代码 cd dev-ops git拉取最新master代码: git checkout master git pull git checkout wangdachu_dev git merge master :wq 1、切换到文件的本地目录 cd ~/Desktop/aldaba-ops 2、修改用户名和邮箱 git config --global user.email "xxxxxxxxxx.…...
![](https://img-blog.csdnimg.cn/db927e49636540488bf39c1e9e008c0f.png)
层叠上下文、层叠顺序
原文合集地址如下,有需要的朋友可以关注 本文地址 什么是层叠上下文 层叠上下文(Stacking Context)是指在 HTML 和 CSS 中,用于控制和管理元素层叠顺序以及呈现的一种机制。在一个网页中,许多元素(例如文…...
![](https://www.ngui.cc/images/no-images.jpg)
postgres开发目录
目录 推荐 0.00001 Bruce的博客 0.00002 官方社区博客 0.00003 德哥的培训资料 0.00004 官方开发指南 0.00005 官方网站 0.00006 官方中国网站 0.00007 官方Wiki 0.00008 postgresql代码树 0.00009 gitee-学习资料1 0.00010 gitee-源码 安装与编译 1.00001git源码clone后进…...
![](https://img-blog.csdnimg.cn/img_convert/2867505c01686fb19b61e80390dfaa9d.png)
计算机视觉入门 6) 数据集增强(Data Augmentation)
系列文章目录 计算机视觉入门 1)卷积分类器计算机视觉入门 2)卷积和ReLU计算机视觉入门 3)最大池化计算机视觉入门 4)滑动窗口计算机视觉入门 5)自定义卷积网络计算机视觉入门 6) 数据集增强(D…...
![](https://img-blog.csdnimg.cn/64f5703877a6432ba32d66fb1307c167.png)
Python分享之redis(2)
Hash 操作 redis中的Hash 在内存中类似于一个name对应一个dic来存储 hset(name, key, value) #name对应的hash中设置一个键值对(不存在,则创建,否则,修改) r.hset("dic_name","a1","aa&quo…...
![](https://www.ngui.cc/images/no-images.jpg)
springboot aop方式实现敏感数据自动加解密
一、前言 在实际项目开发中,可能会涉及到一些敏感信息,那么我们就需要对这些敏感信息进行加密处理, 也就是脱敏,比如像手机号、身份证号等信息。如果我们只是在接口返回后再去做替换处理,则代码会显得非常冗余…...
![](https://img-blog.csdnimg.cn/6cc8e9b2601044958688ddf6324d5411.png)
RabbitMQ---work消息模型
1、work消息模型 工作队列或者竞争消费者模式 在第一篇教程中,我们编写了一个程序,从一个命名队列中发送并接受消息。在这里,我们将创建一个工作队列,在多个工作者之间分配耗时任务。 工作队列,又称任务队列。主要思…...
wordpress的qq邮件列表qq邮件列表订阅rss源地址怎么找/企业网络营销方案策划
快速开发平台,简单地说就是指那些不用编码或通过少量代码,就可以快速开发应用程序的平台。既可以降低开发人力成本,又可以缩短开发时间,从而实现企业降本增效的价值。应用快速开发(rapid application development, RAD…...
![](/images/no-images.jpg)
网站建设实训日记/北京全网营销推广公司
该楼层疑似违规已被系统折叠 隐藏此楼查看此楼sqlplus 运行脚本prvtlmpg.plb 报错,请问各位大神有什么解决方法SQL> prvtlmpg.plbOracle GoldenGate Workaround prvtlmpgThis script provides a temporary workaround for bug 17030189.It is strongly recommend…...
![](/images/no-images.jpg)
2010网站建设管理/优化设计
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid6396 假设k为5,那么开5个数组用来分别存放每头怪兽对应的五个防御力 用五个指针去从头开始遍历,如果当前值小于对应的攻击力,就判断一下这头怪兽的五个值是不是都小于其对应…...
![](/images/no-images.jpg)
网站安全 扫描/seo技术建站
https://codeforces.ml/contest/1353/problem/D (题目链接↑) 题解 这题主要用到优先队列,size(区间长度)大的排在前,size相同的left(左端点)小的排在前。 主要积累一下这里的语法: …...
![](/images/no-images.jpg)
WordPress建站维护服务/成都网站优化
文章目录 零、写在前面一、概念定义二、题目描述三、算法详解四、源码剖析五、推荐专栏六、习题练习零、写在前面 这是《算法零基础100讲》 专栏打卡学习的第 64 天了。如果觉得本专栏太贵无法承受,在博主主页添加博主好友,获取 付费专栏优惠券。 每天专栏的题,做不出来…...
![](https://images0.cnblogs.com/blog2015/425893/201506/112245508012638.png)
网络营销如何进行网站推广/关键词爱站网
1、对Tags进行管理 设置一个全局的类,类似如下: public class Tags:MonoBehaviour{public const string player"Player"; } 调用Tags.player 2、发送消息 unity中每一个对象都有SendMessage,BroadcastMessage,SendMessa…...