Настройка nginx в качестве прокси для работы с зеркалом devpi на HP-облаке
Я пытаюсь создать зеркало devpi в облаке HP, к которому будет обращаться через nginx, т.е. nginx прослушивает порт 80 и используется в качестве прокси для devpi, использующего порт 4040 на той же машине.
Я настроил группу безопасности HP-cloud, которая открывается для всех портов (входящих и исходящих) в hp-cloud (только для начала, я, конечно, позже ее изменю), и запустил экземпляр ubuntu 14.
Я назначил общедоступный IP-адрес созданному экземпляру.
Я установил devpi-сервер, используя pip, и nginx, используя apt-get.
Я следовал инструкциям на странице tutuorial devpi в здесь:
побежал devpi-server --port 4040 --gen-config
и скопировал содержимое, созданное в nginx-devpi.conf, в nginx.conf.
Затем я запустил сервер, используя devpi-server --port 4040 --start
,
Запустил nginx используя sudo nginx
,
Моя проблема заключается в следующем: когда я SSHing к экземпляру hp, на котором запущены nginx и devpi, и выполняю pip install -i http://<public-ip>:80/root/pypi/ simplejson
это удалось.
Но когда я запускаю ту же команду с моего ноутбука, я получаю
Downloading/unpacking simplejson
Cannot fetch index base URL http://<public-ip>:80/root/pypi/
http://<public-ip>:80/root/pypi/simplejson/ uses an insecure transport scheme (http). Consider using https if <public-ip>:80 has it available
Could not find any downloads that satisfy the requirement simplejson
Cleaning up...
No distributions at all found for simplejson
Storing debug log for failure in /home/hagai/.pip/pip.log
Я думал, что это может быть проблема безопасности / сети, но я думаю, что это не так, потому что curl http://<public-ip>:80
возвращает то же самое, когда я выполняю его с моего ноутбука и из экземпляра HP:
{
"type": "list:userconfig",
"result": {
"root": {
"username": "root",
"indexes": {
"pypi": {
"type": "mirror",
"bases": [],
"volatile": false
}
}
}
}
}
Я также попытался запустить другой экземпляр в облаке HP и выполнить pip install -i http://<public-ip>:80/root/pypi/ simplejson
, но я получил ту же ошибку, что и в моем ноутбуке.
Я не могу понять, в чем разница между этими двумя случаями, и я был бы рад, если бы у кого-то было решение для этого случая или какая-либо идея, в чем может быть проблема.
мой nginx.conf
файл:
user www-data;
worker_processes 4;
pid /run/nginx.pid;
events {
worker_connections 768;
# multi_accept on;
}
http {
server {
server_name localhost;
listen 80;
gzip on;
gzip_min_length 2000;
gzip_proxied any;
#gzip_types text/html application/json;
proxy_read_timeout 60s;
client_max_body_size 64M;
# set to where your devpi-server state is on the filesystem
root /home/ubuntu/.devpi/server;
# try serving static files directly
location ~ /\+f/ {
error_page 418 = @proxy_to_app;
if ($request_method != GET) {
return 418;
}
try_files /+files$uri @proxy_to_app;
}
# try serving docs directly
location ~ /\+doc/ {
try_files $uri @proxy_to_app;
}
location / {
error_page 418 = @proxy_to_app;
return 418;
}
location @proxy_to_app {
proxy_pass http://localhost:4040;
#dynamic: proxy_set_header X-outside-url $scheme://$host:$server_port;
proxy_set_header X-outside-url http://localhost:80;
proxy_set_header X-Real-IP $remote_addr;
}
}
##
# 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;
##
# Logging Settings
##
access_log /var/log/nginx/access.log;
error_log /var/log/nginx/error.log;
##
# Gzip Settings
##
gzip on;
gzip_disable "msie6";
#passenger_root /usr;
#passenger_ruby /usr/bin/ruby;
##
# Virtual Host Configs
##
include /etc/nginx/conf.d/*.conf;
#include /etc/nginx/sites-enabled/*;
}
редактировать: я пытался использовать devpi-client
с моего ноутбука, и когда я казнил devpi use http://<public-ip>:80
со своего ноутбука я получаю следующее:
using server: http://localhost/ (not logged in)
no current index: type 'devpi use -l' to discover indices
~/.pydistutils.cfg : no config file exists
~/.pip/pip.conf : no config file exists
~/.buildout/default.cfg: no config file exists
always-set-cfg: no
1 ответ
Вы можете попробовать изменить это:
location @proxy_to_app {
proxy_pass http://localhost:4040;
#dynamic: proxy_set_header X-outside-url $scheme://$host:$server_port;
proxy_set_header X-outside-url http://localhost:80;
proxy_set_header X-Real-IP $remote_addr;
}
К этому
location @proxy_to_app {
proxy_pass http://localhost:4040;
proxy_set_header X-outside-url $scheme://$host;
proxy_set_header X-Real-IP $remote_addr;
}
Это была работа для меня:-).