TechMindWave从0到1-开发到部署1

本文涉及的产品
云数据库 Tair(兼容Redis),内存型 2GB
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
Redis 开源版,标准版 2GB
推荐场景:
搭建游戏排行榜
简介: TechMindWave从0到1-开发到部署

|前序

由于网站没做太多防护,就不再这里粘贴网站访问链接了。

有想要看网站UI模样的可以到下面平台相关页面截图展示模块看


花有再开日,人无在少年。

感谢曾经奋斗的你。

致青春。

经历一个月每周末的时间,终于把项目完整的搞了出来。

有的周末一两点才关闭电脑。

有的时候小小的bug可以噶两三个小时还没有解决。

多少次想放弃。

但多亏了星球小伙伴们的帮忙。

再次感谢星球小伙伴

@星球 sanqi 付文鑫

@猫十二懿 星球

@爱䇚䇚 星球 文本解决

(排名不分先后顺序)

好久没部署过网站了,这次在知识星球鱼皮哥的带领下,从0到1完成了网站的开发到部署。

也是第一次接触前后端分离的项目。

也是第一次见证到了部署方式之多。

  1. 原生化部署(纯Linux指令)
  2. docker打包部署
  3. 宝塔部署


此项目融合了用户中心、智能BI,并对其做了扩展。

管理员功能扩展

智能文本分析扩展

AI对话(dev)

由于还有点bug没有处理,等迭代,所以dev哈哈哈~


主要页面参考@猫十二懿 星球

文本分析参考@爱䇚䇚 星球 文本解决

bug解决帮助@星球 sanqi 付文鑫

再次鸣谢各位小伙伴!



|正式篇

喜欢md形式的小伙伴可以复制网站链接🔗跳转对应笔记

相关笔记链接🔗

南城余:

https://www.yuque.com/g/nanchengcyu/dubfny/ibwmnan5bo9uf51x/collaborator/join?token=wkxCKWCK5Lt3BlsI&source=doc_collaborator# 《TechMindWave》

知识星球:

https://bcdh.yuque.com/staff-wpxfif/resource/oywzglpnxegf579a

猫十二:

https://www.yuque.com/kcsshier/zpovmy/frhxvidgief5r5df?singleDoc

上传前后端代码教程

相关链接🔗:

https://zhuanlan.zhihu.com/p/193140870

前端代码:

https://github.com/nanchengcyu/TechMindWave-frontend

后端代码:

https://github.com/nanchengcyu/TechMindWave-backend


1)在GitHub上创建仓库



2)建立本地仓库

3) 将所有文件添加到仓库中

git add  .

4)修改文件描述

git commit -m "first commit"

5)关联github仓库

git branch -M main
git remote add origin git@github.com:nanchengcyu/TechMindWave-frontend.git

6)上传本地代码

git push -u origin main

项目背景

什么是 BI?


即商业智能:数据可视化、报表可视化系统
主流 BI 平台:帆软 BI、小马 BI、微软 Power BI

传统 BI 平台:
https://chartcube.alipay.com/
1需要人工上传数据
2需要人工拖选分析要用到的数据行和列(数据分析师)
3需要人工选择图表类型(数据分析师)
4生成图表并保存配置

智能 BI 平台:
区别于传统的 BI,用户(数据分析者)只需要导入最最最原始的数据集,输入想要进行分析的目标(比如帮我分析一下网站的增长趋势),就能利用 AI 自动生成一个符合要求的图表以及结论。

优点:让不会数据分析的同学也能通过输入目标快速完成数据分析,大幅节约人力成本。


需求分析


1智能分析:用户输入目标和原始数据(图表类型),可以自动生成图表和分析结论
2图表管理
3图表生成的异步化(消息队列)
4对接 AI 能力

架构图


基础流程:


优化流程(异步化):




技术栈

前端
1.React
2.Umi
3.Ant Design Pro
4.可视化开发库:
Echarts √ 、HighChairts + AntV
5.umi openapi 代码生成:自动生成后端调用代码
6.EChart 图表生成

后端
1.Spring Boot:万用模板
2.MySQL数据库
3.Redis:Redissson限流控制
4.MyBatis Plus 数据库访问结构
5.消息队列:RabbitMQ
6.AI能力:Open AI接口开发
7.Excel上传和数据的解析:Easy Excel
8.Swagger + Knife4j 项目文档
9.Hutool 工具库

平台功能介绍

  1. 用户登录,注册。
  2. 智能图表分析(同步)。调用AI根据用户上传csv文件生成对应的 JSON 数据,并使用 ECharts图表 将分析结果可视化展示。
  3. 智能图表分析(异步)。使用了线程池异步生成图表,最后将线程池改造成使用 RabbitMQ消息队列 保证消息的可靠性,实现消息重试机制。
  4. 智能文本分析(异步)。使用了线程池异步生成markdown文本,最后将线程池改造成使用 RabbitMQ消息队列 保证消息的可靠性,实现消息重试机制。
  5. 智能问题分析(异步)。使用了线程池异步生成问题解决答案,最后将线程池改造成使用 RabbitMQ消息队列 保证消息的可靠性,实现消息重试机制。
  6. 个人管理图表/文本/问题,增删改查。
  7. 个人信息管理,头像,名字,账号等的修改。
  8. 管理员管理,支持图表/文本/问题增删改查,新增用户,修改用户,删除用户,查看用户,增删改查等。
  9. 用户限流。本项目使用到令牌桶限流算法,使用Redisson实现简单且高效分布式限流,限制用户每秒只能调用一次数据分析接口,防止用户恶意占用系统资源
  10. 调用AI进行数据分析,并控制AI的输出。
  11. 由于AIGC的输入 Token 限制,使用 Easy Excel 解析用户上传的 XLSX 表格数据文件并压缩为CSV,实测提高了20%的单次输入数据量、并节约了成本。
  12. 后端自定义 Prompt 预设模板并封装用户输入的数据和分析诉求,通过对接 AIGC 接口生成可视化图表 JSON 配置和分析结论,返回给前端渲染。

平台相关页面截图展示

网站名字

改名了,这是之前版本的名字

我的选择

WiseGraphs:将"Wise"(意为智慧)和"Graphs"(意为图表)结合,强调图表的智能化。

副标题:智能可视化,数据一目了然

前后端相关网站链接

RabbitMQ网站地址:

http://localhost:15672/#/

ant-design 官网镜像地址:

http://ant-design.gitee.io/index-cn

ant-design-pro镜像地址:

http://ant-design-pro.gitee.io/index-cn

antd-mobile镜像地址:

https://antd-mobile.gitee.io/index-cn

前端项目初始化

Install node_modules:

npm install

OR

yarn

启动项目

npm start

构建项目

npm run dev

前端初始化问题解决

1.依赖缺失解决(主要更改包名后的报错解决方法)



后端项目初始化

  1. 下载/拉取本项目到本地
  2. 通过 IDEA 代码编辑器进行打开项目,等待依赖的下载
  3. 修改配置文件 application.yaml的信息,比如数据库、Redis、RabbitMQ等
  4. 修改信息完成后,通过 NanchengyuApplication 程序进行运行项目
  5. 队列生成

部署项目

部署方式

1)原生态部署方法,各种环境利用Linux指令安装(下面所有环境安装方法,MySQL、redis等)

2)docker容器打包方法,将所有的环境打包在docker容器中,包括前后端项目

3)利用第三方网站部署,如宝塔。

阿里云服务器重置以及安装宝塔

链接:

https://blog.csdn.net/qq_44891617/article/details/123723766

宝塔部署参考链接:

https://www.cnblogs.com/galo/p/17539631.html

宝塔 运行jar目录参考

---------------------------------------------------

下面所有方法都为1)的部署方法-原生安装方法

前端

前端打包

webstrom

npm run build

前端环境

nginx

前端环境安装

nginx下载安装

1)利用centosyum下载
yum 
or 利用官网链接下载 
curl -o  [filename] [curl] 
2)解压安装
tar -zxvf nginx-1.24.0.tar.gz  
3)相关依赖安装
yum install pcre pcre-devel -y
yum install openssl openssl-devel -y
./configure --with-http_ssl_module--with-http_v2_module--with-stream
4)编译安装
make
make install
5)编译配置环境
ls /usr/local/nginx/sbin/nginx
vim /etc/profile
(shift+g)快速跳到编译文件最后一行
在最后一行添加:
export PATH=$PATH:/usr/local/nginx/sbin 
6)启动nginx
source /etc/profile 刷新配置文件
nginx
6)查看端口启动情况
netstat -ntlp

后端

后端打包

后端多环境运行配置

在企业项目运行时,一般会经历开发-测试等多个环节,因此需要一套代码多个环境,项目上线打包的时候只需要修改application.yml配置即可,详情可看下图

相关链接:

https://zhuanlan.zhihu.com/p/148823337


参考链接:

https://www.cnblogs.com/galo/p/17539631.html

后端环境

Java maven MySQL  Redis RabbitMQ  Java版本

推到重来,建议全部安装利用podman/docker安装

后端环境安装

Java maven安装

yum install -y java-1.8.0-openjdk*
curl -o apache-maven-3.8.5-bin.tar.gz https://dlcdn.apache.org/maven/maven-3/3.8.5/binaries/apache-maven-3.8.5-bin.tar.gz
tar -zxvf apache-maven-3.8.5-bin.tar.gz 
git clone xxx 下载代码
打包构建,跳过测试
mvn package -DskipTests
java -jar ./user-center-backend-0.0.1-SNAPSHOT.jar --spring.profiles.active=prod


MySQL安装

参考网站链接:

https://blog.csdn.net/wangpaiblog/article/details/120259448

MySQL镜像网:

https://mirrors.aliyun.com/mysql/MySQL-8.0/?spm=a2c6h.25603864.0.0.6a2f712bwfBnNT

RabbitMQ安装

参考网站

https://blog.csdn.net/qq_45173404/article/details/116429302

下载网站

https://www.rabbitmq.com/download.html

问题解决方案

rabbitmq用户管理(Not management user问题解决)

参考链接:

https://blog.csdn.net/qq_24095055/article/details/97001679

建议最后执行

rabbitmqctl set_user_tags 用户名 administrator

redis安装

参考网站链接:

https://blog.csdn.net/m0_37959155/article/details/108897863

https://blog.csdn.net/u012723183/article/details/105970244(阿里云推荐)

推到重来,建议全部安装利用podman/docker安装


相关实践学习
基于Redis实现在线游戏积分排行榜
本场景将介绍如何基于Redis数据库实现在线游戏中的游戏玩家积分排行榜功能。
云数据库 Redis 版使用教程
云数据库Redis版是兼容Redis协议标准的、提供持久化的内存数据库服务,基于高可靠双机热备架构及可无缝扩展的集群架构,满足高读写性能场景及容量需弹性变配的业务需求。 产品详情:https://www.aliyun.com/product/kvstore     ------------------------------------------------------------------------- 阿里云数据库体验:数据库上云实战 开发者云会免费提供一台带自建MySQL的源数据库 ECS 实例和一台目标数据库 RDS实例。跟着指引,您可以一步步实现将ECS自建数据库迁移到目标数据库RDS。 点击下方链接,领取免费ECS&RDS资源,30分钟完成数据库上云实战!https://developer.aliyun.com/adc/scenario/51eefbd1894e42f6bb9acacadd3f9121?spm=a2c6h.13788135.J_3257954370.9.4ba85f24utseFl
目录
相关文章
|
消息中间件 人工智能 数据可视化
TechMindWave1
TechMindWave
70 0
|
消息中间件 资源调度 前端开发
TechMindWave(BIGC前后端分离项目)从0到1-开发到部署3
TechMindWave(BIGC前后端分离项目)从0到1-开发到部署
54 0
|
人工智能 Linux BI
TechMindWave(BIGC前后端分离项目)从0到1-开发到部署1
TechMindWave(BIGC前后端分离项目)从0到1-开发到部署
45 0
|
Kubernetes 持续交付 开发工具
使用Drone搭建CICD服务
Drone是Go语言编写的,基于容器技术的CI/CD系统。它具有以下几个关键特性。 1、Everything is a Docker Container 2、One Server, Multiple Agents 3、Configuration as a code 4、丰富的插件
2213 1
|
消息中间件 前端开发 NoSQL
TechMindWave从0到1-开发到部署2
TechMindWave从0到1-开发到部署
54 0
|
消息中间件 JavaScript BI
TechMindWave(BIGC前后端分离项目)从0到1-开发到部署6
TechMindWave(BIGC前后端分离项目)从0到1-开发到部署
64 0
|
消息中间件 人工智能 数据可视化
TechMindWave(BIGC前后端分离项目)从0到1-开发到部署2
TechMindWave(BIGC前后端分离项目)从0到1-开发到部署
62 0
|
前端开发 应用服务中间件 nginx
TechMindWave(BIGC前后端分离项目)从0到1-开发到部署4
TechMindWave(BIGC前后端分离项目)从0到1-开发到部署
40 0
|
前端开发 NoSQL Java
TechMindWave(BIGC前后端分离项目)从0到1-开发到部署5
TechMindWave(BIGC前后端分离项目)从0到1-开发到部署
48 0
|
消息中间件 前端开发 Java
TechMindWave2
TechMindWave
61 0