質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.35%
Gunicorn

Gunicorn (Green Unicorn)は、Rubyのunicornをベースに開発されたUNIX向けのPython製HTTPサーバです。他のライブラリとの依存関係がないため、容易にインストールして使用できます。

Django

DjangoはPythonで書かれた、オープンソースウェブアプリケーションのフレームワークです。複雑なデータベースを扱うウェブサイトを開発する際に必要な労力を減らす為にデザインされました。

nginx

nginixは軽量で高性能なwebサーバーの1つです。BSD-likeライセンスのもとリリースされており、あわせてHTTPサーバ、リバースプロキシ、メールプロキシの機能も備えています。MacOSX、Windows、Linux、上で動作します。

API

APIはApplication Programming Interfaceの略です。APIはプログラムにリクエストされるサービスがどのように動作するかを、デベロッパーが定めたものです。

React.js

Reactは、アプリケーションのインターフェースを構築するためのオープンソースJavaScriptライブラリです。

Q&A

解決済

1回答

1567閲覧

EC2にデプロイしたアプリで、Nginxの設定ができない

k_takahashi

総合スコア6

Gunicorn

Gunicorn (Green Unicorn)は、Rubyのunicornをベースに開発されたUNIX向けのPython製HTTPサーバです。他のライブラリとの依存関係がないため、容易にインストールして使用できます。

Django

DjangoはPythonで書かれた、オープンソースウェブアプリケーションのフレームワークです。複雑なデータベースを扱うウェブサイトを開発する際に必要な労力を減らす為にデザインされました。

nginx

nginixは軽量で高性能なwebサーバーの1つです。BSD-likeライセンスのもとリリースされており、あわせてHTTPサーバ、リバースプロキシ、メールプロキシの機能も備えています。MacOSX、Windows、Linux、上で動作します。

API

APIはApplication Programming Interfaceの略です。APIはプログラムにリクエストされるサービスがどのように動作するかを、デベロッパーが定めたものです。

React.js

Reactは、アプリケーションのインターフェースを構築するためのオープンソースJavaScriptライブラリです。

0グッド

0クリップ

投稿2021/05/20 08:28

わからないこと

ローカルで開発していたアプリケーションをAWS EC2にデプロイしたのですが、サーバーがうまく動きません。
Nginxの設定がうまくいっていないのではないかと考えています。

前提条件

開発しているアプリケーションの言語は、
React + Django REST frameworkで、
仕様としては、ReactからfetchでAPIを取得するようなものです。

ローカルでは、
Reactサーバーはnpm startを、APIサーバーはDjangoのrunserverを使っています。

このアプリケーションをAWS EC2にデプロイするにあたって、
NginxでReactを動かして、GunicornでAPIを動かす想定です。

現状どうなっているか

Nginxの設定をして、Reactのサーバーは立ち上げることが出来て、画面を表示することはできています。
Gunicornもインストール済で、Gunicornのプロセスは立ち上がっています。

しかし、ReactからfetchでAPIを取得する処理を行うとエラーが起き、
Chromeデベロッパーツールで確認すると下記エラーが起きていました。
(ローカルではこのエラーは出ずに動いていました。)

POST http://localhost:8000/api/obtain net::ERR_CONNECTION_REFUSED

上記エラーの該当箇所のソースです。

export async function PostAPI(url,data){ const response=await fetch(url, { method: "POST", mode:'cors', headers: {"Content-Type": "application/json"}, body: JSON.stringify(data) }) return response.json() }

上記を呼び出している箇所のソースです。

login(event){ const { cookies } = this.props this.render(); PostAPI("http://localhost:8000/api/login",this.state.data) .then((res) => { console.log("Receive", res) if(res.token){ cookies.set('token',res.token) window.location.href="/Top" }else{ this.setState({message:"NG"}) } this.render() }) event.preventDefault() }

考えていること

ローカルでは動いていたので、NginxとGunicornの設定に問題があると考えています。
Gunicornについてはインストールして、そのままgunicorn [プロジェクト名].wsgi -Dという感じで使っています。
nginx.confは下記内容です(一部抜粋)。

server { listen 80; server_name [EC2のIP]; location / { proxy_pass http://localhost:3000; } } server { listen localhost:8000; location /api { proxy_pass http://localhost:8000; } }

私の考えではNginxがうまく動いていないと考えております。
どなたかわかる方、教えていただけますと嬉しいです。

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

hoshi-takanori

2021/05/20 17:19

localhost とは何のことかお分かりでしょうか? PostAPI("http://localhost:8000/api/login",this.state.data) の localhost を EC2 のホスト名または IP アドレスにする必要があります。また、http://localhost:3000 で webpack-dev-server を動かしてるとしたら、それはあまり良くない気が…。
guest

回答1

0

自己解決

解決しました!
ご指摘の通り、
PostAPI("http://localhost:8000/api/login",this.state.data) の localhost を EC2 のホスト名または IP アドレスにするという点で解決しました。
webpack-dev-serverの件については、また調べてみます。
ありがとうございました。

投稿2021/05/21 01:05

k_takahashi

総合スコア6

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.35%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問