Произошла ошибка с redis HMSEET, наберите tcp: 6379: connect: отказано в подключении

#docker #go #redis #docker-compose

# #docker #Вперед #redis #docker-compose

Вопрос:

У меня есть серверная часть с докеризованным сервером golang gin, postgresql и redis.

Все начинается правильно с этого файла docker-compose.yaml :

 version: '3.9'
services:
  postgresql:
    image: 'postgres:13.1-alpine'
    volumes: 
      - data:/var/lib/postgresql/data
    env_file: 
      - ./env/postgre.env
    healthcheck:
        test: ["CMD-SHELL", "pg_isready -U postgres"]
        interval: 10s
        timeout: 5s
        retries: 5
    ports: 
      - '5432:5432'
  server:
    build: ./server
    ports:
      - '8000:8000'
    volumes: 
      - ./server:/app
    depends_on: 
      - postgresql
  redis:
    image: "redis"
    ports: 
      - "6379:6379"
    volumes: 
      - $PWD/redis-data:/var/lib/redis

volumes: 
  data:
 

Затем я инициализирую redis в основной функции :

 func main() {
    util.InitializeRedis()
    (...)
 

// InitializeRedis func

 func newPool() *redis.Pool {
    return amp;redis.Pool{
        MaxIdle:3,
        IdleTimeout:240 * time.Second,
        DialContext: func(context.Context) (redis.Conn, error) {
            return redis.Dial("tcp",":6379")
        },
    }
}

var (
    pool *redis.Pool
)



func InitializeRedis() {
    flag.Parse()
    pool = newPool()
}
 

Он не выдает никаких сообщений об ошибках, но я не могу установить соединение с pool.Get в другой функции :

// Обработайте «/ redis» для проверки

 router.GET("/redis", util.ServeHome)
 

// ServeHome функция

функция ServeHome (ctx * gin.Context) {

 conn := pool.Get()
defer conn.Close()

var p1 struct{
    Title string `redis:"title" json:"title"`
    Author string `redis:"author" json:"author"`
    Body string `redis:"body" json:"body"`
}

p1.Title = "Example"
p1.Author = "Gary"
p1.Body = "Hello"

if _, err := conn.Do("HMSET", redis.Args{}.Add("id1").AddFlat(amp;p1)...); err != nil {
    log.Fatalf("Error occured with redis HMSEET, %v", err) // Error in console is from here
    return
}

(...)
 

И когда я пытаюсь получить доступ к / redis с Insomnia, он показывает: Ошибка: сервер ничего не вернул (ни заголовков, ни данных) и в журналах консоли: произошла ошибка с redis HMSEET, наберите tcp: 6379: connect: отказано в подключении

Я не смог найти ни одной статьи, которая решила бы эту проблему для меня, поэтому я ценю любую помощь.

Ответ №1:

Поскольку вы используете docker-compose, Redis не будет доступен :6379 , вместо этого он будет доступен в имени хоста redis .

Я думаю, вам нужно будет обновить свой код следующим образом:

 redis.Dial("tcp","redis:6379")
 

Комментарии:

1. Да, это именно то, что устранило мою проблему. Я сделал то же самое с postgresql, но я совершенно забыл об этом. Спасибо