欢迎来到爱学习爱分享,在这里,你会找到许多有趣的技术 : )

apollo:开源的 Go 原生社交系统

开发者头条 1434℃

apollo 项目

see English README

apollo 项目的主体是一个 go 语言原生的 bbs 社区系统,主要为了弥补当前 go 语言原生社区系统的空白。在前后端分离盛行的今天,越来越多的技术细节被默认存在,无形中也就增加了初学者在这个技术栈的学习门槛。apollo 项目专注在 go 技术栈,从命令行启动、配置读取,到数据库访问、html模板渲染,均直接采用了 go 对应的库;除了语言层面的学习,apollo 项目还抽象了一些 web 设计中可能涉及的基本点,从而便于初学者未来了解设计更为宏大的项目。

由于经验尚浅,再加上时间因素约束,项目中难免有一些不雅的设计,欢迎大家创建 issue 指出问题,并欢迎大家提交更为完善的代码。

设计细节请查看 wiki

安装运行

apollo 是一个功能轻完备的项目,目前它已具备注册、登陆、注销、发帖、编辑、回复等功能,可以在一些简单应用场景下使用。可以到 http://www.jianzhoubian.com) 预览,测试好像只能使用 http 协议而不能使用 https 协议访问=。=

环境要求

  • 安装 go(version >= 1.13)
  • 安装 MySQL(apollo 使用了 5.7.28 进行的开发)
  • (可选)安装 make (Linux 和 MacOS 上默认应该都有),如果没有安装,则需要手动运行一些命令

详细步骤

  1. 下载本仓库的代码(后面的操作都是在项目目录下执行);
  2. 根据configs/config.yml.example创建configs/config.yml文件;
  3. 根据configs/config.yml中数据库(database)的配置,在 MySQL 中创建用户及数据库。下面以apollo为例
-- 创建 apollo 数据库,默认字符集为 utf8mb4
CREATE DATABASE `apollo` DEFAULT CHARACTER SET = `utf8mb4`;

-- 创建用户名为 jingwei 密码为 20200101 的用户,并赋权 apollo 的所有权限给 jingwei
GRANT ALL PRIVILEGES ON apollo.* TO jingwei@"%" IDENTIFIED BY "20200101";

  1. 迁移数据表结构:

    1.1 如果安装了make工具,直接运行make migrate即可完成数据表的迁移。

    1.2 如果没有安装make工具,依次执行:

# 下载依赖
go mod tidy
# 构建 apollo.exe 二进制执行文件
go build -o apollo.exe main.go

# 执行迁移
./apollo.exe migrate

  1. 通过命令./apollo.exe运行apollo项目。
  2. 通过浏览器访问localhost:2020即可看到对应的页面。

其他资料

请查看 wiki 目录。

转载请注明:爱学习爱分享 » apollo:开源的 Go 原生社交系统

喜欢 (1)or分享 (0)