Docker builds laravel development environment example
This article mainly uses laradock
for local docker configuration. laradock
has integrated the environment that laravel needs to use. You only need to simply modify the configuration to build an environment for development. It is really a good solution for development and management.
A brief explanation, in the docker
environment we need to run the laravel
project, and actually create several containers (containers): when the computer is still a window system , it is often necessary to build an environment based on vm services in order to develop better (should be closer to the online environment), but now under the mysterious aura of docker, it is possible to build a local development environment with minimal resources
environment, while being able to better migrate to other places.
workspace (development environment)
php-fpm (php support)
nginx (web service)
mysql (database)
These are generated based on reprocessing of laradock
For containers, please refer to the directory with the corresponding name under the laradock
directory, which contains Dockerfile
and related configurations. Interested students can read and learn as much as you like:)
More in-depth It is recommended to move the content to laradock official documentation.
Preparation
Install docker under the window system first
docker command to test it.
git to pull
https://github.com/ laradock/laradock.gitThis package.
# 平级目录 D:/www/ - /laradock - /my-projectNow you are ready to proceed to the next step. ConfigurationThe environment configured here is configured according to the common environment
- nginx
- php-fpm 5.6
- mysql 5.6
laradock/.env file
/www/laradock - .envEnter# The ##laradock
directory will find that the .env
file does not exist. Here we need to copy a copy from env-example
to modify it. <pre class="brush:php;toolbar:false"># /www/laradock
$ cp env-example .env</pre>
Modify PHP version
Enter the
.env file and findPHP_VERSION
Modify the PHP version to 56 (default 71, optional 71, 70, 56 ). <pre class="brush:php;toolbar:false"># /www/laradock/.env
### PHP Version
PHP_VERSION=56</pre>
Modify Mysql version and configuration
Enter the
.env file and find MYSQL
Modify the mysql version to 56 (default 8, optional 8, 5 , 5.6, 5.5). Other settings are filled in according to personal needs. Generally,
, MYSQL_PASSWORD
, MYSQL_ROOT_PASSWORD
need to be modified to ensure the link. <pre class="brush:php;toolbar:false"># /www/laradock/.env
### MYSQL
MYSQL_VERSION=5.6
# MYSQL_DATABASE 可选,填写后会默认创建同名数据库
MYSQL_DATABASE=default
# MYSQL_USER 用户,填写后会创建用户,默认为 default
MYSQL_USER=packy
# MYSQL_PASSWORD 密码,填写后作为新建用户的密码,默认为 secret
MYSQL_PASSWORD=123456-
# MYSQL_PORT 访问端口,默认是3306,建议不要修改
MYSQL_PORT=3306
# MYSQL_ROOT_PASSWORD root用户密码,建议使用严谨的密码,默认为 root
MYSQL_ROOT_PASSWORD=23333-
MYSQL_ENTRYPOINT_INITDB=./mysql/docker-entrypoint-initdb.d</pre>
About Mysql version selection
mysql uses the official image, so we can use hub.docker.com to query
mysqlwhich versions the official image contains. The specific choice depends on your individual needs.
Modify nginx configuration
Generally, there is no need to modify anything, just use the default one. Regarding the configuration of the website, you need to enter
laradock/nginx/sites. If you need to modify the port, you can enter the
file and findnginxNGINX
to modify it.<pre class="brush:php;toolbar:false"># /www/laradock/.env ### NGINX NGINX_HOST_HTTP_PORT=80 NGINX_HOST_HTTPS_PORT=443 # NGINX_HOST_LOG_PATH log存放位置,默认位置在laradock/logs/nginx/ NGINX_HOST_LOG_PATH=./logs/nginx/ # NGINX_SITES_PATH 网站配置, 默认位置在laradock/nginx/sites/ NGINX_SITES_PATH=./nginx/sites/ NGINX_PHP_UPSTREAM_CONTAINER=php-fpm NGINX_PHP_UPSTREAM_PORT=9000</pre>
About Nginx configuration
The configuration file is stored under laradock/nginx/sites
. If you need to create a new website, you can copy it. .example
and rename it to .conf
for modification. Note: Only .conf
files will be loaded under nginx
. Here I copy
as an example and rename it to my-project.conf
: <pre class="brush:php;toolbar:false"># laradock/nginx/sites/my-project.conf
server {
listen 80;
listen [::]:80;
# 域名,改为你的域名
server_name my-project.com;
# 项目目录,均以 /var/www/ 开头。这个约定后续会说明
root /var/www/my-project;
index index.php index.html index.htm;
location / {
try_files $uri $uri/ /index.php$is_args$args;
}
location ~ \.php$ {
try_files $uri /index.php =404;
fastcgi_pass php-upstream;
fastcgi_index index.php;
fastcgi_buffers 16 16k;
fastcgi_buffer_size 32k;
fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
include fastcgi_params;
}
location ~ /\.ht {
deny all;
}
location /.well-known/acme-challenge/ {
root /var/www/letsencrypt/;
log_not_found off;
}
error_log /var/log/nginx/laravel_error.log;
access_log /var/log/nginx/laravel_access.log;
}</pre>
Also modify the host (that is window local machine)
<pre class="brush:php;toolbar:false"># C:\Windows\System32\drivers\etc\hosts
127.0.0.1 my-project.com</pre>
try to run
At this point, the preparation work is almost completed.
Run the following command to install and use it. Please wait patiently because the pulling time from foreign sources is slow.
docker-compose up -d nginx mysql
After completion, enter
to see the container running status. everything is normal! ! !
Try visiting
to see the effect. Currently, the php
file can be accessed normally.
Running laravel
I cannot mention the
workspace container, which serves as a workspace to provide various types of Tool usage (including: PHP CLI, Composer, Git, Linuxbrew, Node, V8JS, Gulp, SQLite, xDebug, Envoy, Deployer, Vim, Yarn, etc.). How to use these functions?
首先进入workspace
容器
# /www/laradock docker-compose exec workspace bash
composer换国内源
进到容器后默认就是项目目录/var/www
,由于composer用的是国外源比较慢,这里需要切换成国内源。
composer config -g repo.packagist composer https://packagist.phpcomposer.com
安装laravel
这里我们需要在my-project
目录安装laravel。
*注:需要提前把my-project里的所有内容清空
composer create-project laravel/laravel my-project2 "5.2.*" && \ cd my-project && \ php artisan key:generate
配置并重启nginx
安装完成后,把laradock/nginx/sites/my-project.conf
文件下的网站目录地址稍微改一下
server { listen 80; listen [::]:80; server_name my-project.com; # 加上public目录 root /var/www/my-project/public; index index.php index.html index.htm; ... }
重启nginx
容器
# /www/laradock docker-compose restart nginx
关于数据库服务
# .env DB_CONNECTION=mysql # mysql的容器网络已经解析至"mysql"域,所以这里配置"mysql"域便能访问 DB_HOST=mysql # 默认3306,一般不需要改动,如要改动端口应该与laradock/.env中的MYSQL_PORT一致 DB_PORT=3306 # 数据库 DB_DATABASE=default # 用户 DB_USERNAME=packy # 密码 DB_PASSWORD=123456-
一些问题:
Q:运行失败,提示ERROR: for laradock_mysql_1 Cannot create container for service mysql: Drive sharing seems blocked by a firewall
A:先暂停你本机杀毒程序的防御进程。
Q:运行失败,提示ERROR: for laradock_nginx_1 Cannot start service nginx: driver failed programming external connectivity on endpoint laradock_nginx_1 (6e4f4761d30f4cd80c44c6b0fddfbd4ef0324529099aace02bee6a6653ce453a): Error starting userland proxy: Bind for 0.0.0.0:443 failed: port is already allocated
A:建议你切换端口,我已尝试改为1443能正常运行,目前只能以这种方式处理。
# .env ### NGINX NGINX_HOST_HTTPS_PORT=1443
Q:为何网站目录必须以/var/www
开头?
A:网站访问进入的是nginx
容器,/var/www
目录就是容器内网站目录存放的位置。由于配置在创建容器时,会将本地目录挂载至/var/www
目录,所以就能访问到本地的代码。这块设置在laradock/.env
中找到APPLICATION
可自行设置。
相关推荐:
The above is the detailed content of Docker builds laravel development environment example. For more information, please follow other related articles on the PHP Chinese website!

PHP type prompts to improve code quality and readability. 1) Scalar type tips: Since PHP7.0, basic data types are allowed to be specified in function parameters, such as int, float, etc. 2) Return type prompt: Ensure the consistency of the function return value type. 3) Union type prompt: Since PHP8.0, multiple types are allowed to be specified in function parameters or return values. 4) Nullable type prompt: Allows to include null values and handle functions that may return null values.

In PHP, use the clone keyword to create a copy of the object and customize the cloning behavior through the \_\_clone magic method. 1. Use the clone keyword to make a shallow copy, cloning the object's properties but not the object's properties. 2. The \_\_clone method can deeply copy nested objects to avoid shallow copying problems. 3. Pay attention to avoid circular references and performance problems in cloning, and optimize cloning operations to improve efficiency.

PHP is suitable for web development and content management systems, and Python is suitable for data science, machine learning and automation scripts. 1.PHP performs well in building fast and scalable websites and applications and is commonly used in CMS such as WordPress. 2. Python has performed outstandingly in the fields of data science and machine learning, with rich libraries such as NumPy and TensorFlow.

Key players in HTTP cache headers include Cache-Control, ETag, and Last-Modified. 1.Cache-Control is used to control caching policies. Example: Cache-Control:max-age=3600,public. 2. ETag verifies resource changes through unique identifiers, example: ETag: "686897696a7c876b7e". 3.Last-Modified indicates the resource's last modification time, example: Last-Modified:Wed,21Oct201507:28:00GMT.

In PHP, password_hash and password_verify functions should be used to implement secure password hashing, and MD5 or SHA1 should not be used. 1) password_hash generates a hash containing salt values to enhance security. 2) Password_verify verify password and ensure security by comparing hash values. 3) MD5 and SHA1 are vulnerable and lack salt values, and are not suitable for modern password security.

PHP is a server-side scripting language used for dynamic web development and server-side applications. 1.PHP is an interpreted language that does not require compilation and is suitable for rapid development. 2. PHP code is embedded in HTML, making it easy to develop web pages. 3. PHP processes server-side logic, generates HTML output, and supports user interaction and data processing. 4. PHP can interact with the database, process form submission, and execute server-side tasks.

PHP has shaped the network over the past few decades and will continue to play an important role in web development. 1) PHP originated in 1994 and has become the first choice for developers due to its ease of use and seamless integration with MySQL. 2) Its core functions include generating dynamic content and integrating with the database, allowing the website to be updated in real time and displayed in personalized manner. 3) The wide application and ecosystem of PHP have driven its long-term impact, but it also faces version updates and security challenges. 4) Performance improvements in recent years, such as the release of PHP7, enable it to compete with modern languages. 5) In the future, PHP needs to deal with new challenges such as containerization and microservices, but its flexibility and active community make it adaptable.

The core benefits of PHP include ease of learning, strong web development support, rich libraries and frameworks, high performance and scalability, cross-platform compatibility, and cost-effectiveness. 1) Easy to learn and use, suitable for beginners; 2) Good integration with web servers and supports multiple databases; 3) Have powerful frameworks such as Laravel; 4) High performance can be achieved through optimization; 5) Support multiple operating systems; 6) Open source to reduce development costs.


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

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.

PhpStorm Mac version
The latest (2018.2.1) professional PHP integrated development tool

DVWA
Damn Vulnerable Web App (DVWA) is a PHP/MySQL web application that is very vulnerable. Its main goals are to be an aid for security professionals to test their skills and tools in a legal environment, to help web developers better understand the process of securing web applications, and to help teachers/students teach/learn in a classroom environment Web application security. The goal of DVWA is to practice some of the most common web vulnerabilities through a simple and straightforward interface, with varying degrees of difficulty. Please note that this software

Dreamweaver Mac version
Visual web development tools

Dreamweaver CS6
Visual web development tools