Skip to content

Forrest-Tao/LinkMe

Repository files navigation

LinkMe - 开源论坛项目

LinkMe

项目简介

LinkMe 是一个使用 Go 语言开发的论坛项目。它旨在为用户提供一个简洁、高效、可扩展的在线交流平台。本项目使用DDD领域设计理念,采用模块化的设计,使得添加新功能或进行定制化修改变得非常容易。LinkMe 支持多种数据库后端,并且可以通过 Kubernetes 进行部署。

功能特性

  • 用户注册、登录、注销
  • 发布帖子、评论、点赞
  • 用户个人资料编辑
  • 论坛版块管理
  • 多种数据库支持
  • Kubernetes 一键部署
  • RESTful API 设计
  • 前后端分离架构

技术栈

  • Go 语言
  • Gin Web 框架
  • Wire 依赖注入
  • Kubernetes 集群管理
  • MySQL 数据库
  • Redis 缓存数据库
  • MongoDB 文档数据库
  • Kafka 消息队列
  • Prometheus 监控
  • ELK 日志收集
  • ElasticSearch 搜索引擎
  • Docker 容器化
  • 随项目进度技术栈实时更新..

目录结构

.
├── config           # 项目配置文件目录
├── docs             # API文档目录
├── go.mod           # Go模块定义文件
├── go.sum           # Go模块依赖校验和
├── internal         # 项目内部包,含核心业务逻辑
├── ioc              # IoC容器配置,负责依赖注入设置
├── LICENSE          # 开源许可证书
├── LinkMe           # 可执行文件或快捷方式
├── main.go          # 项目主入口文件
├── pkg              # 自定义工具包与库
├── middleware       # 中间件目录
├── README.md        # 项目自述文件
├── tmp              # 临时文件目录
├── wire_gen.go      # Wire工具生成的代码
├── wire.go          # Wire配置,声明依赖注入关系
└── yaml             # Kubernetes部署配置文件目录

如何贡献

我们欢迎任何形式的贡献,包括但不限于:

  • 提交代码(Pull Requests)
  • 报告问题(Issues)
  • 文档改进
  • 功能建议 请确保在贡献代码之前阅读了我们的贡献指南

贡献指南

  • Fork 本仓库
  • 创建您的特性分支 (git checkout -b my-new-feature)
  • 提交您的改动 (git commit -am 'Add some feature')
  • 将您的分支推送到 GitHub (git push origin my-new-feature)
  • 创建一个 Pull Request

开始使用

克隆项目

[email protected]:GoSimplicity/LinkMe.git

安装依赖

go mod tidy

创建数据库

你可以选择手动创建数据库,或者使用提供的 Kubernetes YAML 文件自动创建。

手动创建

mysql -uroot -proot -e "create database linkme;"

使用 Kubernetes YAML 文件

kubectl apply -f yaml/  # 需要有k8s环境

使用 Wire 进行依赖注入

go install github.com/google/wire/cmd/wire@latest
wire # 注意需要在wire.go文件所在目录下使用

构建并启动项目

go build -o linkme . && ./linkme

使用 air 启动项目(可选)

go install github.com/cosmtrek/[email protected] # 注意go版本不得低于air指定版本,本项目使用golang版本为1.22
air

许可证

本项目使用 MIT 许可证,详情请见 LICENSE 文件。

联系方式

致谢

感谢所有为本项目做出贡献的人!

欢迎来到 LinkMe,让我们一起构建更好的论坛社区!

About

LinkMe交流论坛

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Go 99.0%
  • Other 1.0%