微服务 docker-compose部署etcd

GO微服务 docker-compose部署etcd

最近在学习golang的微服务, 使用的是go-zero。微服务就会涉及到grpc和etcd,本地开发调试完成后,就计划上线,部署到腾讯云。踩坑就开始了。

踩坑开始,先说结论。

原因是腾讯云服务里的文件夹权限不够,导致docker启动成功,但连接失败。大无语,错怪了腾讯云的防火墙。

gitee新开一个etcd仓库

仓库文件整体结构如下所示。里面的.drone.yml文件可能比较陌生, 他的作用是drone的CI/CD的配置文件,.env是给doker使用的环境变量 docker-compose.yml是docker部署文件。

  • .drone.yml

  • .env

  • docker-compose.yml

.drone.yml 再次推荐CICD工具: drone

volumes的作用是调用服务器上的docker,when的tag, 是打tag进行部署。

yaml 复制代码
pipeline:
  build-dev:
    image: docker
    volumes:
      - /var/run/docker.sock:/var/run/docker.sock
    commands:
      - docker-compose down
      - docker-compose build
      - docker-compose up -d
    when:
      event: tag
      branch: '*'
      ref: refs/tags/dev.*
    privileged: true

.env

ini 复制代码
ETCD_DIR=/home/ubuntu/etcd
ETCD_VERSION=latest
ETCD_PORT=2379

docker-compose.yml

最终成功版 , volumes数据卷,用于在 Docker 容器和主机之间持久化存储数据,权限不够的话, 就会访问失败。

yaml 复制代码
version: '3'

services:
  etcd1:
    container_name: etcd1
    image: bitnami/etcd:$ETCD_VERSION
    deploy:
      replicas: 1
      restart_policy:
        condition: on-failure
    environment:
      ETCD_ROOT_PASSWORD: qwerdf
    privileged: true
    volumes: 
      - $ETCD_DIR/data:/bitnami/etcd/data  <-罪魁祸首就是你,ETCD_DIR文件夹没给权限。
    ports:
      - $ETCD_PORT:2379
      - 2380:2380

部署成功后,检查docker运行状态

你看多好,docker一切正常。

开始连接,但是连接失败。

连接失败时报错,context deadline exceeded,这个报错就坑我,网上都是说网络问题。

查询一下,都说是网络问题,我就按照网络的思路,各种折腾腾讯云的端口,最后发现不是端口的问题。 是docker就没部署成功。

相关推荐
烛之武31 分钟前
SpringBoot基础
java·spring boot·后端
橙序员小站42 分钟前
Harness Engineering:从 OpenClaw 看 AI 助理的基础设施建设
后端·aigc·openai
小陈工1 小时前
2026年3月28日技术资讯洞察:5G-A边缘计算落地、低延迟AI推理革命与工业智造新范式
开发语言·人工智能·后端·python·5g·安全·边缘计算
azhou的代码园2 小时前
基于SpringBoot+微信小程序的图片识别科普系统
spring boot·后端·微信小程序
Tony Bai2 小时前
Rust 看了流泪,AI 看了沉默:扒开 Go 泛型最让你抓狂的“残疾”类型推断
开发语言·人工智能·后端·golang·rust
用户3167361303422 小时前
javaLangchain4j从官方文档入手,看他做了什么——具体使用(二)
后端
無名路人2 小时前
Zsh 脚本 + VS Code 任务:NestJS + Vue3 一键部署到 1Panel
运维·后端·自动化运维
ybwycx3 小时前
springboot之集成Elasticsearch
spring boot·后端·elasticsearch
程途知微4 小时前
AQS 同步器——Java 并发框架的核心底座全解析
java·后端
iPadiPhone4 小时前
分布式架构的“润滑剂”:RabbitMQ 核心原理与大厂面试避坑指南
分布式·后端·面试·架构·rabbitmq