1

我正在开发一个使用 Zappa 在 Lambda 上托管无服务器应用程序的 Django 项目。它在背面使用 Postgres 数据库,我已经能够完美地使用它一段时间了。最近需要使用 urllib,所以需要一个 NAT 实例(EC2 微实例)来让 Lambda 访问互联网。

现在它已经设置好了,它在生产中运行良好,我可以看到我的站点很好,并且所有部分都可以正确交互。但是,在本地,Django 似乎无法连接,它收到此错误:

django.db.utils.OperationalError: could not connect to server: Connection timed out (0x0000274C/10060)
server is running on host "XXXXXXXXX.XXXXXXXXX.us-west-2.rds.amazonaws.com" (54.70.245.158)并接受端口 5432 上的 TCP/IP 连接?

为了概述我所经历的步骤,我通过向导创建了一个包含私有子网和公有子网的 VPC 网络。为了可用性,我在其他区域添加了另外 2 个私有子网。我转到我的 Lambda 函数并将子网更改为新子网,我还将我的 RDS 移动到相同的子网(私有子网)。对于我的 RDS,我为 Postgres 创建了一个新的安全组(端口 5432 入站,源为 0.0.0.0/0)。

我在 Django 下的 settings.py 保持不变:

DATABASES = {
    # AMAZON RDS Instance
    'default': {
        'ENGINE': 'django.db.backends.postgresql_psycopg2',
        'NAME': 'XXXXXXXXX',
        'USER': 'XXXXXXXXX',
        'PASSWORD': 'XXXXXXXXX',
        'HOST': 'XXXXXXXXXX.XXXXXXXXXX.us-west-2.rds.amazonaws.com',
        'PORT': '5432',
    }
}

我不知道从这里去哪里。老实说,这超出了我的舒适区,我不知道自己在做什么。我怀疑我需要与安全组做一些事情,但我在我的头上,非常感谢一些帮助。谢谢!

4

1 回答 1

0

经过一番摆弄,我意识到我把事情复杂化了。RDS 应保留在它启动的子网中,无需将其带到与 NAT 实例相同的子网中。一旦我将它移回原来的子网,它在本地和生产中都运行良好。

于 2018-10-20T01:01:02.963 回答