I am a firm believer of keeping my host system clean. And Docker containers are the perfect solution to this. Let's say you are working on a React app with a Node / Express backend and a MySQL server for your DB needs. Typically, you would install mysql in your host system, create a database, create a user with a password and grant the user privileges to work with that database.
Instead of wasting time in configuring this every single time for every single project, I just use a Docker image to create my MySQL database server, to be ready, up and running in a few seconds, with all the necessary setup I would ever need.
Trust me, once you figure out your workflow using this route, you will never go back to the old ways. So, here is how I go about it and a very simple, basic manner.
If you have some experience with Docker and wish to skip this tutorial and jump in with a TLDR version directly, this Gist would be much faster.
What will we need?
To use Docker, we need Docker, duh! I will not go into the detail of installing Docker here. If you aren't comfortable with a CLI or your are on Windows/MacOS, go for Docker Desktop, it will do all the heavy lifting for you behind the scenes.
Linux users could install Docker Engine with the Docker Compose plugin or Docker Desktop too if you aren't feeling it.
You typically don't need an account on Docker Hub to download public images likeMySQL official image that we will be using.
Alright, what now?
There are two ways of doing this.
Using Docker Run (Not Recommended)
To be able to directly run the container using the docker run command, you will have to have downloaded the MySQL image on your system first. To pull the image to your system, simply use this command:
docker pull mysql
Note: If you do not need a particular version of MySQL, then this command will download the latest one (the one with the latest tag). You could explore more tags and versions from the Docker Hub if you need.
Once Docker is done downloading, you can see your downloaded image like this:
docker image ls
Now, to run the container, you have to add a lot of flags with the docker run command. You can visit this link to check all the options you have. You also need to remember all the flags you need to add since missing some might throw errors or start an incapable container.
Besides, every time you wish to run your container, you will either have to fish out this long command from the terminal history, or type it out again. There is no point of that.
This is the reason why I DO NOT recommend this approach. There is a better way.
Docker Compose
We will create a Docker Compose file which will tell Docker what we need while launching the container. Once everything is laid out in the file, launching the container becomes a piece of cake.
Note: You can create your compose file with any name. If you use your own name or store your compose file in other folders, you will have to provide a flag -f to make it work. Alternatively, if you are running the command from the same folder as your file, then you can name the file docker-compose.yaml.
A Docker Compose file is a YAML file. Ours will look like this:
# This Docker Compose YAML deploys a MySQL database services: container-name: image: mysql # Official MySQL image from Docker Hub restart: always environment: # Note - Root password is mandatory for the container to run and grant privileges to our User. MYSQL_ROOT_PASSWORD: ${MYSQL_ROOT_PASSWORD} MYSQL_DATABASE: ${MYSQL_DATABASE} # Same name as used in your project # DB User Details MYSQL_USER: ${MYSQL_USER} MYSQL_PASSWORD: ${MYSQL_PASSWORD} ports: # Adjust this port as per your needs -> <hostport>:<containerport> - 3308:3306 # DB is available at localhost:3308 on the host. volumes: - ./volumes/db-mnt:/var/lib/mysql </containerport></hostport>
This file is also available on the Gist mentioned in the beginning.
Important To Know
- Port-Mapping: The first port is the host port (your system) which is mapped to the second port (the port inside the docker container). This means, in the above example, you can access the database at localhost:3308. Unless, you know what you are doing, keep the second port as 3306. This is the default port for MySQL.
- Volume Bind Mount: We are mounting a local volume to the container to persist the data inside the database. This makes it easy to backup and move around if needed. You could also let Docker manage it's own volume and create periodic backups on your host system. #### The Environment File To supply the necessary credentials to Docker while creating the container, we will create a .env file, just like how we do in our React or Backend apps.
You can either create this file in the same folder where your compose file is, or you can create it anywhere you like but will need to supply the path while calling docker-compose.
# Content of the Environment Variables file MYSQL_ROOT_PASSWORD=rootpassword MYSQL_DATABASE=nameofdatabase MYSQL_USER=dbusername MYSQL_PASSWORD=dbuserpassword
Once we have all this in place, we can simply use one little command and our database will be up and ready waiting for us.
docker-compose up -d
You are now ready to make a connection to the database using your preferred means.
And since we have configured our containers to run from a compose file, you could safely back it up in a git system in your repo. Just make sure you .gitignore the .env file.
The above is the detailed content of Using MySQL in a Docker Container for your Projects. For more information, please follow other related articles on the PHP Chinese website!

The article discusses using MySQL's ALTER TABLE statement to modify tables, including adding/dropping columns, renaming tables/columns, and changing column data types.

Article discusses configuring SSL/TLS encryption for MySQL, including certificate generation and verification. Main issue is using self-signed certificates' security implications.[Character count: 159]

Article discusses strategies for handling large datasets in MySQL, including partitioning, sharding, indexing, and query optimization.

Article discusses popular MySQL GUI tools like MySQL Workbench and phpMyAdmin, comparing their features and suitability for beginners and advanced users.[159 characters]

The article discusses dropping tables in MySQL using the DROP TABLE statement, emphasizing precautions and risks. It highlights that the action is irreversible without backups, detailing recovery methods and potential production environment hazards.

The article discusses creating indexes on JSON columns in various databases like PostgreSQL, MySQL, and MongoDB to enhance query performance. It explains the syntax and benefits of indexing specific JSON paths, and lists supported database systems.

Article discusses using foreign keys to represent relationships in databases, focusing on best practices, data integrity, and common pitfalls to avoid.

Article discusses securing MySQL against SQL injection and brute-force attacks using prepared statements, input validation, and strong password policies.(159 characters)


Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

AI Hentai Generator
Generate AI Hentai for free.

Hot Article

Hot Tools

SublimeText3 Chinese version
Chinese version, very easy to use

Dreamweaver Mac version
Visual web development tools

WebStorm Mac version
Useful JavaScript development tools

Notepad++7.3.1
Easy-to-use and free code editor

SecLists
SecLists is the ultimate security tester's companion. It is a collection of various types of lists that are frequently used during security assessments, all in one place. SecLists helps make security testing more efficient and productive by conveniently providing all the lists a security tester might need. List types include usernames, passwords, URLs, fuzzing payloads, sensitive data patterns, web shells, and more. The tester can simply pull this repository onto a new test machine and he will have access to every type of list he needs.
