佳木斯湛栽影视文化发展公司

主頁 > 知識(shí)庫 > 在docker容器中調(diào)用和執(zhí)行宿主機(jī)的docker操作

在docker容器中調(diào)用和執(zhí)行宿主機(jī)的docker操作

熱門標(biāo)簽:阿里云 智能手機(jī) 硅谷的囚徒呼叫中心 美圖手機(jī) 網(wǎng)站建設(shè) 使用U盤裝系統(tǒng) 百度競(jìng)價(jià)點(diǎn)擊價(jià)格的計(jì)算公式 檢查注冊(cè)表項(xiàng)

首先這個(gè)帖子,獻(xiàn)給docker新手。當(dāng)然如果你是一個(gè)老手,文中分割線后的操作方法也是一種思路。

首先說一下,如何在docker中執(zhí)行宿主機(jī)的docker操作,我們管它叫docker in docker。

至于為什么要在docker中操作宿主機(jī)的docker,優(yōu)點(diǎn)不言而喻,你既可以將你的具體需求容器化部署,又不用直接在宿主機(jī)上安裝(假設(shè)我們沒有辦法在docker中操作宿主機(jī)的docker,那么我們只能將這樣的軟件程序直接安裝到宿主機(jī)上,這樣顯然是不利于管理和維護(hù)的)。

實(shí)現(xiàn)這種需求,其實(shí)非常簡(jiǎn)單,你只需要將docker宿主機(jī)的docker文件和docker.sock文件掛載到容器中即可,具體為:

-v /var/run/docker.sock:/var/run/docker.sock

-v /usr/bin/docker:/usr/bin/docker

你要先找到你宿主機(jī)的docker和docker.sock位置,別掛載錯(cuò)了,標(biāo)準(zhǔn)的Linux正常來說就是上面的位置。

你在啟動(dòng)docker容器的時(shí)候,將上述兩個(gè)文件正常掛載后,就可以在docker中執(zhí)行諸如 docker images 等等這樣的命令了。

如果出現(xiàn)問題 permission denied

Got permission denied while trying to connect to the Docker daemon socket at unix:///var/run/docker.sock

…………………………………………………………

dial unix /var/run/docker.sock: connect: permission denied

解決方法

在容器所在的宿主機(jī)上直接給 docker.sock 777權(quán)限,命令 chmod 777 docker.sock

華麗麗的分割線

下面是針對(duì)群輝系統(tǒng),你不用太關(guān)心這個(gè)系統(tǒng)是什么,總之就是這個(gè)系統(tǒng)在docker方面有一些特有的問題,導(dǎo)致你不能這么隨心所欲,所以我采用了一種變通的方法來處理(一種思路,拋磚引玉)先敘述一下現(xiàn)狀:

該系統(tǒng)提供了docker的UI管理工具,我們?cè)谶@個(gè)工具上可以進(jìn)行常規(guī)的掛載操作,但是如果我們想掛載上面的docker和docker.sock文件,就不行了,先看一下截圖:

說一下圖上UI操作的局限性!

群輝官方進(jìn)行了限制,你可以選擇的文件,是不可能選擇到 /usr/ /va/ 等這樣系統(tǒng)層面的文件的,也就是我們無法直接掛載docker和docker.sock文件。

做 ln -s 軟連接是否可行?

經(jīng)嘗試,先通過ssh命令行在jenkins文件夾中創(chuàng)建2個(gè)軟連接(將docker和docker.sock進(jìn)行軟連接),然后回到群輝的UI界面,依然不能選擇(因?yàn)槿狠x直接屏蔽了軟連接文件,你是看不到的)

那么如何解決呢?

我的方法是(軟連接的方法變通一下):

1、在圖上的jenkins目錄下隨便創(chuàng)建2個(gè)文件 docker 和 docker.sock 文件(命名正確即可)

2、然后在docker點(diǎn)擊“添加文件”按鈕,正常選擇這2個(gè)文件,進(jìn)行掛載,你完全可以正常掛載并且完成其他配置,配置完畢后,暫時(shí)不要啟動(dòng)docker容器。

3、登錄ssh進(jìn)入群輝,將jenkins目錄中剛剛創(chuàng)建的2個(gè)文件刪除掉,然后把docker和docker.sock源文件創(chuàng)建軟連接到j(luò)enkins中。

root@test:cd /volume1/docker/jenkins/
root@test:rm -rf docker docker.sock
root@test:ln -s /run/docker.sock /volume1/docker/jenkins/docker.sock
root@test:ln -s /usr/local/bin/docker /volume1/docker/jenkins/docker
root@test:/volume1/docker/jenkins# ll
total 8
drwxrwxrwx+ 1 Nuggets users 96 Jun 6 11:22 .
drwxr-xr-x+ 1 root root 188 May 30 19:29 ..
lrwxrwxrwx 1 root root 21 Jun 6 11:22 docker -> /usr/local/bin/docker
lrwxrwxrwx 1 root root 16 Jun 6 11:21 docker.sock -> /run/docker.sock
drwxrwxrwx+ 1 shanhongyu users 24 Jun 1 11:07 java_home
drwxrwxrwx+ 1 Nuggets users 4476 Jun 6 11:00 jenkins_home
drwxrwxrwx+ 1 shanhongyu users 82 Jun 1 11:12 maven_home

4、然后回到群輝UI,啟動(dòng)容器,這樣就完美了。

(群輝不讓你選軟連接,但是linux和docker本質(zhì)上是可以直接掛載軟連接的)

補(bǔ)充知識(shí):使用docker在鏡像中運(yùn)行宿主機(jī)程序

docker run命令用于在新容器中運(yùn)行命令。docker run命令首先在指定的映像上創(chuàng)建一個(gè)可寫容器層,然后使用指定的命令啟動(dòng)它。

也就是說,docker run相當(dāng)于API /containers/create 和 /containers/(id)/start。

可以使用docker start重新啟動(dòng)停止的容器,并使用其所有先前的更改完整。 請(qǐng)參閱docker ps -a查看所有容器的列表。

用法

docker run [OPTIONS] IMAGE [COMMAND] [ARG...]

Shell

例子

分配名稱并分配偽TTY(-name,-it)

$ docker run --name test -it debian
 
root@d6c0fe130dba:/# exit 13
$ echo $?
13
$ docker ps -a | grep test
d6c0fe130dba  debian:7   "/bin/bash"   26 seconds ago  Exited (13) 17 seconds ago       test

Shell

此示例使用debian:latest映像運(yùn)行一個(gè)名為test的容器。 -it 指示Docker分配連接到容器的stdin的偽TTY; 在容器中創(chuàng)建一個(gè)交互式的bash shell。 在該示例中,bash shell通過輸入exit 13退出。該退出代碼傳遞給docker run的調(diào)用者,并記錄在測(cè)試容器的元數(shù)據(jù)中。

捕獲容器ID(-cidfile)

$ docker run --cidfile /tmp/docker_test.cid ubuntu echo "test"

Shell

這將創(chuàng)建一個(gè)容器并打印測(cè)試到控制臺(tái)。--cidfile標(biāo)志使Docker嘗試創(chuàng)建一個(gè)新文件,并將容器ID寫入它。如果文件已經(jīng)存在,Docker將返回一個(gè)錯(cuò)誤。 Docker運(yùn)行退出時(shí),Docker將關(guān)閉此文件。

完整的容器功能(-privileged)

$ docker run -t -i --rm ubuntu bash
root@bc338942ef20:/# mount -t tmpfs none /mnt
mount: permission denied

Shell

這將不起作用,因?yàn)槟J(rèn)情況下,大多數(shù)潛在的危險(xiǎn)內(nèi)核功能被丟棄; 包括cap_sys_admin(這是掛載文件系統(tǒng)所需的)。 但是,--privileged標(biāo)志將允許它運(yùn)行:

$ docker run -t -i --privileged ubuntu bash
root@50e3f57e16e6:/# mount -t tmpfs none /mnt
root@50e3f57e16e6:/# df -h
Filesystem  Size Used Avail Use% Mounted on
none   1.9G  0 1.9G 0% /mnt

Shell

設(shè)置工作目錄[-w]

$ docker run -w /path/to/dir/ -i -t ubuntu pwd

Shell

-w允許在目錄中執(zhí)行命令,這里是/path/to/dir/。 如果路徑不存在,則在容器內(nèi)創(chuàng)建。

為每個(gè)容器設(shè)置存儲(chǔ)驅(qū)動(dòng)程序選項(xiàng)

$ docker run -it --storage-opt size=120G fedora /bin/bash

Shell

掛載tmpfs(-tmpfs)

$ docker run -d --tmpfs /run:rw,noexec,nosuid,size=65536k my_image

Shell

--tmpfs標(biāo)志使用rw,noexec,nosuid,size = 65536k選項(xiàng)將一個(gè)空tmpfs裝載到容器中。

掛載卷(-v,-read-only)

$ docker run -v `pwd`:`pwd` -w `pwd` -i -t ubuntu pwd

Shell

-v標(biāo)志將當(dāng)前工作目錄裝載到容器中。 -w允許在當(dāng)前工作目錄中執(zhí)行命令,將目錄更改為pwd返回的值。所以這個(gè)組合使用容器執(zhí)行命令,但在當(dāng)前工作目錄中。

$ docker run -v /doesnt/exist:/foo -w /foo -i -t ubuntu bash

Shell

當(dāng)綁定卷的主機(jī)目錄不存在時(shí),Docker將自動(dòng)在主機(jī)上創(chuàng)建此目錄。 在上面的示例中,Docker將在啟動(dòng)容器之前創(chuàng)建/doesnt/exists文件夾。

$ docker run --read-only -v /icanwrite busybox touch /icanwrite/here

Shell

卷可以與--read-only組合使用,以控制容器寫入文件的位置。 --read-only標(biāo)志將容器的根文件系統(tǒng)掛載為只讀禁止寫入容器的指定卷以外的位置。

以上這篇在docker容器中調(diào)用和執(zhí)行宿主機(jī)的docker操作就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。

標(biāo)簽:懷化 通遼 湘潭 黃山 山南 湖北 賀州 煙臺(tái)

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《在docker容器中調(diào)用和執(zhí)行宿主機(jī)的docker操作》,本文關(guān)鍵詞  ;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 收縮
    • 微信客服
    • 微信二維碼
    • 電話咨詢

    • 400-1100-266
    特克斯县| 嘉黎县| 随州市| 油尖旺区| 新民市| 台安县| 中卫市| 武隆县| 武鸣县| 许昌县| 元朗区| 江达县| 芦溪县| 容城县| 卫辉市| 中西区| 德庆县| 依安县| 奉节县| 鄂伦春自治旗| 阿合奇县| 汪清县| 漳浦县| 海原县| 大化| 广西| 磴口县| 东山县| 元阳县| 大竹县| 两当县| 和田县| 田东县| 许昌县| 长治市| 佛坪县| 建阳市| 梓潼县| 营山县| 环江| 长治市|