Docker容器的简单操作及应用部署
1.什么是虛擬化
? ? ? ? 虛擬化(Virtualization)是一種資源管理技術 ,虛擬化技術種類很多,例如:軟件虛擬化、硬件虛擬化、內存虛擬化、網絡虛擬化(vip)、桌面虛擬化、服務虛擬化、虛擬機等等 。
2.什么是Docker
? ? ? ?Docker 是一個Go 語言實現開源項目。?Docker 的基礎是 Linux 容器(LXC)等技術。用戶操作 Docker 的容器就像操作一個快速輕量級的虛擬機一樣簡單。
3.容器與虛擬機比較
? ? ?容器是在操作系統層面上實現虛擬化,直接復用本地主機的操作系統,而傳統方式則是在硬件層面實現。Docker優勢體現為啟動速度快、占用體積小。
?
關于Docker的一系列操作流程。
systemctl命令是系統服務管理器指令
啟動docker:
systemctl start?docker停止docker:
systemctl stop?docker重啟docker:
systemctl restart?docker查看docker狀態:
systemctl status?docker開機啟動:
systemctl enable docker查看docker概要信息
docker info查看docker幫助文檔
docker --help鏡像相關命令
查看docker鏡像
docker images搜索docker鏡像
docker search拉取鏡像就是從中央倉庫中下載鏡像到本地
docker pull 鏡像名稱按鏡像ID刪除鏡像
docker rmi 鏡像ID刪除所有鏡像
docker rmi `docker images -q`容器相關命令
查看正在運行的容器
docker ps查看所有容器
docker ps –a查看最后一次運行的容器
docker ps –l查看停止的容器
docker ps -f status=exited創建與啟動容器
創建容器常用的參數說明:
創建容器命令:docker run
-i:表示運行容器
-t:表示容器啟動后會進入其命令行。加入這兩個參數后,容器創建就能登錄進去。即分配一個偽終端。
--name :為創建的容器命名。
-v:表示目錄映射關系(前者是宿主機目錄,后者是映射到宿主機上的目錄),可以使用多個-v做多個目錄或文件映射。注意:最好做目錄映射,在宿主機上做修改,然后共享到容器上。
-d:在run后面加上-d參數,則會創建一個守護式容器在后臺運行(這樣創建容器后不會自動登錄容器,如果只加-i -t兩個參數,創建后就會自動進去容器)。
-p:表示端口映射,前者是宿主機端口,后者是容器內的映射端口。可以使用多個-p做多個端口映射
(1)交互式方式創建容器
docker run -it --name=容器名稱 鏡像名稱:標簽 /bin/bash這時我們通過ps命令查看,發現可以看到啟動的容器,狀態為啟動狀態
退出當前容器
exit(2)守護式方式創建容器:
docker run -di --name=容器名稱 鏡像名稱:標簽登錄守護式容器方式:
docker exec -it 容器名稱 (或者容器ID) /bin/bash停止與啟動容器
停止容器:
docker stop 容器名稱(或者容器ID)啟動容器:
docker start 容器名稱(或者容器ID)文件拷貝
如果我們需要將文件拷貝到容器內可以使用cp命令
docker cp 需要拷貝的文件或目錄 容器名稱:容器目錄也可以將文件從容器內拷貝出來
docker cp 容器名稱:容器目錄 需要拷貝的文件或目錄目錄掛載
我們可以在創建容器的時候,將宿主機的目錄與容器內的目錄進行映射,這樣我們就可以通過修改宿主機某個目錄的文件從而去影響容器。創建容器 添加-v參數 后邊為 宿主機目錄:容器目錄,例如:
docker run -di -v /usr/local/myhtml:/usr/local/myhtml --name=mycentos3 centos:7如果你共享的是多級的目錄,可能會出現權限不足的提示。
這是因為CentOS7中的安全模塊selinux把權限禁掉了,我們需要添加參數 --privileged=true 來解決掛載的目錄沒有權限的問題
查看容器IP地址
我們可以通過以下命令查看容器運行的各種數據
docker inspect 容器名稱(容器ID)?也可以直接執行下面的命令直接輸出IP地址
docker inspect --format='{{.NetworkSettings.IPAddress}}' 容器名稱(容器ID)刪除容器
刪除指定的容器:
docker rm 容器名稱(容器ID)4 應用部署
4.1 MySQL部署
(1)拉取mysql鏡像
docker pull centos/mysql-57-centos7(2)創建容器
docker run -di --name=tensquare_mysql -p 33306:3306 -e MYSQL_ROOT_PASSWORD=123456 mysql-p 代表端口映射,格式為? 宿主機映射端口:容器運行端口
-e 代表添加環境變量? MYSQL_ROOT_PASSWORD 是root用戶的登陸密碼
(3)遠程登錄mysql
連接宿主機的IP ,指定端口為33306
4.2 tomcat部署
(1)拉取鏡像
docker pull tomcat:7-jre7(2)創建容器
創建容器? -p表示地址映射
docker run -di --name=mytomcat -p 9000:8080 -v /usr/local/webapps:/usr/local/tomcat/webapps tomcat:7-jre74.3 Nginx部署
(1)拉取鏡像
docker pull nginx(2)創建Nginx容器
docker run -di --name=mynginx -p 80:80 nginx4.4 Redis部署
(1)拉取鏡像
docker pull redis(2)創建容器
docker run -di --name=myredis -p 6379:6379 redis5 遷移與備份
5.1 容器保存為鏡像
我們可以通過以下命令將容器保存為鏡像
docker commit mynginx mynginx_i5.2 鏡像備份
我們可以通過以下命令將鏡像保存為tar 文件
docker save -o mynginx.tar mynginx_i5.3 鏡像恢復與遷移
首先我們先刪除掉mynginx_img鏡像 然后執行此命令進行恢復
docker load -i mynginx.tar-i 輸入的文件
執行后再次查看鏡像,可以看到鏡像已經恢復
?
6 Dockerfile
6.1 什么是Dockerfile
Dockerfile是由一系列命令和參數構成的腳本,這些命令應用于基礎鏡像并最終創建一個新的鏡像。
1、對于開發人員:可以為開發團隊提供一個完全一致的開發環境; 2、對于測試人員:可以直接拿開發時所構建的鏡像或者通過Dockerfile文件構建一個新的鏡像開始工作了; 3、對于運維人員:在部署時,可以實現應用的無縫移植。
6.2 常用命令
| FROM image_name:tag | 定義了使用哪個基礎鏡像啟動構建流程 |
| MAINTAINER user_name | 聲明鏡像的創建者 |
| ENV key value | 設置環境變量 (可以寫多條) |
| RUN command | 是Dockerfile的核心部分(可以寫多條) |
| ADD source_dir/file dest_dir/file | 將宿主機的文件復制到容器內,如果是一個壓縮文件,將會在復制后自動解壓 |
| COPY source_dir/file dest_dir/file | 和ADD相似,但是如果有壓縮文件并不能解壓 |
| WORKDIR path_dir | 設置工作目錄 |
使用腳本創建鏡像
步驟:
(1)創建目錄
mkdir –p /usr/local/dockerjdk8(2)下載jdk-8u171-linux-x64.tar.gz并上傳到服務器(虛擬機)中的/usr/local/dockerjdk8目錄
(3)創建文件Dockerfile vi Dockerfile
#依賴鏡像名稱和ID FROM centos:7 #指定鏡像創建者信息 MAINTAINER ITCAST #切換工作目錄 WORKDIR /usr RUN mkdir /usr/local/java #ADD 是相對路徑jar,把java添加到容器中 ADD jdk-8u171-linux-x64.tar.gz /usr/local/java/#配置java環境變量 ENV JAVA_HOME /usr/local/java/jdk1.8.0_171 ENV JRE_HOME $JAVA_HOME/jre ENV CLASSPATH $JAVA_HOME/lib/dt.jar:$JAVA_HOME/lib/tools.jar:$JRE_HOME/lib:$CLASSPATH ENV PATH $JAVA_HOME/bin:$PATH(4)執行命令構建鏡像
docker build -t='jdk1.8' .注意后邊的空格和點,不要省略
(5)查看鏡像是否建立完成
docker images?
7 Docker私有倉庫
7.1 私有倉庫搭建與配置
(1)拉取私有倉庫鏡像(此步省略)
docker pull registry(2)啟動私有倉庫容器
docker run -di --name=registry -p 5000:5000 registry(3)打開瀏覽器 輸入地址http://192.168.184.141:5000/v2/_catalog看到{"repositories":[]} 表示私有倉庫搭建成功并且內容為空
(4)修改daemon.json
vi /etc/docker/daemon.json添加以下內容,保存退出。
{"insecure-registries":["192.168.184.141:5000"]}此步用于讓 docker信任私有倉庫地址
(5)重啟docker 服務
systemctl restart docker鏡像上傳至私有倉庫
(1)標記此鏡像為私有倉庫的鏡像
docker tag jdk1.8 192.168.184.141:5000/jdk1.8(2)再次啟動私服容器
docker start registry(3)上傳標記的鏡像
docker push 192.168.184.141:5000/jdk1.8?
總結
以上是生活随笔為你收集整理的Docker容器的简单操作及应用部署的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: rfcv函数实现_OpenSSL AES
- 下一篇: 求数组的最大值php,求PHP数组最大值