Skip to content

Latest commit

 

History

History
105 lines (84 loc) · 3.64 KB

start-deploy.md

File metadata and controls

105 lines (84 loc) · 3.64 KB

生产部署

目录

  • 编译配置
  • 编译
  • 修改生产配置文件
  • 启动服务
  • Nginx配置

编译配置

  • 配置文件:server/hack/config.yaml,以下是默认配置
gfcli:
  build:
    name: "hotgo"                              # 编译后的可执行文件名称
    #    arch: "all"                           #不填默认当前系统架构,可选:386,amd64,arm,all
    #    system: "all"                         #不填默认当前系统平台,可选:linux,darwin,windows,all
    mod: "none"
    cgo: 0
    packSrc: "resource"                        # 将resource目录打包进可执行文件,静态资源无需单独部署
    packDst: "internal/packed/packed.go"       # 打包后生成的Go文件路径,一般使用相对路径指定到本项目目录中
    version: ""
    output: "./temp/hotgo"                     # 可执行文件生成路径
    extra: ""

编译

  • 以下方式任选其一即可

1、 make一键编译 (确认已安装make环境

cd server &&  make build

2、 按步骤手动编译

cd server                                             # 切换到服务端目录下
rm -rf ./resource/public/admin/                       # 删除之前的web资源
mkdir ./resource/public/admin/                        # 重新创建web资源存放目录,除首次编译后续可以跳过执行此步骤
cd ../web && yarn build                               # 切换到web项目下,编译web项目
\cp -rf ./dist/*  ../server/resource/public/admin/    # 将编译好的web资源复制到server对应的资源存放路径下
echo "y" | gf build                                   # 编译hotgo服务端

# 不出意外你已经编译好了hotgo可执行文件!

3、分端编译 (多人开发时推荐)

# 编译服务端
cd server                                        # 切换到服务端目录下
rm -rf ./resource/public/admin/                  # 删除之前的web资源,如果开发环境没有这个目录可以忽略此步骤
echo "y" | gf build                              # 编译hotgo服务端

# 编译web端
cd web                                           
yarn build

# web端编译完成后,将web/dist/*中的文件上传到`server`端线上运行目录:/resource/public/admin即可
# 至此,web端和server端都可以独立覆盖更新

修改生产配置文件

  • 配置文件:server/manifest/config/config.yaml

如关闭debug、mode设为生产环境、修改数据库地址、缓存驱动、队列驱动、日志路径等

启动服务

这里可以接使用gf官方推荐的启动方式,请参考:https://goframe.org/pages/viewpage.action?pageId=1114403

Nginx配置

      # websocket
      location ^~ /socket  {
  			proxy_pass http://127.0.0.1:8000/socket;
  			proxy_set_header X-Real-IP $remote_addr;
  			proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
  			proxy_set_header Host $host;
  			proxy_set_header X-NginX-Proxy true;
  			proxy_http_version 1.1;
  			proxy_set_header Upgrade $http_upgrade;
  			proxy_set_header Connection "Upgrade";
  			proxy_connect_timeout 600s;
  			proxy_read_timeout 600;
  			proxy_send_timeout 600s;
      }

      # http
      location ^~ / {
          proxy_set_header Host $http_host;
          proxy_set_header  X-Real-IP $remote_addr;
          proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
          proxy_set_header X-Forwarded-Proto $scheme;
          proxy_pass http://127.0.0.1:8000/; # 设置代理服务器的协议和地址
          proxy_http_version 1.1;
          proxy_set_header Upgrade $http_upgrade;
          proxy_set_header Connection upgrade;
    }