admin 管理员组

文章数量: 1087786

花森起始页

码云仓库地址:https://gitee/HuaSenJioJio/huasenjio-compose

Github 仓库地址:https://github/huasenjio/huasenjio-compose

📌 关于

花森系列网站增添新作品,(huasenjio-compose)官方仓库,基于 vue.js、node.js、docker-compose、redis、mongodb、jenkins 组合构建的容器应用。如果我的项目给您带来帮助,请点一个 star(🌟)!您的鼓励和支持,对我真的很重要!

💪 开源列表

✅ 花森起始页容器版(huasenjio-compose)

✅ 花森起始页静态版(huasen-protal)

✅ 花森脚手架(huasen-cli)

☑️ 花森低代码平台 (预研)

☑️ 花森流程引擎(预研)

🤩 在线体验

由于服务器配置过于垃圾,首次访问较慢,请耐心等待,如果加载卡死,则重新刷新网页。不是代码写得烂,相反我已进行性能优化,并且经过实践验证,服务器配置较好的情况下,访问速度很快!

1.网址导航

2.博客

3.个人引导页

💡 平台简介

花森起始页由网址导航博客系统后台管理系统组成,内容涵盖了日常生活、娱乐、学习、影视、考研、工作、科技、实用工具等领域,致力于提供聚合高效地上网冲浪环境的公益性平台!

📙 功能清单

功能介绍系列视频:https://space.bilibili/241546158/video

官网

✅ 界面响应式适配,不同设备完美呈现;

✅ 数据离线本地存储,无需登录,畅享所有功能,支持数据迁移恢复;

✅ 动态爬虫页,生成 Sitemap,优化 SEO 效果;

✅ 云端备份,多设备数据同步;

✅ 自定义网站收录,收藏精品站点;

✅ 鼠标右键改色,更换皮肤壁纸,调整明暗、模糊度,创建专属皮肤;

✅ 极简模式,干净简洁;

✅ 聚合主流搜索引擎,支持百度热词提示;

✅ 站内链接搜索,支持从网站名称、描述等信息,过滤站点,一键直达网站;

✅ 邮箱登录/注册;

✅ 标签、网链、栏目、订阅源相互关联,多角度分类资源;

✅ 时钟、天气信息实时展示;

✅ Markdown 文章阅读,支持三级锚点目录;

✍️ 网链二级详情页;

✍️ AI 对话;

☑️ 提交链接;

☑️ …

后台管理

✅ 实时访客及在线用户(支持踢下线)统计,记录 PV、UV、IP、反向链接、设备,精准掌控流量(不涉及敏感信息);

✅ 服务器状态监听,记录 CPU、内存、磁盘使用占比;

✅ Markdown 文章发布,支持右键粘贴图片;

✅ 订阅源、栏目、网链管理;

✅ 用户、权限、黑名单(IP)管理;

✅ 文件管理,支持图片、视频、PDF、文档、压缩包等文件存储;

✅ 支持文字、上传、爬取三种方式制作网链图标;

✅ 调试工具,包括运行时脚本执行面板、JSON 格式化及对象字面量互转;

✅ 配置管理,支持更换品牌名、LOGO、关键词、描述、所属城市、公告文章、重定向地址、JWT 密钥、headHTML、bodyHTML、页脚、邮箱服务、搜索引擎、壁纸等信息;

✅ 路由标签化展示,支持页面缓存;

✍️ AI 对话应用管理;

☑️ 提交链接管理;

☑️ …

后台服务

✅ 自研并发处理模块,轻松抗下 1000 并发;

✅ 一键容器化部署,经典的 MVC 架构,数据库、redis 解耦,支持直连服务;

✅ 权限管理,支持 jwt 身份校验;

✅ 加密传输,包含对称、非对称、数字签名加密传输;

✅ 邮件服务,支持发送验证码,帮助用户注册/登录;

✅ 日志服务,详细记录敏感操作,安全回溯;

✅ 定时任务服务;

✅ Websocket 实时通讯;

✅ 多线程处理物理机状态及访问数据;

✅ 文件上传,支持控制文件类型、大小、数量等;

✅ CORS 跨域;

✅ 静态目录;

✅ 爬虫、黑名单拦截中间件;

☑️ 资源防盗链;

☑️ …

✨ 界面功能预览

快照更新于 2024 年 11 月 11 日

1.响应式适配

2.首页+搜索+右键换肤

3.极简模式

4.自定义收录

5.皮肤主题

6.文章展示

7.文章阅读

8.数据仪表盘

9.文章发布

10.栏目管理

11.网链管理

12.文件管理

13.配置页面

🧩 技术架构

前端基于 Vue.js(2.6.x)、ElementUI、Tailwindcss、Axios 等技术开发的 Web 应用,服务端基于 Node.js、Mongodb、Redis、Express 开发的服务框架,使用 Nginx 作为代理服务器转发请求,选择 jenkins 实现 CI/CD,借助 docker 进行一键容器化部署。

🔨 快速部署

截止 2023/07/28 支持部署方式:

1.一键脚本部署(推荐)

2.宝塔部署

3.常规部署

环境要求

  1. 操作系统要求 CentOS 7.x,建议 7.4;
  2. 云服务器要求至少 1 核 2G,带宽 2M+,否则首次加载过慢;

方式 1:一键脚本部署(推荐)

⚠️ 打开弹幕和查看评论区

视频教程:https://www.bilibili/video/BV1gu4y1X7Kf/

🏁 流程

进入服务器,执行curl -O https://www.huasenjio.top/huasen-store/open-sh/install.sh ; chmod +x install.sh ; ./install.sh命令,下载安装脚本并且执行。如果运行失败,重新运行即可。更多操作脚本,请查阅 huasenjio-compose/bin/readme.md 文档。

方式 2:宝塔部署

⚠️ 打开弹幕和查看评论区

视频教程:https://www.bilibili/video/BV1xA411z7QA

🏁 流程
上传源码

由于宝塔自带 git,所以可以手动上传或克隆源码到服务器。

启动容器

进入项目根目录终端,执行chmod u+x ./bin/* ,为所有快捷脚本设置可执行权限,然后执行./bin/start.sh,静等拉取镜像后自动启动。

常见问题
nginx 端口冲突

报错:Error starting userland proxy: listen tcp4 0.0.0.0:80: bind: address already in use,因为宝塔自带 nginx已占用 80 端口,所以需要更改nginx 容器的端口,我们在根目录下找到 docker-compose.yml 文件,找到80:80改为8787:80,保存之后,执行./bin/start.sh,通过快捷启动脚本启动网站。

方式 3:常规部署(进阶)

⚠️ 打开弹幕和查看评论区

视频教程:https://www.bilibili/video/BV1G44y1Q7MV

🏁 安装依赖
一.Git

安装 git 版本管理工具,直接拉取源码到服务器,免去通过 xfpt 上传源码文件的繁琐过程。

(1)安装 wandisco 仓库包

yum install http://opensource.wandisco/centos/7/git/x86_64/wandisco-git-release-7-2.noarch.rpm

(2)安装 git 安装包

yum -y install git

(3)验证版本

git version
二.Docker

(1)卸载旧版本

yum remove -y docker \
  docker-client \
  docker-client-latest \
  docker-common \
  docker-latest \
  docker-latest-logrotate \
  docker-logrotate \
  docker-selinux \
  docker-engine-selinux \
  docker-engine

(2)安装依赖工具包

yum install -y yum-utils \
  device-mapper-persistent-data \
  lvm2

(3)设置 yum 源

sudo yum-config-manager --add-repo http://mirrors.aliyun/docker-ce/linux/centos/docker-ce.repo
sudo yum makecache fast

(4)安装 docker

yum install -y docker-ce

(5)启动 docker

systemctl start docker.service

(6)设置开机自启动

systemctl enable docker.service

(7)设置权限

sudo chmod a+rw /var/run/docker.sock

(8)查看版本

命令行执行docker version如下命令,输出有 Client 和 Server 服务,则说明运行正常。

(9)安装 vim 工具

如果系统没有自带 vim 编辑器,则使用如下命令进行安装。

yum -y install vim*

(10)添加镜像源配置文件

⚠️ 由于国内互联网环境,镜像源已关停,请您按需配置可用 docker 镜像源。

默认通过官方镜像源拉取,速度特别,并且容易卡死,所以需要替换镜像源,如果目录下不存在 daemon.json 配置文件,则新建配置文件,执行 vim /etc/docker/daemon.json 命令,输入配置如下:

{
  "registry-mirrors": [
    "https://docker.m.daocloud.io",
    "https://dockerproxy",
    "https://registry.docker-cn"
  ],
  "ipv6":false
}

(11)重载配置

⚠️ 不然配置不会生效

执行sudo systemctl daemon-reload命令

(12)重启 docker

⚠️ 不然配置不会生效

执行sudo systemctl restart docker命令

三.Docker-compose

安装 docker-compose 服务,负责对 docker 容器进行集群和快速编排。

(1)下载资源

sudo curl -L "https://github/docker/compose/releases/download/1.29.2/docker-compose-$(uname -s)-$(uname -m)" -o /usr/local/bin/docker-compose

(2)设置权限

sudo chmod +x /usr/local/bin/docker-compose

(3)建立软连接

不建立软连接,可能无法使用 docker-compose 命令。

ln -s /usr/local/bin/docker-compose /usr/bin/docker-compose

(4)查看版本

docker-compose --version
🏁 运行容器

通过上一步,我们已经安装好 git、docker、docker-compose 服务,接下来我们拉取源码,直接运行容器。

(1)通过 git 拉取源码

git clone https://github/huasenjio/huasenjio-compose.git

(2)进入 huasenjio-compose 目录

cd huasenjio-compose

(3)运行容器

执行运行容器命令后,docker 将自动拉取安装配置 nginx、mongodb、redis、jenkins、后端服务,第一次会比较缓慢,请耐心等待,如果遇到卡死的情况,使用ctrl + c终止命令,然后重复执行运行容器命令即可。

docker-compose up -d

(4)访问站点

容器启动成功之后,我们在浏览器地址栏输入如下地址:

官网:协议://ip/portal/
后台管理:协议://ip/admin/

❓ 常见 QA

(1)按照步骤操作,导航、博客、后台管理网站可以直接访问?

是的,项目采取容器化配置,只要一次安装运行成功,即可访问使用,无需其他繁琐配置。

(2)为什么容器运行失败?

运行容器时,请确保 80、37017、7379、8080、3000、8181 端口不被占用,可以通过netstat -anp | grep 端口号检查端口占用情况,如果不幸已经有服务占用端口,则需要修改docker-compose.yml中对应容器的端口后,重新执行运行容器命令。

(3)运行成功,但是还是无法访问到站点?

如果服务已经正常启动,但是无法访问站点,需要检查一下服务器防火墙和安全组配置,是否限制 80 端口的访问,可以使用端口检测工具,进行检测。

(4)用户注册时,为什么邮箱验证码无法发送?

(4-1)部署前配置

由于邮箱验证码功能依赖 nodemailer 库实现,需要部署之前修改/huasenjio-compose/huasen-server/config.js中的QQ_MAIL配置项,更改成自己的申请邮箱地址和 mtp 通行码。

(4-2)部署后配置(推荐)

进入后台管理,点击状态栏的配置图标,修改 mail 选项,设置正确的 host、port、auth 信息。

(5)mongodb 数据库的存储位置?

工程根目录下huasen-mongo/volume文件夹,就是数据库的数据文件夹。

(6)如何删除容器,重新启动容器?

进入 huasenjio-compose 目录,打开终端,通过docker-compose down,停止容器,删除容器。

(7)如何重新构建镜像?

进入 huasenjio-compose 目录,打开终端,通过docker-compose build --no-cache,不使用缓存,重新构建镜像。

(8)如何操作服务器防火墙?

开启防火墙:systemctl start firewalld
关闭防火墙:systemctl stop firewalld
查看防火墙:systemctl status firewalld
查看指定端口:firewall-cmd --query-port=8080/tcp
打开指定端口:firewall-cmd --add-port=8080/tcp --permanent
重载端口数据:firewall-cmd --reload
关闭指定端口:firewall-cmd --permanent --remove-port=8080/tcp

(9)如何配置放开安全组?

因为服务器提供商的应用界面不同,所以省略教程,大家平时使用阿里云、腾讯云、华为云等服务器提供商的服务器,都是可以轻易地百度到安全组的操作教程!

(10)如何升级网站?

(10-1)使用脚本

进入项目根目录,使用 chmod u+x ./bin/* 为脚本设置可执行权限,然后执行 ./bin/upgrade.sh,耐心等待,拉取新代码,升级网站。

(10-2)使用 jenkins

⚠️《📽 视频教程》章节列有视频教程

网站采用 docker-compose 编排容器,一键部署网站的同时,也在 8080 端口安装 jenkins 用于实现 CI/CD ,另外注意 jenkins 会占用大概 20%的内存,如果不使用可以关闭,进入项目根目录,执行 docker-compose stop jenkins,完成停止 jenkins 容器。

(11)如何修改前端界面?

⚠️ 需要 node.js 环境

进入官网的源码路径 /huasenjio-compose/huasen-frontend/portal 的终端,执行 npm install,安装依赖,然后执行 npm run serve 启动项目进行开发,改动代码之后,使用 npm run build 打包代码,构建后的代码输出在 /huasenjio-compose/huasen-server/public/webapp/portal 下,需要拷贝到服务器的对应位置,最后执行 /huasenjio-compose/bin/update.sh 脚本更新网站。

(12)如何修改后台管理界面?

⚠️ 需要 node.js 环境

进入后台管理的源码路径 /huasenjio-compose/huasen-frontend/admin 的终端,执行 npm install,安装依赖,然后执行 npm run serve 启动项目进行开发,改动代码之后,使用 npm run build 打包代码,构建后的代码输出在 /huasenjio-compose/huasen-server/public/webapp/admin 下,需要拷贝到服务器的对应位置,最后执行 /huasenjio-compose/bin/update.sh 脚本更新网站。

(13)如何修改后端服务?

⚠️ 需要 node.js 环境

进入项目根目录 /huasen-compose 项目执行 docker-compose up -d redis mongo 提前开启本地 redis、mongo 服务,然后进入后端服务代码路径 /huasen-compose/huasen-server,执行 npm install,安装依赖,通过 npm run dev 启动后端服务开发,最后拷贝整个/huasen-compose/server 到服务器的对应位置,执行 /huasen-compose/bin/update.sh 脚本更新网站。

(14)如何修改 nginx 的运行端口?

进入项目根目录,打开docker-compose.yml,修改 published 属性,端口号建议选 3000-10000 范围,然后执行 /huasen-compose/bin/update.sh 脚本更新网站。

(15)如何备份迁移网站?

拷贝整个项目文件夹迁移至新服务器,然后执行 /huasen-compose/bin/update.sh 脚本,网站自动完成刷新重启。

(16)显示部署成功之后,我访问网站,老是打开 up 的主页?

遇到重定向到主页的情况,说明网站部署没问题,只是访问的地址不对,根据 http://ip或域名:nginx容器端口/portal 格式检查一下。截止 2023 年 9 月 1 日后台管理已支持动态配置重定向地址,打开系统配置页面,设置重定向链接。

(17)我已经添加网链,为什么官网不显示链接呢?

官网不显示添加网链的原因主要有两种:17.1.网链没有绑定栏目,栏目没有绑定订阅源;17.2.权限不足,网链、栏目、订阅源任意一项权限不满足,就无法显示网链;详细视频教程:https://www.bilibili/video/BV1ph411j7gP/,建议花点时间了解其他介绍视频。

📽 视频教程

(1)通过 docker-compose 安装教程

https://www.bilibili/video/BV1G44y1Q7MV

(2)通过宝塔面板安装教程

https://www.bilibili/video/BV1xA411z7QA

(3)自动化部署教程

⚠️ 视频中的示例脚本已过时,以文档内提供的 shell 脚本为准!

https://www.bilibili/video/BV1vg4y1E7xy

(3-1)构建完成后执行的 shell 脚本

⚠️ 注意确保路径正确

# 设置权限
chmod u+x ./bin/*
# 执行脚本
./bin/upgrade-jenkins-init.sh

(3-2)远程执行的 shell 脚本

⚠️ 注意确保路径正确

# 设置权限
chmod u+x /root/huasen-compose/huasen-jenkins-cache/bin/*
# 执行脚本
/root/huasen-compose/huasen-jenkins-cache/bin/upgrade-jenkins.sh

🐛 开发者指南

⚠️ 以下内容适合有编程基础的小伙伴观看

环境要求

  1. node.js 16.x,建议版本 16.14.2;
  2. docker 20.x 和 docker-compose 2.6.x;

目录结构

仅展示说明核心文件

├── bin
│   ├── install.sh // 快捷安装
│   ├── readme.md
│   └── upgrade.sh // 快捷升级
├── docker-compose.yml // docker-compose配置
├── huasen-frontend // 界面源码
│   ├── admin // 后台管理
│   │   ├── package.json
│   │   └── vue.config.js
│   └── portal // 起始页界面
│       ├── package.json
│       └── vue.config.js
├── huasen-mongo
│   ├── init-mongo-open.js // 数据库初始化
│   └── volume // mongodb数据
├── huasen-nginx
│   ├── conf
│   │   └── nginx-open.conf // nginx配置
├── huasen-redis
│   ├── conf
│   │   └── redis-open.conf // redis配置
│   └── data
│       └── appendonly.aof // redis缓存
├── huasen-server
│   ├── Dockerfile // 后台服务dockerfile文件
│   ├── app.js // 入口文件
│   ├── config.js // 启动参数
│   ├── package.json
│   └── setting.json // 配置
├── huasen-store // 静态文件目录
└── README.md // 项目说明文档

本地启动调试

一.官网

⚠️ 进入/huasenjio-compose/huasen-frontend/portal 目录下执行命令

(1)安装依赖

npm install

(2)运行程序

npm run serve

(3)打包构建

npm run build
二.后台管理

⚠️ 进入/huasenjio-compose/huasen-frontend/admin 目录下执行命令

(1)安装依赖

npm install

(2)运行程序

npm run serve

(3)打包构建

npm run build
三.后台服务

⚠️ 进入/huasenjio-compose/huasen-server 目录下执行命令

(1)安装依赖

npm install

(2)运行程序

进入项目根目录执行 docker-compose up -d redis mongo 提前开启本地 redis、mongo 服务

npm run dev

🤝 Git 贡献提交规范

示例

提交格式为标识符+英文冒号+空格+模块+内容,即:feat: [首页]添加登录功能fix: [后台管理]更新博客文章失败refactor: [全局]重构安全加密传输方法,请认真组织提交信息,便于后期管理及回溯!

标识符说明

标识符说明
feat新功能
fix修复缺陷
docs文档更新
style格式/样式变动(不影响代码运行)
refactor重构代码
perf优化相关
test测试
build编译相关修改(如:构建成果物或依赖版本变动)
ci修改持续集成
chore构建过程或辅助工具的变动
revert回滚到上一个版本
mod不确定分类的变动
wip开发中
types类型声明

❌ 声明

如需授权请联系我们

  1. 仅供学习参考,未经授权,禁止商业使用;
  2. 个人运营网站时,未经作者许可,不可删除相关版权声明,包括但不限于 github 仓库、作者、logo 等信息,否则视为侵权,一切后果自负;

🥳 联系我们

由于涉及知识面较广,无法使用文字全面讲解,可以关注我的 Bilibili 账号,后续更新视频教程,感兴趣的小伙伴可以添加站长微信 ,进入技术交流群!

🐧 企鹅服务号:184820911

😸 微信服务号 :huasencc(站长会邀请加入社群)

📮 QQ邮箱 :184820911@qq

📺 bilibili:花森酱

本文标签: 管理系统 开源 正式发布 强势 后台