Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

How to access host MySQL server in a Docker container?

I have a MySQL server on my host machine and I want my docker containers connect to it, instead of create a MySQL container.

In my application configuration file I'm using localhost, as I used to do before using Docker, but the connection is being refused.

I'm using docker-compose and here is my .yml:

version: "3.2"

services:
    php:
        build: 
            context: './dockerfiles/php/'
            args:
                PHP_VERSION: ${PHP_VERSION}
        networks:
            - backend
        volumes:
            - ${PROJECT_ROOT}/:/var/www/html/
        container_name: acadbase_php

    apache:
        build:
            context: './dockerfiles/apache/'
            args:
                APACHE_VERSION: ${APACHE_VERSION}
        depends_on:
            - php
        networks:
            - frontend
            - backend
        ports:
            - "8080:80"
        volumes:
            - ${PROJECT_ROOT}/:/var/www/html/
        container_name: acadbase_apache

networks:
    frontend:
    backend:

volumes:
    data:

My ./dockerfiles/php/Dockerfile:

ARG PHP_VERSION=""
FROM php:${PHP_VERSION:+${PHP_VERSION}-}fpm-alpine

RUN apk update; \
    apk upgrade; \
    apk add libxml2-dev

RUN docker-php-ext-install mysqli soap mbstring xml pdo_mysql

My ./dockerfiles/apache/Dockerfile:

ARG APACHE_VERSION=""
FROM httpd:${APACHE_VERSION:+${APACHE_VERSION}-}alpine

RUN apk update; \
    apk upgrade; \
    apk add vim;

COPY acadbase.conf /usr/local/apache2/conf/acadbase.conf
RUN echo "Include /usr/local/apache2/conf/acadbase.conf" \
    >> /usr/local/apache2/conf/httpd.conf

My .env:

PHP_VERSION=7.1
APACHE_VERSION=2.4
PROJECT_ROOT=.
like image 438
Thiago B. Bittencourt Avatar asked Oct 30 '25 22:10

Thiago B. Bittencourt


1 Answers

As @StrahinjaTasic and @AvinashReddy said, I need to use the IP of my host machine, but it was not working only because I needed to do more things in my MySQL local server.

1- I needed to allow the database user connects from the container IP (or from everywhere) instead of only from localhost.

# use the correct IP if it is not for local development
GRANT ALL PRIVILEGES ON *.* TO '[user]'@'%';

FLUSH PRIVILEGES;

For MySQL GRANT command details see: https://dev.mysql.com/doc/refman/5.7/en/grant.html

2- I needed to change MySQL configuration file to let it listen not only localhost, but also the container IP (or everywhere).

In my case, the configuration file is /etc/mysql/mysql.conf.d/mysqld.conf.

# use the correct IP if it is not for local development
bind-address = 0.0.0.0

After that I put the IP of my host machine and my database user credentials in my application configuration file and it worked!

P.S.: To get the container IP see How to get a Docker container's IP address from the host?

like image 115
Thiago B. Bittencourt Avatar answered Nov 01 '25 12:11

Thiago B. Bittencourt



Donate For Us

If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!