2.1 Environment Requirements

  • Golang 1.17
  • Etcd
  • Redis
  • Mysql
  • Prometheus
  • Grafana
  • Jaeger

2.2 DockerLocal development environment setup

In order to facilitate development and debugging, we use Docker to build a local development environment. Docker Desktop can be downloaded for Windows and macOS. For details about how to download and install Docker Desktop, you can search for related tutorials.

Docker Compose: Docker Compose: Docker Compose: Docker Compose: Docker Compose: Docker Compose: Docker Compose: Docker Compose

# golang ├ ─ ─ etcd etcd service registry found │ └ ─ ─ Dockerfile ├ ─ ─ golang # golang running environment │ └ ─ ─ Dockerfile ├ ─ ─ grafana # │ grafana visualization data monitoring └ ─ ─ Dockerfile ├ ─ ─ jaeger tracking # jaeger link │ └ ─ ─ Dockerfile ├ ─ ─ # mysql mysql service │ └ ─ ─ Dockerfile ├ ─ ─ mysql - manage # mysql │ ├─ ├─ ├─ Prometheus # ├─ ├─ Prometheus # ├─ Prometheus # ├─ Prometheus # ├─ Prometheus # ├─ ├─ ├─ ├─ ├─ ├─ ├─ ├─ ├─ docker-compose.ymlCopy the code

2.2.1 writeDockerfile

In go-Zero microservice, GRPC is used for communication between services, and the compilation of GRPC needs to use Protoc and protoc-Gen-Go plug-in translated into GO language RPC stub code.

In order to improve the development efficiency, reduce the error rate of code and shorten the workload of business development, Go-Zero also provides the GoCTL code generation tool.

Therefore, we need to pre-install protoc, protoc-gen-go, goCTL into golang’s container for subsequent use.

So the golang Dockerfile code looks like this:

FROM golang:1.17

LABEL maintainer="Ving <[email protected]>"

ENV GOPROXY https://goproxy.cn,direct

Install the necessary software packages and dependencies
USER root
RUN sed -i 's/deb.debian.org/mirrors.tuna.tsinghua.edu.cn/' /etc/apt/sources.list && \
    sed -i 's/security.debian.org/mirrors.tuna.tsinghua.edu.cn/' /etc/apt/sources.list && \
    sed -i 's/security-cdn.debian.org/mirrors.tuna.tsinghua.edu.cn/'/etc/apt/sources.list && \ apt-get update && \ apt-get upgrade -y && \ apt-get install -y --no-install-recommends \ curl  \ zip \ unzip \ git \ vim

# installation protoc
USER root
RUNcurl -L -o /tmp/protoc.zip https://github.com/protocolbuffers/protobuf/releases/download/v3.19.1/protoc-3.19.1-linux-x86_64.zip && \ unzip - d /tmp/protoc /tmp/protoc.zip && \ cp -r /tmp/protoc /usr/local/protoc

# protoc added to the environment variable
ENV PATH /usr/local/protoc/bin:$PATH

Install goctl and protoc-gen-go
RUNGo get the -u github.com/tal-tech/go-zero/tools/goctl && \ go get -u github.com/golang/protobuf/[email protected]

# Take out the trash
USER root
RUN apt-get clean && \
    rm -rf /var/lib/apt/lists/* /tmp/* /var/tmp/* && \
    rm /var/log/lastlog /var/log/faillog

Set the working directory
WORKDIR /usr/src/code

EXPOSE 8000
EXPOSE 8001
EXPOSE 8002
EXPOSE 8003
EXPOSE 8004
EXPOSE 8005
EXPOSE 8006
Copy the code

Other service containers dockerfiles need no special handling, just based on existing images.

service Based mirror
Etcd bitnami/etcd
Mysql Mysql: 5.7
Redis Redis: 5.0
Mysql Manage phpmyadmin/phpmyadmin
Redis Manage erikdubbelboer/phpredisadmin
Prometheus bitnami/prometheus
Grafana grafana/grafana
Jaeger Jaegertracing/all – in – one: 1.28

2.2.2 write.envThe configuration file

TZ = # set time zone Asia/Shanghai # Paths # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # on host code storage directory path CODE_PATH_HOST =. / code # On host Mysql Reids data storage directory path DATA_PATH_HOST. = # Mysql/data # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # MYSQL_HOST = Mysql Mysql service mapping host port number, MYSQL_USERNAME=admin MYSQL_PASSWORD=123456 MYSQL_ROOT_PASSWORD=123456 # Mysql Visual management mapping host port numbers, Available on the host 127.0.0.1:1000 access MYSQL_MANAGE_PORT = 1000 # REDIS # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # REDIS_HOST = REDIS REDIS The service maps the host port number, REDIS_PORT=6379 # Redis visual admin user name REDIS_MANAGE_USERNAME=admin # Redis visual admin user password REDIS_MANAGE_PASSWORD=123456 # Redis visualized management mapping host port number, Available on the host 127.0.0.1:2000 access REDIS_MANAGE_PORT = 2000 # ETCD # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # ETCD mapping hosting service port, Available on the host 127.0.0.1:2379 access ETCD_PORT = 2379 # PROMETHEUS # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # PROMETHEUS mapping hosting service port, Available on the host 127.0.0.1:3000 access PROMETHEUS_PORT = 3000 # GRAFANA # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # GRAFANA mapping hosting service port, Available on the host 127.0.0.1:4000 access GRAFANA_PORT = 4000 # JAEGER # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # JAEGER mapping hosting service port, JAEGER_PORT=5000 is accessible from the host 127.0.0.1:5000Copy the code

Then writedocker-compose.ymlThe configuration file

version: '3.0'
# Network configuration
networks:
  backend:                       # Custom network name
    driver: bridge               # Network mode
    ipam:                        IP address management
      config:                    # config information
        - subnet: 172.30. 0. 0/ 16  # Network segment configuration

Service container configuration
services:
  golang:                                Create a custom container name
    build:
      context: ./golang                  # specify the Dockerfile file to use for the build
    environment:                         Set environment variables
      - TZ=${TZ}
    volumes:                             Set the mount directory
      - ${CODE_PATH_HOST}:/usr/src/code  # reference the CODE_PATH_HOST variable in the. Env configuration to mount the host code directory to /usr/src/code in the container
    ports:                               Set port mapping
      - "8000:8000"
      - "8001:8001"
      - "8002:8002"
      - "8003:8003"
      - "9000:9000"
      - "9001:9001"
      - "9002:9002"
      - "9003:9003"
    stdin_open: true                     Turn on standard input to accept external input
    tty: true
    networks:                            # Set up network
      backend:                           Specify network configuration name
        ipv4_address: 172.30. 02.         The container IP address must be in the specified network segment
    restart: always                      Set the container exit restart policy to always restart

  etcd:                                  Create a custom container name
    build:
      context: ./etcd                    # specify the Dockerfile file to use for the build
    environment:
      - TZ=${TZ}
      - ALLOW_NONE_AUTHENTICATION=yes
    ports:                               Set port mapping
      - "${ETCD_PORT}:2379"
    networks:
      backend:
        ipv4_address: 172.30. 03.         The container IP address must be in the specified network segment
    restart: always

  mysql:
    build:
      context: ./mysql
    environment:
      - TZ=${TZ}
      - MYSQL_USER=${MYSQL_USERNAME}                  Mysql > set user name for Mysql
      - MYSQL_PASSWORD=${MYSQL_PASSWORD}              Mysql > set Mysql user password
      - MYSQL_ROOT_PASSWORD=${MYSQL_ROOT_PASSWORD}    Mysql root password
    volumes:
      - ${DATA_PATH_HOST}/mysql:/var/lib/mysql        /var/lib/ Mysql/DATA_PATH_HOST /var/lib/ Mysql
    ports:
      - "${MYSQL_PORT}:3306"                          Set container 3306 port mapping to specify host port
    networks:
      backend:
        ipv4_address: 172.30. 04.
    restart: always

  redis:
    build:
      context: ./redis
    environment:
      - TZ=${TZ}
    volumes:
      - ${DATA_PATH_HOST}/redis:/data                 Env to mount the host directory containing Redis data to /data
    ports:
      - "${REDIS_PORT}:6379"                          Set container 6379 port mapping to specify host port
    networks:
      backend:
        ipv4_address: 172.30. 0. 5
    restart: always

  mysql-manage:
    build:
      context: ./mysql-manage
    environment:
      - TZ=${TZ}
      - MYSQL_USER=${MYSQL_USERNAME}                  Mysql > set user name to connect to Mysql server
      - MYSQL_PASSWORD=${MYSQL_PASSWORD}              Set mysql service user password for connection
      - MYSQL_ROOT_PASSWORD=${MYSQL_ROOT_PASSWORD}    Mysql server root password
      - PMA_ARBITRARY=1
      - PMA_HOST=${MYSQL_HOST}                        Mysql > connect to host; Mysql > connect to host
      - PMA_PORT=3306                                 Mysql > connect to Mysql server
    ports:
      - "${MYSQL_MANAGE_PORT}:80"                     Container 80 port mapping specifies the host port used by the host to access the visual Web
    depends_on:                                       # dependency container
      - mysql                                         Start the Mysql server container after it is started
    networks:
      backend:
        ipv4_address: 172.30. 06.
    restart: always

  redis-manage:
    build:
      context: ./redis-manage
    environment:
      - TZ=${TZ}
      - REDIS_1_HOST=${REDIS_HOST}                    Redis host = Redis host = Redis host = Redis host
      - REDIS_1_PORT=6379                             Set the Redis service port number for the connection
      - ADMIN_USER=${REDIS_MANAGE_USERNAME}           Set user name for Redis visual management
      - ADMIN_PASS=${REDIS_MANAGE_PASSWORD}           # Set user password for Redis visual management
    ports:
      - "${REDIS_MANAGE_PORT}:80"                     Container 80 port mapping specifies the host port used by the host to access the visual Web
    depends_on:                                       # dependency container
      - redis                                         Start after the Redis service container is started
    networks:
      backend:
        ipv4_address: 172.30. 07.
    restart: always

  prometheus:
    build:
      context: ./prometheus
    environment:
      - TZ=${TZ}
    volumes:
      - ./prometheus/prometheus.yml:/opt/bitnami/prometheus/conf/prometheus.yml  Mount the Prometheus configuration file to the container
    ports:
      - "${PROMETHEUS_PORT}:9090"                     Container 9090 port mapping specifies the host port used by the host to access the visual Web
    networks:
      backend:
        ipv4_address: 172.30. 08.
    restart: always

  grafana:
    build:
      context: ./grafana
    environment:
      - TZ=${TZ}
    ports:
      - "${GRAFANA_PORT}:3000"                        Container 3000 port mapping specifies the host port for the host to access the visual Web
    networks:
      backend:
        ipv4_address: 172.30. 09.
    restart: always

  jaeger:
    build:
      context: ./jaeger
    environment:
      - TZ=${TZ}
    ports:
      - "${JAEGER_PORT}:16686"                        Set container 16686 port mapping to specify host ports for host access to the visual Web
    networks:
      backend:
        ipv4_address: 172.30. 010.
    restart: always
Copy the code

2.2.4 Build and Run

  • usedocker-composeCommand to build and start running our service container by executing the following command in the root directory:
$ docker-compose up -d
Copy the code
  • Container Under construction

  • inWindowsThe following figure shows the system container construction, please selectShare itThis will allowWindowsTo the container directory.

  • The container is running

2.2.5 Container Description

Container name Exposure to port The IP address instructions
golang A 8000-8000

A 8001-8001

A 8002-8002

A 8003-8003

A 9000-9000

A 9001-9001

A 9002-9002

A 9003-9003
172.30.0.2 Microservices are typically clustered in a production environment, with one microservice per server or one microservice per container. In order to facilitate the development and debugging, we willgolangStart all microservices in the container and assign them to listen to different port numbers to distinguish them.

80: The starting port number we will useapiservice

90: The starting port number we will userpcservice
etcd A 2379-2379 172.30.0.3 Etcd http apiService port number for client interaction.

In this project we are only inDockerInternal container access between the use, so also can not expose the port number to the host
mysql A 3306-3306 172.30.0.4 MysqlService default port number that the host can pass127.0.0.1:3306Connect to the database
redis A 6379-6379 172.30.0.5 RedisService default port number that the host can pass127.0.0.1:6379Connect to the database
mysql-manage A 1000-80 172.30.0.6 phpMyAdmin webThe service port number can be on the host127.0.0.1:1000access
redis-manage A 2000-80 172.30.0.7 phpRedisAdmin webThe service port number can be on the host127.0.0.1:2000access
prometheus A 3000-9090 172.30.0.8 Prometheus webThe service port number can be on the host127.0.0.1:3000access
grafana A 4000-3000 172.30.0.9 Grafana webThe service port number can be on the host127.0.0.1:4000access
jaeger A 5000-16686 172.30.0.10 Jaeger webThe service port number can be on the host127.0.0.1:5000access

2.2.6 Access Verification

  • MysqlAccess authentication

  • RedisAccess authentication

  • PrometheusAccess authentication

  • GrafanaAccess authentication

  • JaegerAccess authentication