@jikeytang
2022-08-05T04:13:16.000000Z
字数 6033
阅读 1272
2022-blog
前段时间上线了一个小博客,今天有点空总结一下http://www.milu.blog,走过路过的小伙伴不要错过。Golang 边学边撸,这个看起来不复杂的小东西前后搞了2个多月的时间。在前期技术选型时,做为一个略懂前端的菜鸟,在前端方面做了大部分舍弃,没有选择时下流行的技术栈反而选择最原始的技术栈。这样做的目的一方面希望自己能够将主要的精力聚焦在Golang开发上,能够在完成阶段小目标的同时尽量不要沉迷于前台页面细节中,另外一方面还是希望能够在初期问题比较多的时候能够快速修复快速更新,给用户和反馈问题的小伙伴能够及时响应。就算这样的目标,最终还是在前台尝试了三套不同的风格模板来展示,也花费了不少时间,有兴趣的小伙伴可以试试。当然这些都是在Pongo2模板引擎的配合下完美实现,直接更新单个页面不用重启后台服务,如果切换模板需要重启服务。
这个项目的初衷就是通过一个基础代码的练习来巩固一下对Golang基础知识的掌握,同时也能够串联起所学的其它知识,并且以最简单的开发方式能够快速开发完成并能发布上线。由于侧重的是Golang,前台页面用简单的服务端方式渲染,没有npm,webpack,没有安装依赖、压缩,粗暴而简单。后台管理页面在 Layuimini 的基础上采用 iframe+vue 混合开发方式,原来通过 iframe 实现多标签的功能及基础布局框架没有变更,在业务页面直接引入 vue,element。优点是省去了安装依赖包、上线前打包的步骤,缺点是支撑不了复杂的业务。可选的技术栈有:
1. 前台页面可以用Nuxt3 + ElementPlus,Nextjs + Antd等方式。
2. 后台管理可以用 Vue3 + Arco, React + Antd 等等的方式。
仓库地址:
- Gitee elk-blog
取麋鹿博客 名字是为便于搜索引擎关键字直达,同时组成整个动物系列开源项目。总的思路就是:
Vue 2.x,但是不安装依赖不打包,直接引入使用。docker, redis,FTP直接上传,适合配置低的机型部署。.go文件打包发布后需要重启go应用,public、view等静态文件可单独热更新,不需要重启go服务。开发时间从5.1到8.1差不多三个月的业余时间。
| 技术 | 说明 | 官网 |
|---|---|---|
| Golang - 1.18 | 开发语言 | https://go.dev/ |
| Gin - 1.8.1 | Gin Web Framework | https://gin-gonic.com/zh-cn/docs/ |
| Mysql - 5.7 | 数据库 | https://www.mysql.com/cn/ |
| Gorm - 1.9.16 | Golang ORM | https://gorm.io/zh_CN/docs/index.html |
| Jwt | Golang jwt | https://github.com/golang-jwt/jwt |
| Pongo2 - 5 | 模板引擎 | https://github.com/flosch/pongo2 |
| Logrus | 日志 | https://github.com/sirupsen/logrus |
| Base64Captcha | 验证码 | https://github.com/mojocn/base64Captcha |
| Crypto | 密码库 | https://golang.org/x/crypto |
| Ini | ini文件库 | https://github.com/go-ini/ini |
| Goment | 时间处理工具 | https://github.com/nleeper/goment |
| Air | 热更新工具 | https://github.com/cosmtrek/air |
| 技术 | 说明 | 官网 |
|---|---|---|
| Vue - 2.x | 渐进式JavaScript 框架 | https://cn.vuejs.org/v2/guide/ |
| Axios | 基于promise 的HTTP 库 | https://github.com/axios/axios |
| Element-UI | 前端UI组件库 | https://element.eleme.io/ |
| Tinymce | 可视化HTML编辑器 | https://www.tiny.cloud/ |
| Fontawesome | 图标字体库 | http://www.fontawesome.com.cn/ |
| 系统 | 工具 | 官网 |
|---|---|---|
| Goland | 开发工具 | https://www.jetbrains.com/zh-cn/go/ |
| Navicat | 数据库管理工具 | https://www.navicat.com.cn/ |
| Atom | 源码阅读工具 | https://atom.io/ |
| Cmder | Cmd替代工具[windows] | https://cmder.net/ |
| Notepad2 | 临时单文件编辑[windows] | http://www.flos-freeware.ch/notepad2.html |
| Chrome | 调试工具 | https://www.google.com/intl/zh-CN/chrome/ |
整体的结构参考世上最优美的框架 Laravel。
├─app // 核心代码│ ├─controller // 控制层│ │ ├─admin│ │ └─home│ ├─database // 数据库链接│ ├─model // 模型层│ └─service // 操作数据层├─config // 配置文件├─pkg // 所有工具文件│ ├─e // 报错│ ├─hash // 验证码│ ├─response // 返回封装│ └─utils // 工具库├─public // 所有静态资源│ ├─admin│ ├─common│ ├─data│ ├─green│ ├─home│ └─uploads├─routers // 路由文件└─views // 所有静态资源├─admin├─green // 绿色主题模板├─default // 默认模板└─home // 普通模板
Tips:
Fresh满足基础的应用,每次保存文件都会生成或重新启动Web应用程序,只是这工具多年未更新所以弃用。
Air的优点也比较突出:彩色日志输出,自定义构建或二进制命令,支持忽略子目录,启动后支持监听新目录等等的。
Air 存在问题Air存在缓存问题,虽然在cmd里边结束Air,但刷新浏览器程序依然在运行,这时就需要手工结束进程然后重启。
// 查找 PID,9888为端口号netstat -ano | findstr 9888// 杀死进程,14172 查到的pidtaskkill /pid 14172 /f
如果输入 air 报这个错,那需要在系统的path里边配置项目路径,比如项目在D:\go-project,那么在path里边就应该有一条:
D:\go-project\bin
两种解决办法:
1. Vue的标签用v-html来代替,比如:<div v-html="user.nickname"></div>
2. 修改Vue的边界修饰符 delimiters配置方式。
Goland对Pongo2并没有提供专门的语法高亮支持,这其中推荐另外一个插件,Twig,需要2步
1. 安装插件 File -> Settings -> Plugins -> Twig。
2. 重启开发工具
以下以windows系统举例
先从官网下载安装最新版Go开发包 1.18.3,然后进行相关的配置。
在系统变量中添加 Go 开发相关的变量,需添加以下变量
| 变量名 | 值 | 说明 |
|---|---|---|
| GOPATH | d:\go-project | Go 语言的开发目录 |
| GOROOT | c:\Go | 安装 Go 安装目录 |
| PATH | c:\Go\bin;d:\go-project\bin | 终端可以直接运行Go命令; 运行自己编译的Go程序和Air |
| GO111MODULE | on | 开启 Go.mod 功能,统一用go.mod管理开发依赖包,此功能在Go1.11版本中添加 |
| GOPROXY | https://goproxy.cn | Go 包下载代理地址 |
Mysql的安装Mysql是我以前玩PHP的套件Phpstudy,有安装方便、启动便捷、管理省心等特点,当然也可以选择单独的 Mysql 来安装。由于最终发布的宝塔控制面板目前默认版本是 5.7,为了避免不必要的麻烦,我目前安装这是这一版本。
然后导入 elk-blg/public/data/elk-blog.sql文件。
默认管理入口:
http://localhost:4000/admin/login
初始用户名:admin,密码:admin
Cmd中cd到当前目录,然后直接输入命令 air后启动项目。
$ cd D:\go-project\src\elk-blog$ air
Goland 的配置| 变量名 | 值 | 说明 |
|---|---|---|
| GOPATH | d:\go-project | Go 语言的开发目录 |
| GOROOT | C:\Go | 会默认选择系统安装最高版本 |
| GOPATH-Global GOPATH | d:\go-project | 全局设置 |
| Go Modules | GOPROXY=https://goproxy.cn,direct | 先从配置地址下载,若失败,转从原始地址下载 功能,统一用go.mod管理开发依赖包,此功能在Go1.11版本中添加 |
| GOPROXY | https://goproxy.cn | Go 包下载代理地址 |
排除Exclued .idea, bin, pkg 等目录,不进行索引,有效节省内存资源。
使用One Dark主题
Air 的配置由于本人特别菜,对经典的linux及docker一直没怎么学会,所以这次选择的是宝塔控制面板来辅助部署,以下的经验也是基于宝塔来介绍。
tar包,然后上传到服务器指定目录上 /usr/local,这样做的目的是,能够快速完成节省时间。tar -xzvf go1.18.2.linux-amd64.tar.gz,这里边需要说明的是宝塔的终端不能修改配置文件,即没有退出保存的模式,需要ssh和直接在文本编辑模式修改。
export GOROOT=/usr/local/go # 设置为go安装的路径export GOPATH=/www/wwwroot/GO #项目路径export PATH=$PATH:$GOROOT/bin:$GOPATH/bin
go version,显示:go version go1.18.2 linux/amd64 即确认为安装成功其实就是新建nginx配置文件,比如新建网站 milu.blog,然后在nginx中配置go服务端口入口。假如go的端口为4000,则增加如下配置:
server{location / {proxy_pass http://127.0.0.1:4000;}}
go的打包命令只打包*.go结尾的文件,换句话说非*.go的文件需要自己手动上传。如果经历过npm run build洗礼的人,那go的这个build至少到现在没有遇到大的问题,或许我代码写的少的原因。
set CGO_ENABLED=0set GOARCH=amd64set GOOS=linuxgo build main.go
上传的目录为在环境变量里边定义的项目路径,比如milu项目的目录就是
/www/wwwroot/GO/milu
其它的项目就是
/www/wwwroot/GO/other
为了防止其它配置文件寻找不到,那所有相关的文件都在这个目录中。那最后发布完的/www/wwwroot/GO/milu下的文件组织为:
├─config // 配置文件├─public // 静态资源├─views // 模板文件├─main // 打完包二进制文件
也就是说前面那么多文件,如果部署这些文件就够了。
SQL文件这块唯一说的是宝塔只支持Mysql5.7版本,暂不支持Mysql8.0,手工安装估计也可以,偷懒也没折腾。为防止版本不兼容,在本地开发时Mysql就为5.7。然后本地Navicat导出结构和数据,在宝塔的Phpmyadmin里边导入。
在宝塔终端中cd到项目目录/www/wwwroot/GO/milu,然后直接 ./main,这样方便的查看日志,能够看到一些详情的报错信息。运行 ./main之后,就可以刷新域名,如果各步正常页面就能显示出来。
我也只是试试的心态用pm2来运行一下go,没想到还真运行起来了。这样暂时不安装其它的服务,和Node服务一块运行起来。
此项目感谢以下各界人士的支持和帮助