1

我在远程 linux 服务器上安装了 neo4j-server。该服务器使用 nginx 并具有虚拟主机。这是配置:

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

    server_name neo.mydomain.in.ua;

    access_log /var/log/nginx/neo-browser-access.log;
    error_log /var/log/nginx/neo-browser-error.log;

    location / {
        proxy_pass http://localhost:7474;
        proxy_set_header Host $host;
        proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
        proxy_set_header X-Real-IP $remote_addr;
    }
}

我使用它是因为我不能使用端口 7474,只能使用 80 或 8080。

http://neo.mydomain.in.ua/browser/,效果很好,我看到了neo4j-browser。但我无法使用任何客户端(即使使用控制台客户端)连接到数据库。我懂了:

>> neo4j-client -u neo4j neo.mydomain.in.ua 80
OpenSSL error: 336031996:SSL routines:SSL23_GET_SERVER_HELLO:unknown protocol
error: Unexpected error

但是当我尝试使用邮递员时,我得到了

>> http://neo.mydomain.in.ua/db/data/

{
    "errors": [
        {
            "code": "Neo.ClientError.Security.Unauthorized",
            "message": "No authentication header supplied."
        }
    ]
}

这意味着我可以访问数据库,但不能通过 neo4j-client。我尝试使用基本身份验证登录,它的工作原理。

怎么了?

4

2 回答 2

1

您需要打开 7687 端口才能连接 Neo4j 数据库。

从邮递员连接时,提供身份验证并将连接 URL 中的端口更改为 7687。

于 2019-03-20T16:42:59.613 回答
1

问题解决了。我只是取消注释

dbms.connectors.default_listen_address=0.0.0.0

在我的 neo4j.conf 中。但奇怪的是,即使这个选项被禁用,我也可以使用邮递员登录 neo4j。\(0_0)/

于 2019-03-22T14:14:09.523 回答