Обслуживать Go API на Linux сервере - PullRequest
0 голосов
/ 24 января 2020

После нескольких уроков я все еще не могу заставить мой API работать должным образом. Локально работает, но когда я добавляю его на сервер, я просто не могу подключиться. Может кто-нибудь, пожалуйста, проведите меня?

Я использую сервер Ubuntu 18.04 с NGINX. API написан на GoLang.

Моя структура папок:

/ var / www/example.com/

/ var / www/example.com/GoAPI/

Очевидно, что API находится в папке GoAPI (я знаю, что присвоение имен плохое, но это просто для целей обучения).

API использует Gorilla Mux и обслуживает ": 8000". Мой интерфейс написан на Typescript и использует Ax ios. Он пытается подключиться к «http://example.com/GoAPI/».

У меня есть мой стандартный блок сервера (только 1 атм), который только что определил мое имя сервера и «пробные файлы», и это на момент. Я попытался добавить проход прокси, но это, похоже, ничего не помогло.

Ошибка, которую я получаю сейчас, это «Ошибка:« Ошибка сети »и ошибка CORS, хотя CORS работал локально, и я добавил методы CORS, которые дает вам Gorilla Mux.

Надеюсь, кто-нибудь может мне помочь.

Файл блокировки сервера на данный момент:

server {
  listen 80;
  listen [::]:80;

  root /var/www/example.com;
  index index.html index.htm index.nginx-debian.html;

  server_name example.com www.example.com;

  location / {
        try_files $uri $uri/ =404;
  }
}

Nginx конфигурация просто Из коробки я ничего не менял.

Мой конфигурационный файл выглядит так:

user www-data; worker_processes auto; pid /run/nginx.pid; include /etc/nginx/modules-enabled/*.conf;

events {    worker_connections 768;     # multi_accept on; }

http {

    ##  # Basic Settings    ##

    sendfile on;    tcp_nopush on;  tcp_nodelay on;     keepalive_timeout 65;   types_hash_max_size 2048;   # server_tokens off;

    server_names_hash_bucket_size 64;   # server_name_in_redirect off;

    include /etc/nginx/mime.types;  default_type application/octet-stream;

    ##  # SSL Settings  ##

    ssl_protocols TLSv1 TLSv1.1 TLSv1.2; # Dropping SSLv3, ref: POODLE  ssl_prefer_server_ciphers on;

    ##  # Logging Settings  ##

    access_log /var/log/nginx/access.log;   error_log /var/log/nginx/error.log;

    ##  # Gzip Settings     ##

    gzip on;

    # gzip_vary on;     # gzip_proxied any;     # gzip_comp_level 6;    # gzip_buffers 16 8k;   # gzip_http_version 1.1;    # gzip_types text/plain text/css application/json application/javascript text/xml application/xml application/xml+rss text/javascript;

    ##  # Virtual Host Configs  ##

    include /etc/nginx/conf.d/*.conf;   include /etc/nginx/sites-enabled/*; }


#mail {
#   # See sample authentication script at:
#   # http://wiki.nginx.org/ImapAuthenticateWithApachePhpScript
#
#   # auth_http localhost/auth.php;
#   # pop3_capabilities "TOP" "USER";
#   # imap_capabilities "IMAP4rev1" "UIDPLUS";
#
#   server {
#       listen     localhost:110;
#       protocol   pop3;
#       proxy      on;
#   }
#
#   server {
#       listen     localhost:143;
#       protocol   imap;
#       proxy      on;
#   }
#}

1 Ответ

2 голосов
/ 24 января 2020

В настоящее время в вашем файле конфигурации Nginx ничего не настроено для подключения к службе через порт 8000. Самый простой и быстрый способ сделать это - использовать директиву ProxyPass и добавить контекст местоположения в файл конфигурации внутри блок сервера.

Например, ваш пример должен выглядеть примерно так:

server {
    listen 80;
    server_name example.com;

    location /GoAPI {
        proxy_pass http://127.0.0.1:8000;
    }
 }

Помните, что при настройке файла конфигурации Nginx служба должна быть перезагружена / перезапущена, чтобы изменения вступили в силу. Вы также можете проверить файлы, используя nginx -t, чтобы убедиться, что синтаксис правильный.

...