docker内部的django服务连接宿主机的mysql

今天把负责的django项目做了一个docker,部署到了自己的服务器上。

遇到的比较麻烦的问题,docker内部连接不上宿主机的mysql,边查边试:

1、数据库配置文件,默认的没修改

bind-address   = 127.0.0.1

2、docker启动时要配置host网络模式,docker访问的ip就直接是主机ip了。docker run参数是--net或者--network,还不太一样,

3、数据连接参数不能用localhost,只能用127.0.0.1,应该是bind-address配置的原因?

web服务的Dockerfile文件:

FROM env:1.0.0
COPY sources.list /etc/apt/
RUN  apt-get update -y
WORKDIR /server
ENV DB_ADDR=127.0.0.1:3306
ENV DB_PASS="xxxxxx" 
COPY ./PushAdminServer /server
COPY ./Dockerfile /server/
EXPOSE 8000
CMD /usr/local/bin/gunicorn -w 4 --threads 2 -b 0.0.0.0:8000 settings.wsgi

基础环境镜像的Dockerfile:

FROM ubuntu:14.04
COPY sources.list /etc/apt/
COPY requirements.txt .
RUN  apt-get update -y
RUN apt-get install python-pip -y
RUN apt-get install python2.7 
RUN apt-get install vim -y
RUN apt-get install build-essential python-dev libmysqlclient-dev -y
RUN apt-get install mysql-server -y
RUN apt-get install python-mysqldb -y
RUN pip install -r /requirements.txt

 

您好!对于 Docker 中 Superset 无法连接宿主机 MySQL 的问题,可以尝试以下解决方案: 1. 确保宿主机 MySQL 服务正常运行,并且已经配置了正确的用户名、密码以及数据库连接信息。您可以在宿主机上使用命令行或者图形化工具来验证连接是否正常。 2. 在 Docker 中运行 Superset 容器时,确保正确映射了宿主机 MySQL 的端口。例如,如果宿主机 MySQL 使用的是默认的 3306 端口,则可以使用以下命令来运行 Superset 容器: ``` docker run -p 8088:8088 -e SUPERSET_CONFIG=superset.config -e SUPERSET_CONFIG=superset.config -v /path/to/superset:/home/superset superset ``` 其中,`-p 8088:8088` 表示将容器的 8088 端口映射到宿主机的同样端口,`-v /path/to/superset:/home/superset` 表示将宿主机中的 Superset 配置文件目录挂载到容器中。 3. 在 Superset 的配置文件中,确保正确配置了 MySQL 数据库的连接信息。您可以在 Superset 配置文件中找到以下配置项,并根据宿主机 MySQL 的配置进行相应修改: ``` SQLALCHEMY_DATABASE_URI = 'mysql://username:password@hostname:port/database_name' ``` 其中,`username`、`password`、`hostname`、`port` 和 `database_name` 需要替换为宿主机 MySQL 的实际信息。 4. 如果仍然无法连接,可以尝试检查宿主机防火墙设置,确保允许 Superset 容器访问宿主机 MySQL 的网络连接。 希望以上解决方案对您有所帮助!如果还有其他问题,请随时提问。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值