Nowadays it is a must-have skill to use docker for your development. To start the development with docker here are some prerequisites:
- If you’re on Windows you have WSL installed on your system. It will also be required for Docker.
- You have Docker installed on your system.
- You have Visual Studio Code installed with the following extensions
- An interface to connect to a database like MySQL
Now let’s start a sample PHP project to develop with docker.
- Create directory php-base-docker
- Open this directory in VSCode. If you’re on a Windows system it is recommended to use WSL
- Create file
index.php
and type the code as shown in the screenshot below
data:image/s3,"s3://crabby-images/d61bd/d61bdeeae84eeba24f6a79c3980d4b167058eae5" alt="PHP Development with VS Code and Docker Dev Containers php docker container,php vs code"
- Now press
Ctl+Shift+P
, search for ‘Dev Containers: Open Folder in Container…’ and hit enter.
data:image/s3,"s3://crabby-images/38b30/38b30b47a7bc8b9c28470a42752bd8b5bc8c644a" alt="PHP Development with VS Code and Docker Dev Containers php docker container,php vs code"
- Select your current directory
data:image/s3,"s3://crabby-images/1be33/1be3314625fab060d279957859e55a1a4664ac73" alt="PHP Development with VS Code and Docker Dev Containers php docker container,php vs code"
- In the next step at ‘Add Dev Container Configuration Files’ search and select ‘PHP & MariaDB’
data:image/s3,"s3://crabby-images/a57cc/a57cc6405d1f173af2ea0f814e678795d7459422" alt="PHP Development with VS Code and Docker Dev Containers php docker container,php vs code"
- Select the PHP version. 8.2-bullseye is PHP 8.2 version.
data:image/s3,"s3://crabby-images/5a6f5/5a6f56b9a0c8b037f3e4006458040bc6f87ddaf9" alt="PHP Development with VS Code and Docker Dev Containers php docker container,php vs code"
- Then select any features to install if you want or leave empty and hit OK
data:image/s3,"s3://crabby-images/928f6/928f6b89a2508af6b58b97d2ecc250dbfde8e981" alt="PHP Development with VS Code and Docker Dev Containers php docker container,php vs code"
- It will create a directory
.devcontainer
and a few files in it
data:image/s3,"s3://crabby-images/14ef7/14ef72e2b4e913753cb18ebf70d054a572d3cb52" alt="PHP Development with VS Code and Docker Dev Containers php docker container,php vs code"
- You can check that now VS Code has opened this directory in container mode. If you open the terminal and run the command
uname
you will see that you’re already inside the container
data:image/s3,"s3://crabby-images/d3e29/d3e2905d2d57fa12edaac4b08ddd9150bcfb1ec3" alt="PHP Development with VS Code and Docker Dev Containers php docker container,php vs code"
- In the terminal run the following command
sudo chmod a+x "$(pwd)" && sudo rm -rf /var/www/html && sudo ln -s "$(pwd)" /var/www/html
data:image/s3,"s3://crabby-images/3dda7/3dda7a03a1000c040aaa0943df3b4aa975b0f958" alt="PHP Development with VS Code and Docker Dev Containers php docker container,php vs code"
- Then run the following command to check if Apache web server is running
service apache2 status
data:image/s3,"s3://crabby-images/a53f1/a53f176de39ce087e8425ff6a1e595d6167d519a" alt="PHP Development with VS Code and Docker Dev Containers php docker container,php vs code"
- If it is not then run the following command to run the Apache server
service apache2 start
data:image/s3,"s3://crabby-images/e4bb8/e4bb838ef13cbde2a412ce1d390c4b84d355de8f" alt="PHP Development with VS Code and Docker Dev Containers php docker container,php vs code"
- In the Ports tab you can see what ports are being forwarded so you can connect to them from your local system
data:image/s3,"s3://crabby-images/ba65c/ba65cfb1098b32721f3a49b7fcf032216fee4233" alt="PHP Development with VS Code and Docker Dev Containers php docker container,php vs code"
It is possible that you need URL rewriting enabled in apache. To do so run the following commands.
sudo a2enmod rewrite
service apache restart
- You can connect to database using your favorite client or you can install any related extension
data:image/s3,"s3://crabby-images/a40bb/a40bb363f7672e651afca0bf6eac6c7bd337a701" alt="PHP Development with VS Code and Docker Dev Containers php docker container,php vs code"
- You can connect to this MariaDB database server using mariadb as username and password and connect to
localhost
on port 3306.
data:image/s3,"s3://crabby-images/f0271/f0271186002ea80ea0064aa81efcdcede4a443e5" alt="PHP Development with VS Code and Docker Dev Containers php docker container,php vs code"
data:image/s3,"s3://crabby-images/0644b/0644b9bf0f234f60a910174bbf8df53b03e447a8" alt="PHP Development with VS Code and Docker Dev Containers php docker container,php vs code"
- You can also debug the code. Press
Ctrl+Shift+D
to start the debugger.
For further reading see the references section below.
Add a Comment