天天看點

(四)Docker安裝使用 容器

容器管理

plus:

docker本身是一個C/S架構

用戶端用于我們敲指令啊之類的

服務端提供了一些api 等 可以通過ps -ef | docker 看到服務主程序

如果要拉你在公有倉庫裡面自己倉庫裡的東西可以

docker login daocloud.io

username:

password:

基本操作

容器相關操作

docker create # 建立一個容器但是不啟動它 docker run # 建立并啟動一個容器

docker stop # 停止容器運作,發送信号SIGTERM docker kill #強制終止一個容器

docker start # 啟動一個停止狀态的容器

docker restart # 重新開機一個容器

docker rmi # 删除一個容器

docker rm $(docker ps -a -q)

docker kill # 發送信号給容器,預設SIGKILL docker attach # 連接配接(進入)到一個正在運作的容器 docker wait # 阻塞到一個容器,直到容器停止運作 docker --restart=always 容器

docker ps # 顯示狀态為運作(Up)的容器

docker ps -a # 顯示所有容器,包括運作中(Up)的和退出的(Exited)

docker inspect # 深入容器内部擷取容器所有資訊

docker logs -f # 檢視容器的日志(stdout/stderr)(-f 用于實時輸出)

docker events # 得到docker伺服器的實時的事件

docker port # 顯示容器的端口映射

docker top # 顯示容器的程序資訊

docker diff # 顯示容器檔案系統的前後變化

測試

建立一個容器并啟動容器

比如:

docker run -it --name=inspect_shell centos:7 /bin/bash

建立一個名字為inspect_shell的容器,并啟動了該容器(互動式容器)

docker run --name daemon_hello -d centos:7 /bin/bash -c "

while true;do echo hello word;sleep 1;done"

建立一個名字為daemon_hello的容器,并啟動了該容器(背景型容器)

資料持久化

兩種方式實作:

1.主控端挂載點

-v

2.公用容器

--volumes-from

容器銷毀不會影響到資料卷

在叢集服務中可以通過實作主控端存儲叢集來實作叢集資料持久化

搭建LNMP網站

1.啟動一個資料庫

docker search 去找一個你需要的版本

docker pull mysql:5.6

你可以先擷取鏡像幫助來更好的使用鏡像

docker run -d -p 3307:3306 -e MYSQL_ROOT_PASSWORD=xy123456 --name xy_mysql mysql:5.6
映射到主機3307端口  建立一個密碼為xy123456的資料庫 容器名字為xy_mysql 鏡像版本mysql5.6           

同時 我們可以直接在真機上傳入變量到容器 擷取容器資訊

docker exec  xy_mysql  sh -c 'mysql -uroot -p"$MYSQL_ROOT_PASSWORD" -e "show databases" '           

plus:這裡為我們提供了一個一次性建構的思路

設定好mysql的密碼是什麼?建立的資料庫是什麼?要不要建立使用者?建立使用者要不要授權?

(這裡可以同構shell腳本實作 同時也有更簡單的方式 我在後面的部落格中會記錄 即通過導入sql表同時修改初始化配置檔案來實作)

容器中的資料檔案目錄是什麼? 如何挂載來實作存儲資料的持久化?

2.建立一個php解析環境

docker run -d -  v   /var/nginx/www/html:/var/www/html -p 9000:9000 --link xy_mysql:mysql --name xy_phpfpm php:7.0-fpm            

參數說明

-d 讓容器在背景運作

-p 添加主機到容器的端口映射

-v 添加目錄映射,即主機上的/var/nginx/www/html和容器中/var/www/html目錄是同步的

–name 容器的名字

–link 與另外一個容器建立起聯系,這樣我們就可以在目前容器中去使用另一個容器裡的服務。

這裡如果不指定–link參數其實也是可以得,因為容易本身也是有ip的且唯一,是以我們也可以直接利用ip去通路容器。

然後進入到我們的容器,然後我們在/var/www/html目錄下建立一個index.php檔案

`

touch index.php

我們發現我們在容器裡的/var/www/html目錄中建立的檔案也在主機的/var/nginx/www/html目錄中,因為在建立容器的時候,我們已經把主機中的目錄挂載到了容器中去了。

因為後面我要使用pdo子產品進行測試,是以我需要自己安裝pdo_mysql子產品,在docker容器中可以這樣來安裝

docker-php-ext-install pdo_mysql           

然後我們可以通過指令php -m檢視我們的php的所有擴充子產品,我們可以去看到我們剛剛安裝的pdo_mysql擴充也在裡面

3.搭建nginx

docker run -d -p 80:80 --name xy_nginx\ 
-v /var/nginx/www/html:/var/www/html\
--link xy_phpfpm:phpfpm --name xy_nginx nginx:1.10.3           

-v 添加目錄映射,這裡最好nginx容器的根目錄最好寫成和php容器中根目錄一樣。但是不一點非要一模一樣,如果不一樣在配置nginx的時候需要注意

–link 與另外一個容器建立起聯系

然後進入nginx容器,修改nginx的配置檔案讓它支援php

docker exec -ti xy_nginx /bin/bash

location ~ \.php$ {
        root           /var/www/html;
        fastcgi_index  index.php;
        fastcgi_pass   phpfpm:9000;//這裡改成我們之前--link進來的容器,也可以直接用php容器的ip
        fastcgi_param  SCRIPT_FILENAME $document_root$fastcdi_script_name;//如果你的根目錄和php容器的根目錄不一樣,這裡的$document_root需要換成你php下的根目錄,不然php就找不到檔案了
        include        fastcgi_params;                                                                                                                                               

    }           

測試一波

<?php
try {
    $con = new PDO('mysql:host=mysql;dbname=test', 'xuye', 'xy123456');
    $con->query('SET NAMES UTF8');
    $res =  $con->query('select * from test');
    while ($row = $res->fetch(PDO::FETCH_ASSOC)) {
        echo "id:{$row['id']} name:{$row['name']}";
    }
} catch (PDOException $e) {
     echo '錯誤原因:'  . $e->getMessage();
}           

當當當,看到正确的輸出,就證明我們的配置成功了。一個最最最基本的環境就搭建好了。。

是不是參數很多很複雜????

沒關系,後續我們可以通過docker-compose 來實作把這些參數寫在yml檔案裡面 最後實作一次性建構 。

例如 :

建構node環境

node:

image: 7d10217beb82 鏡像
container_name: node 容器名
ports:                            映射端口
    - "3014:3014"
    - "3050:3050"
    - "3051:3051"
    - "8010:8010"
    - "8024:8024"
    - "3005:3005"
volumes:
    - /data/www/htdocs:/data/www 資料持久化
extra_hosts:   附加進hosts檔案
    - "db.pro.com:1.1.1.1"
restart: always           自動重新開機
這裡配置虛拟域名作為項目中mysql連接配接位址 可以很好的避免開發環境和測試環境每次要修改連接配接的問題
           

nginx:

image: 169bd14dcf7a
container_name: nginx
links:
    - php
    - node
    - tomcat
ports:
    - "80:80"
    - "443:443"
    - "8000:8000"
volumes:
    - /data/www/htdocs:/data/www
    - /data/logs/nginx:/var/log/nginx
    - ./volumes/nginx/sites:/etc/nginx/sites-enabled
    - ./volumes/nginx/includes:/etc/nginx/includes
extra_hosts:
    - "db.pro.com:1.1.1.1"
restart: always
           

php:

image: 0b0b9f98dff2
container_name: php
ports:
    - "9000:9000"
links:
    - node
    - mongodb
    - redis
    - mysql           這是需要能通路到的容器
volumes:
    - /data/www/htdocs:/data/www
    - /data/logs/php:/data/logs/php
extra_hosts:
    - "db.pro.com:119.29.105.164"
restart: always
           

mysql:

image: 5a58d88e1b36
container_name: mysql
ports:
    - "3306:3306"
volumes:
    - /data/db/mysql:/data/db/mysql
    - /data/logs/mysql:/data/logs/mysql
environment:
    MYSQL_USER:  "user_test"
    MYSQL_PASSWORD: "N!F3ABaFui"
    MYSQL_ROOT_PASSWORD: "T41Df!x2L4"
restart: always
           

redis:

image: c12f15d2ef75
container_name: redis
ports:
    - "6379:6379"
volumes:
    - /data/db/redis:/data/db/redis
    - /data/logs/redis:/data/logs/redis
restart: always           

memcached:

image: 1739564665db
container_name: memcached
ports:
    - "11211:11211"
restart: always           

mongodb:

image: 8e058d1bebf7
container_name: mongodb
ports:
    - "27017:27017"
volumes:
    - /data/db/mongodb:/data/db/mongodb
    - /data/logs/mongodb:/data/logs/mongodb
environment:
    AUTH: "yes" 
    JOURNALING: "yes"
    MONGODB_DATABASE: "test"
    MONGODB_USER: "test"
    MONGODB_PASS: "541R4evB"
restart: always 
           

最終就會一鍵建構起一套

以nginx作為web容器 能解析php項目 通路到node接口 後端有mysql mongo以及redis 并且資料能夠持久化儲存的一套web環境