您好,登錄后才能下訂單哦!
這篇文章主要講解了“Docker的基本控制命令總結(jié)”,文中的講解內(nèi)容簡(jiǎn)單清晰,易于學(xué)習(xí)與理解,下面請(qǐng)大家跟著小編的思路慢慢深入,一起來(lái)研究和學(xué)習(xí)“Docker的基本控制命令總結(jié)”吧!
1、CPU使用率控制
限制該鏡像本次建立的容器最大只能占總資源的10%
docker run --cpu-quota 10000 centos
2、按比例分配
創(chuàng)建兩個(gè)容器為c1和c2,若只有這兩個(gè)容器,設(shè)置容器的權(quán)重,使得c1和c2的CPU資源占比為33.3%和66. 7%
docker run -itd --name c1 --cpu-shares 512 centos(鏡像名)
docker run -itd --name c2 --cpu-shares 1024 centos(鏡像名)
3、限制容器使用指定的CPU
為該鏡像指定四個(gè)CPU的使用
docker run --name c3 --cpuset-cpus 0001,0010,0100,1000 centos
4、內(nèi)存使用限制
限制建立的容器最多只能使用1gb內(nèi)存
docker run --name c4 -m 1gb centos
5、限制容器讀取磁盤\設(shè)備的數(shù)據(jù)量
限制該容器僅能讀取sda磁盤的100mb的數(shù)據(jù)
docker run -d --device-read-bps /dev/sda:100mb centos
6、限制容器寫(xiě)入磁盤\設(shè)備的數(shù)據(jù)量
限制該容器僅能寫(xiě)入sda磁盤的100mb的數(shù)據(jù)
docker run -d --device-write-bps /dev/sda:100mb centos
7、限制容器讀取磁盤\設(shè)備的次數(shù)
限制該容器僅能讀取sda磁盤10次
docker run -d --device-read-iops /dev/sda:10 centos
8、限制容器寫(xiě)入磁盤\設(shè)備的次數(shù)
限制該容器僅能寫(xiě)入sda磁盤的10次
docker run -d --device-write-iops /dev/sda:10 centos
1、建立數(shù)據(jù)卷(容器目?jī)?nèi)錄與宿主機(jī)目錄之間實(shí)現(xiàn)數(shù)據(jù)共享)
以交互模式建立數(shù)據(jù)卷
docker run -v 本地目錄:容器目錄 --name 容器名 -it 鏡像名 /bin/bash “-v” 指定數(shù)據(jù)卷 “-name” 新建立的容器名稱 /var/www:/data1 前面為宿主目錄,后者為容器目錄(整體為建立關(guān)聯(lián)過(guò)程)
2、建立數(shù)據(jù)卷容器(兩個(gè)容器之間實(shí)現(xiàn)數(shù)據(jù)共享,與宿主機(jī)環(huán)境無(wú)關(guān))
以交互模式建立容器并提供其中目錄作為數(shù)據(jù)卷容器載體
docker run -v 容器內(nèi)目錄 ...... --name 容器名 -it 鏡像名 /bin/bash
掛載提供空間的容器的數(shù)據(jù)卷到新容器中建立數(shù)據(jù)卷容器
docker run --volumes-from 提供空間的鏡像名 --name 容器名 -it 鏡像名 /bin/bash
(1)基于現(xiàn)有鏡像創(chuàng)建新的鏡像
創(chuàng)建容器 docker create -it centos /bin/bash 生成新的鏡像 docker commit -m "new" -a "zhy" -p ccbd1395fce9(容器ID/名稱) ccos:new(生成的新鏡像名稱:標(biāo)簽) ●-m說(shuō)明信息 ●-a作者信息 ●-p生成過(guò)程中停止容器的運(yùn)行
(2)基于本地模板創(chuàng)建新的鏡像
下載鏡像模板 wget http://download.openvz.org/teuplate/precreated/debian-7.0-x86-minimal.tar.gz 生成新的鏡像 cat debian-7.0-x86-minimal.tar.gz | docker import - daoke:new
(3)基于Dockerfile創(chuàng)建新的鏡像
mkdir apache cd apache vim Dockerfile #基于的基礎(chǔ)鏡像 FROM centos #維護(hù)鏡像的用戶信息 MAINTAINER The porject <cloud- ops@centos. org> #鏡像操作指令安裝apache軟件 RUN yum- y update RUN yum -y install httpd #開(kāi)啟80端口 EXPOSE 80 #復(fù)制網(wǎng)站首頁(yè)文件 ADD index. html /var/www/html/index. html #將執(zhí)行腳本復(fù)制到鏡像中 ADD run. sh /run. sh RUN chmod 755 /run. sh #啟動(dòng)容器時(shí)執(zhí)行腳本. CMD[" /run. sh"] vim run.sh #!/bin/bash rm -rf /run/httpd/* exec /usr/sbin/apachectl -D FOREGROUP echo "web test" > index.html //生成鏡像 docker build -t httpd:centos . //新鏡像運(yùn)行容器 docker run -d -p 1216:80 httpd:centos
1、容器內(nèi)隨機(jī)端口進(jìn)行映射(映射范圍:49000~49900)
[root@localhost ~]# docker run -d -P httpd:centos 0820d042e62294c0db107eef0fea8c2c1fca737acb8d91306a6d40e134332bde [root@localhost ~]# docker ps -a CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES 0820d042e622 httpd:centos "/run.sh" 2 seconds ago Up 1 second 0.0.0.0:32768->80/tcp epic_jennings
2、容器內(nèi)指定端口進(jìn)行映射
[root@localhost ~]# docker run -d -p 5566:80 httpd:centos 9f65fc007070f36df88304515232a0d5fa357e55926a5f06b48cdf359e6ec9b8 [root@localhost ~]# docker ps -a CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES 9f65fc007070 httpd:centos "/run.sh" 4 seconds ago Up 4 seconds 0.0.0.0:5566->80/tcp intelligent_nightingale
3、容器之間互聯(lián)
docker run -itd -P --name web1 centos /bin/bash //創(chuàng)建并運(yùn)行容器取名web1,端口號(hào)自動(dòng)映射 docker run -itd -P --name web2 --link web1:web1 centos /bin/bash //創(chuàng)建并運(yùn)行容器取名web2,
[root@localhost tomcat]# docker pull registry //下載私有倉(cāng)庫(kù)注冊(cè)表 [root@localhost nginx]# vim /etc/docker/daemon.json //添加私有倉(cāng)庫(kù)地址 { "insecure-registries" : ["192.168.142.77:5000"], //私有倉(cāng)庫(kù)地址 "registry-mirrors" : ["https://abc123.mirror.aliyuncs.com"] } //重啟docker [root@localhost nginx]# systemctl stop docker [root@localhost nginx]# systemctl start docker //基于倉(cāng)庫(kù)鏡像建立容器 [root@localhost nginx]# docker create -it registry /bin/bash 96f91f83a1d58ddee147fe3d141d27d69fa7d3d76c46e3783bef7c1c5d0339bb [root@localhost nginx]# docker ps -a CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES 96f91f83a1d5 registry "/entrypoint.sh /bin…" 5 seconds ago Created sweet_almeida [root@localhost nginx]# docker run -d -p 5000:5000 -v /data/registry:/tmp/registry registry //更改鏡像標(biāo)簽(地址填寫(xiě)倉(cāng)庫(kù)地址) [root@localhost nginx]# docker tag nginx:zhy 192.168.142.77:5000/nginx:zhy //上傳即可 [root@localhost nginx]# docker push 192.168.142.77:5000/nginx:zhy
感謝各位的閱讀,以上就是“Docker的基本控制命令總結(jié)”的內(nèi)容了,經(jīng)過(guò)本文的學(xué)習(xí)后,相信大家對(duì)Docker的基本控制命令總結(jié)這一問(wèn)題有了更深刻的體會(huì),具體使用情況還需要大家實(shí)踐驗(yàn)證。這里是億速云,小編將為大家推送更多相關(guān)知識(shí)點(diǎn)的文章,歡迎關(guān)注!
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。