最近鼓搗了一個(gè)星期的docker遂跟,終于弄得有點(diǎn)懂了负溪。
1.docker是一個(gè)打包的容器透揣,里面的運(yùn)行的程序的沙盒隔離的,意味著每個(gè)鏡像里面其實(shí)都是裝有一個(gè)Linux操作系統(tǒng)的川抡。
比如:
docker pull Python
它拉下來的這個(gè)鏡像900多M的大小辐真,為什么呢?
這個(gè)鏡像拉下來的時(shí)候其實(shí)也是拉了一個(gè)Ubuntu的操作系統(tǒng)的崖堤,然后這個(gè)Python是跑在這個(gè)Ubuntu里面的侍咱,真是一個(gè)很神奇的設(shè)計(jì),不過確實(shí)這樣的設(shè)計(jì)很好密幔。
2.docker拉下來的鏡像大多數(shù)都是基于Ubuntu的楔脯,意味著不能使用centos的命令,如
yum install
3.docker的重要地方其實(shí)在于寫dockerfile胯甩,這個(gè)dockerfile昧廷,從第一步,from開始偎箫,有點(diǎn)類似一個(gè)腳本
run 后面接的指令是運(yùn)行在Linux程序里面的木柬,
如:
RUN mkdir /opt/test \
&& cd /opt/test
后面還有很多指令不是很熟悉,待我去研究下淹办,哈哈~
docker run 常用的options指令:
-a stdin: 指定標(biāo)準(zhǔn)輸入輸出內(nèi)容類型眉枕,可選 STDIN/STDOUT/STDERR 三項(xiàng);
-d: 后臺(tái)運(yùn)行容器,并返回容器ID速挑;
-i: 以交互模式運(yùn)行容器谤牡,通常與 -t 同時(shí)使用;
-p: 端口映射梗摇,格式為:主機(jī)(宿主)端口:容器端口
-t: 為容器重新分配一個(gè)偽輸入終端,通常與 -i 同時(shí)使用想许;
--name="nginx-lb": 為容器指定一個(gè)名稱伶授;
--dns 8.8.8.8: 指定容器使用的DNS服務(wù)器,默認(rèn)和宿主一致流纹;
--dns-search example.com: 指定容器DNS搜索域名糜烹,默認(rèn)和宿主一致;
-h "mars": 指定容器的hostname漱凝;
-e username="ritchie": 設(shè)置環(huán)境變量疮蹦;
--env-file=[]: 從指定文件讀入環(huán)境變量;
--cpuset="0-2" or --cpuset="0,1,2": 綁定容器到指定CPU運(yùn)行茸炒;
-m :設(shè)置容器使用內(nèi)存最大值愕乎;
--net="bridge": 指定容器的網(wǎng)絡(luò)連接類型,支持 bridge/host/none/container: 四種類型壁公;
--link=[]: 添加鏈接到另一個(gè)容器感论;
--expose=[]: 開放一個(gè)端口或一組端口;
栗子:
// 以交互式命令打開一個(gè)新的窗口啟動(dòng)centos6.8紊册,退出容器后自動(dòng)刪除容器:
docker run -it --rm centos6.8
docker中如果容器間要相互通信,如Python應(yīng)用要使用redis比肄,則不能直接連接127.0.0.1:6379,要先使用命令查看host:
docker network inspect bridge
docker中掛載宿主主機(jī)的db文件到Redis囊陡、MongoDB等數(shù)據(jù)庫(kù)的方法:
假設(shè)掛載宿主本地的/usr/local/db
docker run -v /usr/local/db:data/db -d mongo
清理docker的空間
最近重新部署pyspider的時(shí)候報(bào)錯(cuò)no space left on device
.
一看df -h
,99%的空間木有了7技ā!撞反!
找了好久妥色,終于找到了這個(gè)命令:
docker system prune
直接清理了54個(gè)G的垃圾!6羝垛膝!
docker中的-v、volume指令的注意事項(xiàng)
在docker中-v丁稀、volume指令通常是用來掛載宿主的文件到容器上的吼拥,
栗子:
docker run -v /etc/mydocument:/etc/mydocument image_name
-v、volume指令主要用處是當(dāng)你修改宿主主機(jī)的文件時(shí)也能更新容器內(nèi)的文件
但如果你掛載的是某個(gè)具體的文件线衫,則修改宿主的這個(gè)文件凿可,不會(huì)更新到容器內(nèi),只能掛載文件夾才行!?菖堋惨驶!
栗子:
更改test.txt則不會(huì)更新到容器
docker run -v /etc/mydocument/test.txt:/etc/mydocument/test.txt image_name
更改test.txt會(huì)更新到容器
docker run -v /etc/mydocument:/etc/mydocument image_name
實(shí)時(shí)查看docker容器的日志
sudo docker logs -f -t --tail 行數(shù) 容器名
復(fù)制宿主主機(jī)的內(nèi)容到容器,或從容器復(fù)制內(nèi)容到宿主主機(jī)
將主機(jī)./RS-MapReduce目錄拷貝到容器30026605dcfe的/home/cloudera目錄下:
docker cp RS-MapReduce 30026605dcfe:/home/cloudera
將容器30026605dcfe的/home/cloudera/RS-MapReduce目錄拷貝到主機(jī)的/tmp目錄中:
docker cp 30026605dcfe:/home/cloudera/RS-MapReduce /tmp/
docker-compose 以及docker中l(wèi)inks的含義:
links可以將多個(gè)容器的網(wǎng)絡(luò)接口連接起來敛助,一個(gè)將nginx的80端口映射到app的端口(假設(shè)為2368)具體例子如下:
docker-compose.yml:
nginx:
image: nginx
restart: always
links:
- myapp:app
ports:
- 80:2368
volumes :
- /root/nginx/conf.d: /etc/nginx/conf.d
myapp:
image: app_name
restart: always
由于國(guó)內(nèi)的網(wǎng)絡(luò)情況問題粗卜,在遠(yuǎn)程控制服務(wù)器打包鏡像的時(shí)候可能出現(xiàn)各種下載失敗,導(dǎo)致鏡像不全的情況纳击,這時(shí)候請(qǐng)使用daoclound续扔、淘寶npm、清華大學(xué)pip等國(guó)內(nèi)源;朗纱昧!
前端常用的啟動(dòng)命令:
docker run -p 80:80 -it --rm --name twy -v "${PWD}/nginx":/etc/nginx djytwy/tillage_data_center:latest