婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > 詳解用Docker搭建Laravel和Vue項目的開發環境

詳解用Docker搭建Laravel和Vue項目的開發環境

熱門標簽:遼寧電銷平臺外呼系統軟件 百應電銷機器人靠譜嗎 如何在各種地圖標注自己的地址 菏澤crm外呼系統價格 coreldraw地圖標注 信陽銷售外呼系統招商 營銷電銷機器人招商 申請400電話號碼多少錢 物超所值的400電話申請

本文介紹了用Docker搭建Laravel和Vue項目的開發環境,分享給大家,具體如下:


在這篇文章中我們將通過Docker在個人本地電腦上構建一個快速、輕量級、不依賴本地電腦所安裝的任何開發套件的可復制的Laravel和Vue項目的開發環境(開發環境的所有依賴都安裝在Docker構建容器里),加入Vue只是因為有的項目里會在Laravel項目中使用Vue做前后端分離開發,開發環境中需要安裝前端開發需要的工具集,當然前后端也可以分成兩個項目開發,這個話題不在本篇文章的討論范圍內。

所以我們的目標是:

  • 不在本地安裝Mamp/Wamp這樣的軟件
  • 不使用類似Vagrant這樣的虛擬機
  • 不在本地電腦全局安裝PHP開發所需要的工具集
  • 不在本地電腦全局安裝前端開發所需要的工具集
  • 不在本地電腦全局安裝Mysql和Nginx

開始前你需要先去安裝一個Docker客戶端,Docker的官網中有詳細的安裝方法。

第一步:獲取Laravel的源碼包

因為我們電腦上不安裝Composer,所以就不能使用Composer來創建Laravel項目了, 這里我使用cURL直接從github上下載了最新的Laravel源碼包,你也可以使用wget或者git clone 來獲取源碼包。

curl -L -O https://github.com/laravel/laravel/archive/v5.5.0.tar.gz /
&& tar -zxvf v5.5.0.tar.gz /
&& rm v5.5.0.tar.gz

上面的命令在curl下載完源碼包后會解壓源碼壓縮包,解壓完成后在把源碼壓縮包v5.5.0.tar.gz刪掉,執行完后你會看到一個laravel-5.5.0的項目目錄。

第二步:添加docker-compose.yml

在項目中創建docker-compose.yml文件。

Compose 項目是 Docker 官方的開源項目,負責實現對 Docker 容器集群的快速編排。我們知道使用一個 Dockerfile 模板文件,可以讓用戶很方便的定義一個單獨的應用容器。在這里我們會用到四個容器分別將PHPMysql、Nginx放在四個不同的容器中,通過compose`將四個應用容器關聯到一起組成項目。

編排文件的開頭如下:

version: '2'
services:
  # our services will go here

在編排文件中,把每個容器叫做一個服務,services下定義整個應用中用到的所有服務(即容器)。

App服務

APP服務的容器將執行我們項目中的代碼。

app:
 build:
  context: ./
  dockerfile: app.dockerfile
 working_dir: /var/www
 volumes:
  - ./:/var/www
 environment:
  - "DB_PORT=3306"
  - "DB_HOST=database"

Notes:

  • 我們使用app.dockerfile這個鏡像文件來構建我們的App容器,在鏡像文件中我們會對項目中用到的PHP模塊鏡像配置,也會額外安裝NPM用來構建前端代碼。
  • working_dir: /var/www把工作目錄設置成了/var/www,在容器中項目代碼將會被放在/var/www目錄下面,包括使用docker exec app執行的命令也都是以/var/www為當前工作目錄的。
  • volumes是容器內數據卷所掛載路徑設置,在這里我們只定義一個數據卷,把宿主機項目目錄掛到在容器中的/var/www上,這樣我們在本地電腦對項目代碼進行的更改就會馬上同步到容器中去,反過來也是一樣,容器中對代碼做的更改也會及時反饋到本地電腦的項目中。
  • environment設置環境變量名,這里我們設置了DB_PORTDB_HOST 這樣就不用修改項目中的.env文件里關于這兩項的值了,當然任何你需要在開發環境單獨設置的環境變量都可以寫到這里,Laravel讀取配置使用的DotEnv會檢測是否系統有指定環境變量的設置,有的話就不會在去讀取.env文件了。

現在我們需要創建上面build環節中提到的app.dockerfile這個文件了,具體內容如下:

FROM php:7.1.22-fpm

# Update packages
RUN apt-get update

# Install PHP and composer dependencies
RUN apt-get install -qq git curl libmcrypt-dev libjpeg-dev libpng-dev libfreetype6-dev libbz2-dev

# Clear out the local repository of retrieved package files
# RUN apt-get clean

# Install needed extensions
# Here you can install any other extension that you need during the test and deployment process
RUN apt-get clean; docker-php-ext-install pdo pdo_mysql mcrypt zip gd pcntl opcache bcmath


# Installs Composer to easily manage your PHP dependencies.
RUN curl --silent --show-error https://getcomposer.org/installer | php -- --install-dir=/usr/local/bin --filename=composer

# Install Node
RUN apt-get update &&\

  apt-get install -y --no-install-recommends gnupg &&\

  curl -sL https://deb.nodesource.com/setup_10.x | bash - &&\

  apt-get update &&\

  apt-get install -y --no-install-recommends nodejs &&\

  npm config set registry https://registry.npm.taobao.org --global &&\

  npm install --global gulp-cli

CMD php-fpm

Notes:

我在這里先將NPM和Composer裝到了app容器中,因為在開發時經常需要執行他們,如果發布到生產環境,一般是使用單獨的composer對項目代碼進行構建而不是放在運行應用的容器里,容器的核心思想之一就是保持單一,這樣才能做到快速增加相同角色的容器。

Web服務

接下來,我們需要配置一個Web服務器用,我們把這個容器在編排文件中命名成web

web:
 build:
  context: ./
  dockerfile: web.dockerfile
 working_dir: /var/www
 volumes_from:
  - app
 ports:
  - 8080:80

Notes:

  • volumes_from用來復用在app服務中定義的數據卷路徑
  • 通過ports將本地電腦的8080端口映射到web容器的80端口,這樣在開發環境中我們就不用設置hosts文件,直接通過IP加端口就能訪問服務了。

Web服務器選用nginx,所以我們需要用一個nginx鏡像文件來構建這個容器,在這之前我們需要在nginx鏡像的基礎上再設置一下項目中用到的vhost,所以我們需要一個web.dockerfile文件,它的定義如下:

FROM nginx:1.10

ADD vhost.conf /etc/nginx/conf.d/default.conf

根據鏡像文件的定義,我們把項目中的vhost.conf復制到了容器的/etc/nginx/conf.d/default.conf中,這樣基本的nginx配置就配置好了,vhost.conf中的定義如下:

server {
  listen 80;
  index index.php index.html;
  root /var/www/public;

  location / {
    try_files $uri /index.php?$args;
  }

  location ~ \.php$ {
    fastcgi_split_path_info ^(.+\.php)(/.+)$;
    fastcgi_pass app:9000;
    fastcgi_index index.php;
    include fastcgi_params;
    fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
    fastcgi_param PATH_INFO $fastcgi_path_info;
  }
}

Notes:

  • 因為是開發環境我們就只進行最簡單的配置,不做調優考慮了。
  • fastcgi_pass app:9000; nginx將對PHP的請求通過fastcgi傳遞給了app服務的9000端口,docker-compose會自動把services中定義的容器服務連接起來,各個服務相互之間使用服務名稱引用。

Mysql服務

接下來我們將配置Mysql服務,與上面兩個服務有點不一樣的是,在PHP-FPM和Nginx的容器中,我們配置本地電腦的文件可以同步到容器中供容器訪問,這讓我們開發時對文件作的更改能夠快速的在容器中得到反饋加快我們的開發過程。但是在數據庫容器中我們希望容器中創建的文件能夠持久化(默認容器銷毀時,容器內創建的文件也會被銷毀),我們可以通過Docker的數據卷來實現上述功能,只不過這次不用再把本地電腦的文件掛在到數據卷上了,Docker客戶端會管理創建的數據卷的在本地電腦上具體存儲的位置。

下面是編排文件中對database服務的設置

version: '2'
services:

 database:
  image: mysql:5.7
  volumes:
   - dbdata:/var/lib/mysql
  environment:
   - "MYSQL_DATABASE=homestead"
   - "MYSQL_USER=homestead"
   - "MYSQL_PASSWORD=secret"
   - "MYSQL_ROOT_PASSWORD=secret"
  ports:
    - "33061:3306"

volumes:
 dbdata:

Notes:

  • 在文件的最下面我們通過volumes命令創建了一個名為dbdata的數據卷(dbdata后面的冒號是有意寫上去的,這是YML文件的一個語法限制,不用太關心)
  • 定義完數據卷后,在上面我們使用<name>:<dir>的格式,通知Docker,將dbdata數據卷掛在到容器中的/var/lib/mysql目錄上
  • environments中設置的是Mysql的docker鏡像需要的四個必要參數。
  • ports端口映射中,我們將本地電腦的33061端口映射到容器的3306端口,這樣我們就能通過電腦上的數據庫工具連接到docker內的Mysql了。

將所有服務編排到一起

下面是完整的docker-compose.yml文件,通過編排文件我們將三個應用容器關聯在一起組成了項目的服務端

version: '2'
services:

 # The Application
 app:
  build:
   context: ./
   dockerfile: app.dockerfile
  working_dir: /var/www
  volumes:
   - ./:/var/www
  environment:
   - "DB_PORT=3306"
   - "DB_HOST=database"

 # The Web Server
 web:
  build:
   context: ./
   dockerfile: web.dockerfile
  working_dir: /var/www
  volumes_from:
   - app
  ports:
   - 8080:80

 # The Database
 database:
  image: mysql:5.6
  volumes:
   - dbdata:/var/lib/mysql
  environment:
   - "MYSQL_DATABASE=homestead"
   - "MYSQL_USER=homestead"
   - "MYSQL_PASSWORD=secret"
   - "MYSQL_ROOT_PASSWORD=secret"
  ports:
    - "33061:3306"

volumes:
 dbdata:

啟動服務

按照上面的步驟配置好編排文件還有指定的docker鏡像文件后,我們就可以通過下面的命令啟動服務了,執行完后會啟動上面文件里定義的三個服務。

docker-compose up -d

第一次啟動時,由于docker客戶端要下載上面提到的三個鏡像并且構建服務所以啟動速度會慢一些,等到下載完鏡像并構建完成后,以后的啟動都會非常快。

初始化Laravel項目

啟動完服務后我們可以初始化Laravel項目了,步驟跟官方文檔里介紹的一樣,但是需要在啟動的app服務的容器里執行:

docker-compose exec app composer install
docker-compose exec app npm install // 如果包含前端項目的話再執行相關命令
docker-compose exec app cp .env.example .env
docker-compose exec app php artisan key:generate
docker-compose exec app php artisan optimize
docker-compose exec app php artisan migrate --seed
docker-compose exec app php artisan make:controller MyController

Notes:

  • docker-compose exec 將命令發送到指定的容器中去執行
  • app是定義在docker-compose.yml中的一個服務,它是一個運行著php-fpm的容器
  • php artisan migrate 是要在容器里執行的命令

查看nginx日志的方法:

  • docker ps 找到nginx服務的container id
  • docker exec -it <contianer id> /bin/bash 進入nginx容器
  • nginx日志的具體路徑請查看項目中的vhost.conf

執行完上面的命令后你就能通過http://127.0.0.1:8080/訪問到項目啦。

在我的Github gist有一組參考文件方便同學們參考https://gist.github.com/kevinyan815/fa0760902d29f19a4213b4a16fe0501b

gist里的文件稍微舊一些,后來在使用的過程中又加入些新的PHP模塊和Node,之前composer也單獨放到了一個容器中,不過相信聰明的你看到這里應該已經會根據需求更改這些文件啦。

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。

標簽:內江 瀘州 江門 泰安 江西 廈門 湖北 玉樹

巨人網絡通訊聲明:本文標題《詳解用Docker搭建Laravel和Vue項目的開發環境》,本文關鍵詞  詳解,用,Docker,搭建,Laravel,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《詳解用Docker搭建Laravel和Vue項目的開發環境》相關的同類信息!
  • 本頁收集關于詳解用Docker搭建Laravel和Vue項目的開發環境的相關信息資訊供網民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    国产99久久久国产精品免费看| 亚洲一区二区视频| 欧美精品一区二区久久久| 日韩欧美资源站| 久久久99精品久久| 久久久久久9999| 1000部国产精品成人观看| 亚洲激情六月丁香| 人人爽香蕉精品| 成人做爰69片免费看网站| 成人av资源下载| 欧美精品精品一区| 国产欧美日韩不卡免费| 亚洲视频在线观看一区| 无吗不卡中文字幕| 大陆成人av片| 精品国产制服丝袜高跟| 国产成人啪免费观看软件| 青青草国产精品97视觉盛宴| 成人激情av网| 亚洲中国最大av网站| 极品少妇xxxx精品少妇| 久久99久久99小草精品免视看| 久久精品国产一区二区三| 久久激情综合网| 972aa.com艺术欧美| 欧美日本视频在线| 国产区在线观看成人精品 | 国产风韵犹存在线视精品| 亚洲成在线观看| 成人三级伦理片| 国产亚洲欧美色| 日本一区中文字幕| 欧美精品一卡二卡| 亚洲自拍偷拍欧美| 欧美性淫爽ww久久久久无| 国产精品久久久久久久久免费樱桃 | 亚洲色图20p| 一级中文字幕一区二区| 亚洲午夜激情av| 日韩欧美第一区| 91蝌蚪porny成人天涯| 久久激情五月激情| 久久综合九色综合欧美98| 奇米精品一区二区三区在线观看| 欧美视频在线不卡| 日韩精品国产精品| 精品久久久久久久久久久久久久久 | 国内不卡的二区三区中文字幕 | 中文在线免费一区三区高中清不卡| 日本在线不卡视频| 欧美一区二区久久| 久久精品国产亚洲5555| 久久人人超碰精品| 国产999精品久久| 樱桃国产成人精品视频| 欧美日韩国产影片| 美女视频一区在线观看| 日韩欧美一级二级| 丰满岳乱妇一区二区三区| 亚洲欧洲中文日韩久久av乱码| 欧美午夜精品一区二区蜜桃| 亚洲成人福利片| 久久久久久久网| 欧美色图片你懂的| 成人一区二区在线观看| 日本欧美肥老太交大片| 亚洲精品亚洲人成人网| 国产女主播视频一区二区| 欧美哺乳videos| 欧美一区二区三区男人的天堂| 91视频免费播放| 激情文学综合插| 国产精品久久网站| 欧美va日韩va| 欧美日韩一级片在线观看| 国产精品自拍在线| 日韩精品国产精品| 麻豆精品在线播放| 日韩高清电影一区| 水野朝阳av一区二区三区| 亚洲色图第一区| 亚洲日本护士毛茸茸| 亚洲免费在线播放| 亚洲人123区| 一二三四区精品视频| 国产精品国产三级国产有无不卡 | 日韩码欧中文字| 亚洲一区二区在线视频| 亚洲在线视频一区| 亚洲成精国产精品女| 看国产成人h片视频| 成人小视频在线| 色呦呦一区二区三区| 欧美偷拍一区二区| 欧美电视剧免费观看| 国产精品久久久久久久蜜臀| 亚洲一卡二卡三卡四卡五卡| 亚洲va欧美va人人爽| 麻豆精品一区二区| 色综合色综合色综合| 欧美精品乱人伦久久久久久| 欧美mv和日韩mv的网站| 亚洲欧美另类久久久精品| 日韩在线观看一区二区| 粉嫩aⅴ一区二区三区四区五区| 色综合中文字幕国产 | 日韩不卡在线观看日韩不卡视频| 国产精品一区在线观看你懂的| 成人午夜碰碰视频| 日韩手机在线导航| 亚洲婷婷国产精品电影人久久| 午夜久久久久久久久久一区二区| 风间由美性色一区二区三区| 在线不卡一区二区| 亚洲美女屁股眼交3| 懂色中文一区二区在线播放| 91精品黄色片免费大全| 亚洲人成伊人成综合网小说| 韩国视频一区二区| 欧美日韩一级二级三级| 亚洲婷婷综合久久一本伊一区| 国产一区二区三区av电影| 欧美一三区三区四区免费在线看| 亚洲免费观看高清完整| 99久久国产综合精品麻豆| 国产精品久线观看视频| 成人午夜看片网址| 国产精品妹子av| caoporn国产一区二区| 国产精品久久精品日日| 国产99一区视频免费| 中文字幕精品—区二区四季| 成人午夜私人影院| 国产精品久久久久久久午夜片 | 亚洲乱码国产乱码精品精可以看| 成人高清av在线| 亚洲人成7777| 3d动漫精品啪啪1区2区免费| 精品无人区卡一卡二卡三乱码免费卡| 91精品国产综合久久福利| 韩国三级在线一区| 中文字幕一区二区三区乱码在线| 成人短视频下载| 午夜成人在线视频| 欧美激情综合网| 欧美三级资源在线| 国产一区二区三区日韩| 国产精品久久久久aaaa| 5月丁香婷婷综合| 成人性生交大片免费看视频在线| 一区二区三区蜜桃| 国产欧美精品一区| 日韩视频123| 在线一区二区视频| www.日韩大片| 国产一区999| 久色婷婷小香蕉久久| 亚洲精品中文在线观看| 国产精品美女久久久久久| 欧美猛男超大videosgay| a亚洲天堂av| 国产精品一区在线观看你懂的| 日韩高清中文字幕一区| 亚洲精品免费一二三区| 亚洲国产精品成人综合| 精品伦理精品一区| 精品国产免费人成在线观看| 欧美日韩国产电影| 欧美精品粉嫩高潮一区二区| 欧美亚洲国产一区二区三区va | 美女一区二区视频| 免费成人结看片| 美日韩一级片在线观看| 日韩高清中文字幕一区| 日韩av一区二区三区| 美女www一区二区| 精品夜夜嗨av一区二区三区| 美女视频网站黄色亚洲| 国产在线播放一区| 丁香啪啪综合成人亚洲小说 | 中文字幕一区二区在线播放| 国产精品剧情在线亚洲| 日韩一区在线看| 日本中文在线一区| 99久久精品费精品国产一区二区| 一本大道久久a久久精二百| 欧美久久久久中文字幕| 久久亚洲一区二区三区明星换脸| 国产精品久久久久久久久免费桃花| 一区二区三区**美女毛片| 麻豆国产精品777777在线| 国产精一区二区三区| 欧美亚洲国产怡红院影院| 欧美videossexotv100| 一区二区免费在线播放| 国产精品一区二区在线观看网站| 99久久国产综合精品女不卡| 精品国产污网站| 日本sm残虐另类|