hotgo/docs/guide-zh-CN/start-deploy.md
2024-09-06 12:01:30 +08:00

3.8 KiB
Raw Permalink Blame History

生产部署

目录

  • 编译配置
  • 编译
  • 修改生产配置文件
  • 启动服务
  • 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 && pnpm run build                               # 切换到web项目下编译web项目
\cp -rf ./dist/*  ../server/resource/public/admin/    # 将编译好的web资源复制到server对应的资源存放路径下
cd ../server                                          # 切换回服务端目录下
echo "y" | gf build                                   # 编译hotgo服务端

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

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

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

# 编译web端
cd web                                           
pnpm run build 或 npm run 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;
    }