:black_nib: Puti is a blog system written in Go. It is be expected to be a high performance full-featured writing system. :rocket: Go语言实现的博客系统。
:black_nib: Puti is a full-featured writing system written in Golang.
中文
| Engilsh
Puti 项目现在仍在开发中,目标是面向极客的下一代写作系统。
目前在探究如何在后台管理中引入 Wasm,提高性能和开发效率(统一技术栈)。
本项目使用了 Go Modules,所以需使用 Go 1.13 以上版本。
项目不依赖 Nginx 之类的 Web Server,默认启用自动HTTPS获取Let’s Encrypt证书,但是你可以配置并且使用 Nginx。
项目计划实现以及已经实现的功能如下:
Puti 的配置文件位于 configs
下的 config.yaml
,初次使用可以从 config.yaml.example
初始化配置文件。
需要注意的配置:
配置 | 说明 |
---|---|
server.http_port | HTTP 端口 |
server.https_open | 是否开启 HTTPS |
server.auto_cert | 是否开启自动 HTTPS |
server.https_port | HTTPS 端口 |
server.tls_cert | 如果不是自动 HTTPS,配置 SSL 证书路径 |
server.tls_key | 如果不是自动 HTTPS,配置 SSL 私钥路径 |
puti_domain | 应用绑定的域名,如开启自动 HTTPS,将自动获取域名Let’s Encrypt证书;例如:www.example.com |
safety.jwt_secret | Json web token 秘钥 |
db.name | 数据库名称 |
db.addr | 数据库 HOST:PORT |
db.username | 数据库登录名 |
db.password | 数据库密码 |
项目使用了 Go Module,所以要求 Go 1.13 及以上的版本。目前移除了 Vendor 目录,因为现在 go proxy
已经能够很好地解决某些问题了。
# 下载
$ go get -u github.com/puti-projects/puti
# 使用Makefile来构建程序
$ cd $GOPATH/src/github.com/puti-projects/puti
$ make
我们已经提供了现成的镜像,可以直接拉取使用:
# 从 Docker Hub 拉取镜像
$ docker pull puti/puti
# 创建需要挂载的目录,例如:`/data/puti`为应用文件存放目录,`/data/logs/puti`为日志存放目录
$ mkdir -p /data/puti /data/logs/puti
# 第一次通过`docker run`来创建一个容器
$ docker run --name=puti -p 80:8000 -p 443:8080 -v /data/puti:/data/puti -v /data/logs/puti:/data/logs/puti puti/puti
# 使用 `docker stop``docker start`来停止,关闭容器。
$ docker stop puti
$ docker start puti
更多内容查看:Docker use
我们提供了简单方便地一键部署 Docker-compose 脚本文件,懒人必备。具体使用查看:puti-projects/puti-environment
初始化失败,可能是数据库配置的问题(目前没有安装引导)。默认初始化一个账号 admin
密码 admin
的默认账号,请创建自己的账号后移除默认账号。功能完善后会考虑安装引导。
更多主题制作中。目前提供默认主题 Emma 和 Lin,为两种不同风格的主题。
TODO
Detailed changes for each release are documented in the changelog file).
依赖 | 关于 |
---|---|
gin-gonic/gin | HTTP web framework written in Go. |
go-gorm/gorm | The ORM library for Golang. |
allegro/bigcache | Efficient cache for gigabytes of data written in Go. |
spf13/viper | Complete configuration solution. |
go.uber.org/zap | Fast, structured, leveled logging. |
vuejs/vue | JavaScript framework for building UI on the web. |
ElemeFE/element | A Vue.js 2.0 UI Toolkit for Web. |
PanJiaChen/vue-element-admin | A front-end management background integration solution. |
hinesboy/mavonEditor (will be removed) | A markdown editor. |
Vanessa219/vditor | An in-browser markdown editor. |
88250/lute | A structured Markdown engine that supports Go and JavaScript. |
可以不使用 Nginx 之类的 WebServer,且支持自动 HTTPS;目前不做重定向判断,如根域名到 www 域名,HTTP 到 HTTPS;较好的实践是再加一层 WebServer。
goozp 💻📚🎨 |
---|
Thanks to JetBrains for providing free Goland IDE based on JetBrains OS licenses.
Puti is under the GPL-3.0 license. See the LICENSE file for details.