微服务 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就没部署成功。

相关推荐
VX:Fegn08953 小时前
计算机毕业设计|基于ssm + vue超市管理系统(源码+数据库+文档)
前端·数据库·vue.js·spring boot·后端·课程设计
Java天梯之路8 小时前
Spring Boot 钩子全集实战(七):BeanFactoryPostProcessor详解
java·spring boot·后端
wr2005148 小时前
第二次作业,渗透
java·后端·spring
短剑重铸之日8 小时前
《SpringCloud实用版》生产部署:Docker + Kubernetes + GraalVM 原生镜像 完整方案
后端·spring cloud·docker·kubernetes·graalvm
爬山算法9 小时前
Hibernate(67)如何在云环境中使用Hibernate?
java·后端·hibernate
女王大人万岁10 小时前
Go标准库 io与os库详解
服务器·开发语言·后端·golang
露天赏雪10 小时前
Java 高并发编程实战:从线程池到分布式锁,解决生产环境并发问题
java·开发语言·spring boot·分布式·后端·mysql
短剑重铸之日11 小时前
《SpringCloud实用版》 Seata 分布式事务实战:AT / TCC / Saga /XA
后端·spring·spring cloud·seata·分布式事务
FAFU_kyp11 小时前
RISC0_ZERO项目在macOs上生成链上证明避坑
开发语言·后端·学习·macos·rust
qq_124987075311 小时前
基于springboot的会议室预订系统设计与实现(源码+论文+部署+安装)
java·vue.js·spring boot·后端·信息可视化·毕业设计·计算机毕业设计