Laravel с выданным исключением mailcatcher Не может назначить запрошенный адрес

#php #laravel #docker-compose #mailcatcher

Вопрос:

Я столкнулся с ошибкой при использовании mailcatcher с laravel ( «laravel/framework»: «^8.54»,)

 "message": "Connection could not be established with host localhost :stream_socket_client(): unable to connect to localhost:8003 (Cannot assign requested address)",
  "exception": "Swift_TransportException",
  "file": "/var/www/vendor/swiftmailer/swiftmailer/lib/classes/Swift/Transport/StreamBuffer.php",
  "line": 261,
 

Итак, я отправил электронное письмо, как обычно, я проверил используемую почту по умолчанию smpt

config/mail.php

 'mailers' => [
    'smtp' => [
        'transport' => 'smtp',
        'host' => env('MAIL_HOST', 'smtp.mailgun.org'),
        'port' => env('MAIL_PORT', 587),
        'encryption' => env('MAIL_ENCRYPTION', 'tls'),
        'username' => env('MAIL_USERNAME'),
        'password' => env('MAIL_PASSWORD'),
        'timeout' => null,
        'auth_mode' => null,
    ],
 

в коде

 use IlluminateSupportFacadesMail;
//

Mail::send((new ContactUsEmail($contactUs)));
 

мой .env

 MAIL_MAILER=smtp
MAIL_HOST=localhost
MAIL_PORT=8003
MAIL_USERNAME=null
MAIL_PASSWORD=null
MAIL_ENCRYPTION=null
MAIL_FROM_ADDRESS=from_admin@admin.com
MAIL_TO_ADDRESS=to_admin@admin.com
MAIL_FROM_NAME="${APP_NAME}"
MAIL_TO_NAME=admin
 

Когда я отлаживаю его в
Swift_Transport_StreamBuffer

 params = {array} [8]
 protocol = ""
 host = "localhost"
 port = {int} 8003
 timeout = {int} 30
 blocking = {int} 1
 tls = false
 type = {int} 1
 stream_context_options = {array} [0]
 

похоже, порт правильный

почтовый ловец доступен, когда я открываю http://localhost:8100/

докер-создание yml:

 php-larabostad:
    build:
        context: .
        dockerfile: ./php/Dockerfile
    restart: on-failure
    volumes:
        - "../:/var/www"
        - "./php/php.ini:/usr/local/etc/php/conf.d/custom.ini"
        - "./data/php:/var/larabostad:z"
    networks:
        - php-larabostad-networks
        - mysql-larabostad-networks
        - mailcatcher-larabostad-networks


mailcatcher:
    image: schickling/mailcatcher:latest
    container_name: myapp-mailcatcher
    ports:
        - "8003:1025"
        - "8100:1080"
    networks:
        - mailcatcher-larabostad-networks
 

докер-составьте ps

 docker_nginx-larabostad_1   /docker-entrypoint.sh ngin ...   Up      0.0.0.0:443->443/tcp,:::443->443/tcp,                            
                                                                     0.0.0.0:80->80/tcp,:::80->80/tcp                                 
docker_php-larabostad_1     bash /usr/local/bin/docker ...   Up      9000/tcp                                                         
myapp-mailcatcher           mailcatcher --no-quit --fo ...   Up      0.0.0.0:8003->1025/tcp,:::8003->1025/tcp,                        
                                                                     0.0.0.0:8100->1080/tcp,:::8100->1080/tcp                         
mysql8                      docker-entrypoint.sh mysql ...   Up      0.0.0.0:3306->3306/tcp,:::3306->3306/tcp, 33060/tcp   
 

что я делаю не так ?

Обновить

выполнил пинг из контейнера php

 /var/www# ping mailcatcher
PING mailcatcher (172.23.0.2) 56(84) bytes of data.
64 bytes from myapp-mailcatcher.docker_mailcatcher-larabostad-networks (172.23.0.2): icmp_seq=1 ttl=64 time=0.237 ms
64 bytes from myapp-mailcatcher.docker_mailcatcher-larabostad-networks (172.23.0.2): icmp_seq=2 ttl=64 time=0.138 ms
 

новая ошибка

   "message": "Connection could not be established with host mailcatcher :stream_socket_client(): unable to connect to mailcatcher:8003 (Connection refused)",
  "exception": "Swift_TransportException",
  "file": "/var/www/vendor/swiftmailer/swiftmailer/lib/classes/Swift/Transport/StreamBuffer.php",
  "line": 261,
 

Ответ №1:

Все службы docker в compose работают в одной сети (по умолчанию). Если вы хотите подключиться от одной службы к другой — используйте их имя. И, поскольку вы подключаетесь к частной сети — используйте стандартный порт

 MAIL_HOST=mailcatcher
MAIL_PORT=1025
 

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

1. не помогло, я обновил свой вопрос

2. @shuba.иван обновил

3. ты был прав, спасибо