【问题标题】:Django + MySQL on Elastic Beanstalk - Error When Querying MySQLElastic Beanstalk 上的 Django + MySQL - 查询 MySQL 时出错
【发布时间】:2026-01-20 00:05:01
【问题描述】:

我在弹性 beanstalk 上托管的 Django 应用程序上查询 MySQL 时遇到错误。错误说:

/admin/login 处的操作错误 (1045,“用户'adminDB'@'172.30.23.5'的访问被拒绝(使用密码:YES)”)

这是我的 .config 文件:

container_commands:
  01_migrate:
    command: "source /opt/python/run/venv/bin/activate && python manage.py migrate --noinput"
    leader_only: true

option_settings:
  "aws:elasticbeanstalk:application:environment":
    DJANGO_SETTINGS_MODULE: "mysite.settings"
    "PYTHONPATH": "/opt/python/current/app/mysite:$PYTHONPATH"
    "ALLOWED_HOSTS": ".elasticbeanstalk.com"
  "aws:elasticbeanstalk:container:python":
    WSGIPath: mysite/wsgi.py
    NumProcesses: 3
    NumThreads: 20
  "aws:elasticbeanstalk:container:python:staticfiles":
    "/static/": "www/static/"

这是我在 settings.py 上的数据库部分:

DATABASES = {
        'default': {
            'ENGINE': 'django.db.backends.mysql',
            'NAME': os.environ['RDS_DB_NAME'],
            'USER': os.environ['RDS_USERNAME'],
            'PASSWORD': os.environ['RDS_PASSWORD'],
            'HOST': os.environ['RDS_HOSTNAME'],
            'PORT': os.environ['RDS_PORT'],
        }
    }

我通过eb create 命令创建了 eb 环境,然后在他们网站的 eb 控制台上创建了一个 RDS 数据库。我还需要做些什么来将 Django 连接到 MySQL 吗?与安全组有关吗?

谢谢!

【问题讨论】:

  • 我怀疑您的安全组在 Aws 上很好(检查一下),但 mysql 表 grants 不是
  • 有人可以提示我将哪些模块放入需求文本文件中以使 Elastic Beanstalk 接受我的 Django 上传。我已经尝试了好几天了。也许有人有教程或一些不错的链接,我可以在那里找到帮助!

标签: python mysql django amazon-web-services amazon-elastic-beanstalk


【解决方案1】:

感谢@DrewPierce 的回复,但问题很简单,而且非常愚蠢。原来我的 RDS 密码中的美元符号导致了问题。改成更简单的密码就成功登录了。

希望这可以帮助遇到类似问题的其他人!

【讨论】:

  • 天哪,玩了一整天!谢谢!
  • 3 小时就完事了。感谢您的回答!
  • 3 小时挠头,我无法想象这有多傻,不可能!