PaoPao
🔥一个清新文艺的微社区
View Demo · Report Bug · Features
预览
🛠技术栈
PaoPao主要由以下优秀的开源项目/工具构建
🏗快速开始
环境要求
- Go (1.17+)
- Node.js (14+)
- MySQL (5.7+)
- Redis
- Zinc
* Zinc是一款轻量级全文搜索引擎,可以查阅 zincsearch.com/ 安装
以上环境版本为PaoPao官方的开发版本,仅供参考,其他版本的环境未进行充分测试
安装说明
方式一. 手动安装(推荐)
克隆代码库
git clone https://github.com/rocboss/paopao-ce.git
后端
-
导入项目根目录下的
scripts/paopao.sql文件至MySQL数据库 -
拷贝项目根目录下
config.yaml.sample文件至config.yaml,按照注释完成配置编辑 -
编译后端
编译api服务:make build编译api服务、内嵌web前端ui:
make build TAGS=编译后在
release目录可以找到对应可执行文件。release/paopao-ce -
直接运行后端
运行api服务:make run运行api服务、web前端ui服务:
make run TAGS=提示: 如果需要内嵌web前端ui,请先构建web前端(建议设置web/.env为VITE_HOST="")。
前端
-
进入前端目录
web,编辑.env文件中后端服务地址,下载依赖包cd -
编译前端
yarn buildbuild完成后,可以在dist目录获取编译产出,配置nginx指向至该目录即可
桌面端
-
进入前端目录
web,编辑.env文件中后端服务地址,下载依赖包cd -
编译前端
yarn build -
构建桌面端
yarn tauri build桌面端是使用Rust + tauri编写的,需要安装tauri的依赖,具体参考https://tauri.studio/v1/guides/getting-started/prerequisites.
方式二. 使用Docker构建、运行
- 后端:
# 默认参数构建, 默认内嵌web ui并设置api host为空
- 前端:
cd
方式三. 使用 docker-compose 运行
git clone https://github.com/rocboss/paopao-ce.git
docker compose up --build
默认是使用config.yaml.sample的配置,如果需要自定义配置,请拷贝默认配置文件(比如config.yaml),修改后再同步配置到docker-compose.yaml如下:
# file: docker-compose.yaml
...
backend:
build:
context: .
restart: always
depends_on:
- db
- redis
- zinc
# modify below to reflect your custom configure
volumes:
- ./config.yaml:/app/paopao-ce/config.yaml
ports:
- 8008:8008
networks:
- paopao-network
....
注意:默认提供的 docker-compose.yaml 仅用于搭建本机开发调试环境,paopao-ce/phpMysqlAdmin 默认只能本机访问,如果需要产品部署供外网访问,请自行修改配置参数或使用其他方式部署。
API 文档
构建时将 docs 添加到TAGS中:
make run TAGS=
配置说明
config.yaml.sample 是一份完整的配置文件模版,paopao-ce启动时会读取./configs/config.yaml、./config.yaml任意一份配置文件(优先读取最先找到的文件)。
cp config.yaml.sample config.yaml
vim config.yaml
配置文件中的 Features 小节是声明paopao-ce运行时开启哪些功能项:
...
如上: Default/Develop/Demo/Slim 是不同 功能集套件(Features Suite), Base/Option 是子功能套件, Sms是关于短信验证码功能的参数选项。
这里 Default套件 代表的意思是: 使用Base/Option 中的功能,外加 MySQL/LocalOSS/LoggerFile功能,也就是说开启了Zinc/Redis/Alipay/SimpleCacheIndex/MySQL/LocalOSS/LoggerFile 7项功能; Develop套件依例类推。
使用Feautures:
release/paopao-ce --help
Usage of release/paopao-ce:
-features value
use special features
-no-default-features
whether use default features
目前支持的功能集合:
- 数据库: MySQL/Sqlite3/PostgreSQL
- 对象存储: AliOSS/MinIO/LocalOSS
AliOSS阿里云对象存储服务;
MinIOMinIO对象存储服务;
LocalOSS提供使用本地目录文件作为对象存储的功能,仅用于开发调试环境; - 缓存: Redis/SimpleCacheIndex/BigCacheIndex
SimpleCacheIndex提供简单的 广场推文列表 的缓存功能;
BigCacheIndex使用BigCache缓存广场推文列表,缓存每个用户每一页,简单做到千人千面(推荐使用); - 搜索: Zinc/Meili
Zinc基于Zinc搜索引擎提供推文搜索服务(目前状态: 稳定,推荐使用);
Meili基于Meilisearch搜索引擎提供推文搜索服务(目前状态: 内测阶段); - 日志: LoggerFile/LoggerZinc/LoggerMeili
LoggerFile使用文件写日志(目前状态: 稳定);
LoggerZinc使用Zinc写日志(目前状态: 稳定,推荐使用);
LoggerMeili使用Meilisearch写日志(目前状态: 内测阶段); - 支付: Alipay
- 短信验证码: SmsJuhe(需要开启sms)
Sms功能如果没有开启,任意短信验证码都可以绑定手机;
搭建依赖环境
Zinc 搜索引擎:
- Zinc运行
# 创建用于存放zinc数据的目录
- 修改Zinc配置
# features中加上 Zinc 和 LoggerZinc
Meilisearch 搜索引擎:
- Meili运行
mkdir -p data/meili/data
- 修改Meili配置
# features中加上 Meili 和 LoggerMeili
MinIO 对象存储服务
- MinIO运行
mkdir -p data/minio/data
- 修改Minio配置
# features中加上 MinIO
其他说明
建议后端服务使用 supervisor 守护进程,并通过 nginx 反向代理后,提供API给前端服务调用。
短信通道使用的聚合数据,如果申请不下来,可以考虑替换其他服务商。
代码结构比较简单,很方便扩展
👯♀️贡献
喜欢的朋友欢迎给个Star、贡献PR。
License
Distributed under the MIT License. See LICENSE for more information.
