Развернутая служба AWS copilot недоступна?

#amazon-web-services #amazon-ecs

Вопрос:

У меня есть простое серверное устройство, которое я только что развернул с помощью второго пилота. Однако я не знаю, где к нему получить доступ?

Согласно консоли AWS, она запущена и активна. Я даже вижу в журналах, что он был запущен.

Мой манифест:

 # The manifest for the "user-service" service.
# Read the full specification for the "Backend Service" type at:
#  https://aws.github.io/copilot-cli/docs/manifest/backend-service/

# Your service name will be used in naming your resources like log groups, ECS services, etc.
name: user-service
type: Backend Service

# Your service does not allow any traffic.

# Configuration for your containers and service.
image:
  # Docker build arguments. For additional overrides: https://aws.github.io/copilot-cli/docs/manifest/backend-service/#image-build
  build: ./Dockerfile
  port: 9000

cpu: 256       # Number of CPU units for the task.
memory: 512    # Amount of memory in MiB used by the task.
count: 1       # Number of tasks that should be running in your service.

# Optional fields for more advanced use-cases.
#
variables:                    # Pass environment variables as key value pairs.
  SERVER_PORT: 9000
  NODE_ENV: test
  
secrets:                      # Pass secrets from AWS Systems Manager (SSM) Parameter Store.
  ACCESS_TOKEN_SECRET: ACCESS_TOKEN_SECRET
  REFRESH_TOKEN_SECRET: REFRESH_TOKEN_SECRET
  MONGODB_URL: MONGODB_URL

# You can override any of the values defined above by environment.
environments:
  test:
    variables:
      NODE_ENV: test
#    count: 2               # Number of tasks to run for the "test" environment.
 

Мой Док-файл

 # Check out https://hub.docker.com/_/node to select a new base image
FROM node:lts-buster-slim

# Set to a non-root built-in user `node`
USER node

# Create app directory (with user `node`)
RUN mkdir -p /home/node/app

WORKDIR /home/node/app

# Install app dependencies
# A wildcard is used to ensure both package.json AND package-lock.json are copied
# where available (npm@5 )
COPY --chown=node package*.json ./

RUN npm install

# Bundle app source code
COPY --chown=node . .

RUN npm run build

# Bind to all network interfaces so that it can be mapped to the host OS
ENV HOST=0.0.0.0 PORT=3000

EXPOSE 9000
CMD [ "node", "." ]
 

Это прекрасно работает локально, с помощью docker-compose. Но где я могу найти URL-адрес развернутой службы? Я проверил консоль ECS, и у задачи есть общедоступный IP-адрес. Однако я не могу подключиться к этому.

Чего здесь не хватает?

Ответ №1:

Нм… моя вина. Внутренние службы не должны быть доступны через Интернет. Они предоставляют конечные точки, но должны общаться друг с другом (или с внешним интерфейсом) через обнаружение служб.