У меня есть 2 приложения, работающие на ASW Symfony на порту 8000 (локальный) и реагирующий на 3000 (локальный), но доступные через TCP на 80-м порту, перенаправления были достигнуты путем прослушивания порта 80 на сервере nginx.
server {
listen 80;
server_name example.info www.example.info;
location / {
proxy_pass http://127.0.0.1:3000;
proxy_http_version 1.1;
proxy_set_header Upgrade $http_upgrade;
proxy_set_header Connection 'upgrade';
proxy_set_header Host $host;
proxy_cache_bypass $http_upgrade;
proxy_redirect off;
}
}
server {
listen 8000;
server_name example.info www.example.info;
location / {
proxy_pass http://127.0.0.1:8000;
proxy_http_version 1.1;
proxy_set_header Upgrade $http_upgrade;
proxy_set_header Connection 'upgrade';
proxy_set_header Host $host;
proxy_cache_bypass $http_upgrade;
proxy_redirect off;
}
}
Я попытался прослушать и перенаправить два порта, но безуспешно. На сервере приложение Symfony доступно с помощью curl http://127.0.0.1:8000 Извне в моем приложении для реагирования я отправляю запросы api на asw.external.ip (123.123.123.123:800), но у меня тайм-аут. Как я мог получить доступ к своей серверной части извне?
1. Вы будете использовать приложение React в CloudFront (его очень легко использовать). Я помогу тебе с этим, если тебе нужно.
2. Ваше приложение API будет перехватывать использование порта nginx. Я приведу вам пример.
Вы проверили логи nginx? У вас есть ошибки?





Вы также можете использовать этот файл конфигурации для своего Aws Ec2.
/etc/nginx/conf.d/proxy.conf
upstream nodejs {
server 127.0.0.1:5000;
keepalive 256;
}
server {
listen 8080;
access_log /var/log/nginx/access.log main;
location / {
proxy_pass http://nodejs;
proxy_set_header Connection "";
proxy_http_version 1.1;
proxy_set_header Host $host;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
}
gzip on;
gzip_comp_level 4;
gzip_types text/html text/plain text/css application/json application/x-javascript text/xml application/xml application/xml+rss text/javascript;
## Optional configuration if you want to allow AWS
## to cache your static files
location /static {
alias /var/app/current/static;
}
}
server {
listen 8080;
server_name sf2testproject.dev;
root /home/maurits/public_html/web;
location / {
# try to serve file directly, fallback to rewrite
try_files $uri @rewriteapp;
}
location @rewriteapp {
# rewrite all to app.php
rewrite ^(.*)$ /app.php/$1 last;
}
location ~ ^/(app|app_dev|config)\.php(/|$) {
fastcgi_pass 127.0.0.1:9000;
fastcgi_split_path_info ^(.+\.php)(/.*)$;
include fastcgi_params;
fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
fastcgi_param HTTPS off;
}
}
Где:
listen - это порт, по которому ваше приложение взаимодействует с миром.fastcgi_pass - это двоичный протокол для взаимодействия интерактивных программ с веб-сервером.Рекомендации:
С прокси он работает, но теперь это еще хуже, потому что я этого не понимаю :) Итак, я слушаю и перенаправляю порт 80 в два места / etc / nginx / sites-available / default, как в моем исходном вопросе, а теперь Я добавил /etc/nginx/conf.d/proxy.conf, как в вашем примере. Как получается, что мой интерфейс отображается с узла на локальном порту 3000, и у меня есть доступ к api на локальном порту 8000, где моя symfony просто вызывает http 80 извне?
1. Итак .. Вы можете сделать резервную копию вашего файла default как /etc/nginx/backup/default.bkp и протестировать его, используя мой.
2. Чтобы лучше понять, вы можете протестировать его, добавив server_name и еще несколько.
3. Nginx связывает ваш прокси-сервер с миром, используя порт 80 и порт прокси для связи с вашим серверным приложением. Я обновил свой ответ выше. ;)
еще один вопрос, как я могу управлять большим количеством перенаправлений здесь, в прокси, если я хочу, чтобы еще один node.js работал на локальном порте 3001, как я могу получить к нему доступ извне, когда у меня уже есть доступ к порту 3000 (приложение-реакция) и 8000 (symfony -приложение)? Спасибо.
Вам просто нужно добавить еще одну конфигурацию nginx ИЛИ запустить приложение node.js без nginx и настроить безопасность группы AWS на свой порт 3001 для связи с миром.
Правильно ли вы настроили группы безопасности? Вам необходимо внести в белый список входящие вызовы на порт 8000