当前位置: 首页 > news >正文

【docker compose 部署和 go 热部署工具fresh】

文章目录

      • `docker-compose.yml` 文件配置得很全面,以下是一些注释
      • 安装 `fresh`
      • 配置 `fresh`
      • 注意事项

docker-compose.yml 文件配置得很全面,以下是一些注释

version: '3'
services:# MySQL 服务geekai-mysql:image: registry.cn-shenzhen.aliyuncs.com/geekmaster/mysql:8.0.33  # 使用的镜像container_name: geekai-mysql  # 容器名称command: --default-authentication-plugin=mysql_native_password  # 默认认证插件restart: always  # 自动重启策略environment:- MYSQL_ROOT_PASSWORD=12345678  # MySQL root 用户密码ports:- "3307:3306"  # 主机端口3307映射到容器端口3306volumes:- ./conf/mysql/my.cnf:/etc/mysql/my.cnf  # 自定义配置文件- ./data/mysql/data:/var/lib/mysql  # 数据持久化- ./logs/mysql:/var/log/mysql  # 日志持久化- ./data/mysql/init.d:/docker-entrypoint-initdb.d/  # 初始化脚本# Redis 服务geekai-redis:image: registry.cn-shenzhen.aliyuncs.com/geekmaster/redis:6.0.6  # 使用的镜像restart: always  # 自动重启策略container_name: geekai-redis  # 容器名称command: redis-server --requirepass 12345678  # Redis 密码volumes:- ./data/redis:/data  # 数据持久化ports:- "6380:6379"  # 主机端口6380映射到容器端口6379# XXL-JOB 管理平台xxl-job-admin:container_name: geekai-xxl-job-admin  # 容器名称image: registry.cn-shenzhen.aliyuncs.com/geekmaster/xxl-job-admin:2.4.0  # 使用的镜像restart: always  # 自动重启策略ports:- "8081:8080"  # 主机端口8081映射到容器端口8080environment:- PARAMS=--spring.config.location=/application.properties  # 配置文件路径volumes:- ./logs/xxl-job:/data/applogs  # 日志持久化- ./conf/xxl-job/application.properties:/application.properties  # 配置文件# Midjourney 代理midjourney-proxy:image: registry.cn-shenzhen.aliyuncs.com/geekmaster/midjourney-proxy:2.6.2  # 使用的镜像container_name: geekai-midjourney-proxy  # 容器名称restart: always  # 自动重启策略ports:- "8082:8080"  # 主机端口8082映射到容器端口8080volumes:- ./conf/mj-proxy:/home/spring/config  # 配置文件# 后端 API 程序geekai-api:image: registry.cn-shenzhen.aliyuncs.com/geekmaster/geekai-api:v4.0.8-amd64  # 使用的镜像container_name: geekai-api  # 容器名称restart: always  # 自动重启策略depends_on:- geekai-mysql  # 依赖 MySQL 服务- geekai-redis  # 依赖 Redis 服务environment:- DEBUG=false  # 调试模式- LOG_LEVEL=info  # 日志级别- CONFIG_FILE=config.toml  # 配置文件ports:- "5678:5678"  # 主机端口5678映射到容器端口5678- "9999:9999"  # 主机端口9999映射到容器端口9999volumes:- /usr/share/zoneinfo/Asia/Shanghai:/etc/localtime  # 时区设置- ./conf/config.toml:/var/www/app/config.toml  # 配置文件- ./logs/app:/var/www/app/logs  # 日志持久化- ./static:/var/www/app/static  # 静态文件- ./data/leveldb:/var/www/app/data  # 数据持久化# 前端应用geekai-web:image: registry.cn-shenzhen.aliyuncs.com/geekmaster/geekai-web:v4.0.8-amd64  # 使用的镜像container_name: geekai-web  # 容器名称restart: always  # 自动重启策略depends_on:- geekai-api  # 依赖 API 服务ports:- "8080:8080"  # 主机端口8080映射到容器端口8080volumes:- ./logs/nginx:/var/log/nginx  # Nginx 日志持久化- ./conf/nginx/conf.d:/etc/nginx/conf.d  # Nginx 配置目录- ./conf/nginx/nginx.conf:/etc/nginx/nginx.conf  # Nginx 主配置文件- ./conf/nginx/ssl:/etc/nginx/ssl  # Nginx SSL 证书目录

如果你想启用热部署以便每次修改代码后自动重启 API 服务,可以使用 fresh 工具。下面是如何安装和配置 fresh 工具的步骤:

安装 fresh

  1. 安装 Go (如果还没安装)
    确保你已经安装了 Go 语言环境。可以从 Go 官方网站 下载并安装。

  2. 安装 fresh
    打开终端并运行以下命令来安装 fresh

    go install github.com/gravityblast/fresh@latest
    

    这将会把 fresh 安装到 $GOPATH/bin 目录下。确保这个目录在你的系统 PATH 中。

配置 fresh

  1. 创建配置文件
    在你的项目根目录下创建一个 fresh 配置文件(fresh.toml),内容示例如下:

    [watch]
    # 监视文件的模式
    watch = ["./"][build]
    # 构建时排除的路径
    exclude = ["vendor", "test"]
    
  2. 使用 fresh 启动服务
    在项目根目录下运行以下命令以启动 fresh 并监视文件变动:

    fresh
    

    fresh 会启动你的应用并持续监视代码文件的变动,一旦检测到变动就会自动重启服务。

注意事项

  • 确保你的项目配置和依赖正确,否则 fresh 可能无法正常工作。
  • fresh 通常用于开发环境,不建议在生产环境中使用。

通过使用 fresh 工具,你可以更高效地进行开发,不必每次修改后手动重启服务。如果有任何问题或需要进一步的帮助,请随时告诉我!


http://www.mrgr.cn/news/12034.html

相关文章:

  • java之Math类介绍
  • AcWing854. Floyd求最短路
  • zabbix4.0 实现钉钉告警
  • ctfhub-web-SSRF
  • 设计模式 4 建造者模式
  • Linux模拟输入设备
  • EmguCV学习笔记 VB.Net 6.2 轮廓处理
  • python-opencv读写图像中文路径的问题
  • yd云手机登录算法分析
  • SpringBoot2:依赖管理与自动配置
  • 【网络安全】XML-RPC漏洞之盲SSRF
  • 一篇精通Ansible之playbook
  • P2709 小B的询问
  • 知识图谱问答召回机制-GraphRAG
  • AIGC:Flux.1 NF4 使用 diffusers 推理
  • 观察者模式(Observer Pattern)
  • xss-labs通关攻略 11-15关
  • 代码随想录 -- 哈希表 -- 四数相加 II
  • 使用canal增量同步ES索引库数据
  • 主场竞争,安踏把背影留给耐克