本文主要包括部分
- 注意事項 重要資訊提示
- 快速執行安裝的純命令
- 相關介紹
- 配置檔案,參考地址
1.
特別注意:
本文中提及的密碼與配置檔案可能不一致,簡單改成了mima123456, 文中用的123456在進行說明
windows環境中,專案中mysql的連線主機為 172…和localhost都連線失敗 (Linux中用宿主機ip連線成功–沒探究原因,歡迎評論補全)
安裝成功後, 我發現專案連線 資料庫的時候連線不了, 一直是 Connection timed out(2002) ,
但是我使用 cmd , navicate, 都能夠連線, 而且 localhost, 172.0.0.1, 和對應的docker ip 都是可以連線的, 就是php專案中無法連線 一直提示 連線超時. 專案執行正常, 我的其他專案連線的其他伺服器的資料庫也是訪問正常的.
解決記錄:
專案連線資料庫成功了 使用如下 注意專案中資料庫主機用 host=mysql(我在linux中用的宿主機ip是可以直接訪問資料庫的,windows失敗了)
$pdo = new PDO(‘mysql:host=mysql;dbname=site1’, ‘root’, ‘123456’);。
或者使用
$connect = mysqli_connect(‘mysql’,’root’,’123456′,’wordpress’,’3306′);
(注意 是 mysqli_connect, 不是 mysql_connect)
另外:
–強烈建議修改sql密碼,配置檔案中預設密碼公開的
修改專案路徑為自己已有專案路徑(如果有,比如安裝過PHPstudy的www目錄),預設下載的配置檔案目錄下的www
注意:
配置中localhost在www/site1中,請修改site的域名配置或者localhost的配置指向
環境安裝過後修改yml配置的資料庫密碼未能生效, 沒找到解決辦法, 間接解決方法是: 重新下載配置檔案用新的命名,重新執行環境
參考連結中的下載的配置檔案的版本號3執行失敗 改成2就可以了 改成1頁失敗了的
注意:
如果本地有phpstudy等環境, 注意關閉環境, 並且注意關閉mysql程式(關閉phpstudy可能還有mysql程式存在), 否則啟動會失敗
2.
快速直接安裝:
直接執行命令即可!
git clone https://github.com/yeszao/dnmp.git
docker-compose up
3.
錯誤記錄:
環境安裝過後修改yml配置的資料庫密碼未能生效, 沒找到解決辦法, 間接解決方法是: 重新下載配置檔案用新的命名,重新執行環境
嘗試過 2種方法
2.1.
docker-compose build 然後 docker-compose up -d
build會提示:
…..
Successfully built 6a55df4e9d16
redis uses an image, skipping
nginx uses an image, skipping
mysql uses an image, skipping
2.2.(以下是部分命令記錄,修改的mysql密碼均失敗)
docker-compose down
18 docker-compose build
19 docker-compose ps
20 docker-compose up -h
21 docker-compose up –build -d
22 docker-compose up –build -d –force-recreate
23 docker-compose ps
24 docker-compose down
25 docker-compose up -d –force-recreate
(根據)
4.詳細說明:
專案目錄,
專案路徑指定了下載資料夾內的www目錄, 如需改成其他目錄或自己原有目錄,直接修改目錄下的檔案 docker-compose.yml 內的全部 – ./www 為自己的目錄, 比如 – F:/phpStudy2018/www(絕對路徑) 或者 – ../phpStudy2018/www(相對路徑)
mysql密碼
windows環境中,專案中mysql的連線主機為 mysql, 172…和localhost都連線失敗 (Linux中用宿主機ip連線成功–沒探究原因,歡迎評論補全)
安裝成功後, 我發現專案連線 資料庫的時候連線不了, 一直是 Connection timed out(2002) ,
但是我使用 cmd , navicate, 都能夠連線, 而且 localhost, 172.0.0.1, 和對應的docker ip 都是可以連線的, 就是php專案中無法連線 一直提示 連線超時. 專案執行正常, 我的其他專案連線的其他伺服器的資料庫也是訪問正常的.
基礎配置檔案內容
# 注意 這裡clone的配置檔案中是3 我的執行失敗 我改成2就可以了 ,1也不行 各自根據情況進行修改
version: "2"
services:
nginx:
image: nginx:alpine
ports:
- "80:80"
- "443:443"
volumes:
# 修改此處 ./www/為自己的專案路徑, 如果沒有可以自定義 ,這裡使用的是相對路徑 就是git clone下來的目錄中的www目錄
- ./www/:/var/www/html/:rw
- ./conf/conf.d:/etc/nginx/conf.d/:ro
# 這裡就是站點域名的配置檔案 在相對路徑 conf/conf.d/ 下面(注意 linux是反斜槓) clone下來的配置目錄中的www目錄下已經有了site1 和2 的目錄,所以訪問沒問題, 但是如果換成自己的專案目錄, 就需要自己新建site1目錄(因為site1配置檔案中把localhost配置到了site1目錄下了)或者自己修改site1裡面的配置,把localhost指向到自己的專案目錄,
- ./conf/nginx.conf:/etc/nginx/nginx.conf:ro
- ./log/:/var/log/dnmp/:rw
networks:
- net-php
php:
build: ./php/php72/
expose:
- "9000"
volumes:
# 修改此處 ./www/為自己的專案路徑, 如果沒有可以自定義 ,這裡使用的是相對路徑 就是git clone下來的目錄中的www目錄
- ./www/:/var/www/html/:rw
- ./conf/php.ini:/usr/local/etc/php/php.ini:ro
# 這裡就是站點域名的配置檔案 在相對路徑 conf/conf.d/ 下面(注意 linux是反斜槓) clone下來的配置目錄中的www目錄下已經有了site1 和2 的目錄,所以訪問沒問題, 但是如果換成自己的專案目錄, 就需要自己新建site1目錄(因為site1配置檔案中把localhost配置到了site1目錄下了)或者自己修改site1裡面的配置,把localhost指向到自己的專案目錄,
- ./conf/php-fpm.conf:/usr/local/etc/php-fpm.d/www.conf:rw
- ./log/:/var/log/dnmp/:rw
networks:
- net-php
- net-mysql
- net-redis
mysql:
image: mysql:8.0
ports:
- "3306:3306"
volumes:
- ./conf/mysql.cnf:/etc/mysql/conf.d/mysql.cnf:ro
- ./mysql/:/var/lib/mysql/:rw
networks:
- net-mysql
environment:
# // todo: 修改為自己的密碼,此密碼github中公開的
MYSQL_ROOT_PASSWORD: "mima123456"
redis:
image: redis:4.0
networks:
- net-redis
ports:
- "6379:6379"
phpmyadmin:
image: phpmyadmin/phpmyadmin:latest
ports:
- "8080:80"
networks:
- net-mysql
environment:
- PMA_HOST=mysql
- PMA_PORT=3306
phpredisadmin:
image: erikdubbelboer/phpredisadmin:latest
ports:
- "8081:80"
networks:
- net-redis
environment:
- REDIS_1_HOST=redis
- REDIS_1_PORT=6379
networks:
net-php:
net-mysql:
net-redis:
配置說明詳細參考地址
http://www.cnblogs.com/xishuai/p/docker-compose.html
部分命令參考:
YAML 配置命令
配置 | 說明 |
---|---|
build | 指定 Dockerfile 所在的目錄地址,用於構建映象,並使用此映象建立容器,比如上面配置的build: .
|
command | 容器的執行命令 |
dns | 自定義 dns 伺服器 |
expose | 暴露埠配置,但不對映到宿主機,只被連線的服務訪問 |
extends | 對docker-compose.yml 的擴充套件,配置在服務中 |
image | 使用的映象名稱或映象 ID |
links | 連結到其它服務中的容器(一般橋接網路模式使用) |
net | 設定容器的網路模式(四種:bridge , none , container:[name or id] 和host ) |
ports | 暴露埠資訊,主機和容器的埠對映 |
volumes | 資料卷所掛載路徑設定 |
Docker Compose 常用命令
命令 | 說明 |
---|---|
docker-compose build | 構建專案中的映象,--force-rm :刪除構建過程中的臨時容器;--no-cache :不使用快取構建;--pull :獲取最新版本的映象 |
docker-compose up -d | 構建映象、建立服務和啟動專案,-d 表示後臺執行 |
docker-compose run ubuntu ls -d | 指定服務上執行一個命令,-d 表示後臺執行 |
docker-compose logs | 檢視服務容器輸出日誌 |
docker-compose ps | 列出專案中所有的容器 |
docker-compose pause [service_name] | 暫停一個服務容器 |
docker-compose unpause [service_name] | 恢復已暫停的一個服務容器 |
docker-compose restart | 重啟專案中的所有服務容器(也可以指定具體的服務) |
docker-compose stop | 停止執行專案中的所有服務容器(也可以指定具體的服務) |
docker-compose start | 啟動已經停止專案中的所有服務容器(也可以指定具體的服務) |
docker-compose rm | 刪除專案中的所有服務容器(也可以指定具體的服務),-f :強制刪除(包含執行的) |
docker-compose kill | 強制停止專案中的所有服務容器(也可以指定具體的服務) |
參考來源:http://www.cnblogs.com/xishuai/p/docker-compose.html 文末