當前位置:首頁 » 密碼管理 » 容器訪問方式

容器訪問方式

發布時間: 2022-04-20 12:59:52

① 如何進入 Docker 容器

如何進入Docker容器

概述
在使用Docker創建了容器之後,大家比較關心的就是如何進入該容器了,其實進入docker容器有好幾多種方式,這里我們就講一下常用的幾種進入Docker容器的方法。
進入Docker容器比較常見的幾種做法如下:
使用docker attach
使用SSH
使用nsenter
使用exec

下面我們來逐一講一下每種方式。
一、使用docker attach進入Docker容器
Docker提供了attach命令來進入Docker容器。

接下來我們創建一個守護態的Docker容器,然後使用docker attach命令進入該容器。

[plain] view plain
$ sudo docker run -itd ubuntu:14.04 /bin/bash

然後我們使用docker ps查看到該容器信息,接下來就使用docker attach進入該容器

[plain] view plain
$ sudo docker attach 44fc0f0582d9

可以看到我們已經進入到該容器中了。

但在,使用該命令有一個問題。當多個窗口同時使用該命令進入該容器時,所有的窗口都會同步顯示。如果有一個窗口阻塞了,那麼其他窗口也無法再進行操作。下來我們來演示一下。打開兩個窗口,都使用attach命令進入同一個容器裡面。如下所示:

接下來我們只在第一個窗口進行操作,可以看到第一個窗口的操作同步到第二個窗口顯示了,如下:

因為這個原因,所以docker attach命令不太適合於生產環境,平時自己開發應用時可以使用該命令。

二、使用SSH進入Docker容器
在生產環境中排除了使用docker attach命令進入容器之後,相信大家第一個想到的就是ssh。在鏡像(或容器)中安裝SSH Server,這樣就能保證多人進入容器且相互之間不受干擾了,相信大家在當前的生產環境中(沒有使用Docker的情況)也是這樣做的。但是使用了Docker容器之後不建議使用ssh進入到Docker容器內。關於為什麼不建議使用,請參考如下幾篇文章:
Why you don't need to run SSHd in your Docker containers
上面這篇文章是英文的,如果英語不好的話可以參考如下譯文
為什麼不需要在 Docker 容器中運行 sshd

三、使用nsenter進入Docker容器
在上面兩種方式都不適合的情況下,還有一種比較方便的方法,即使用nsenter進入Docker容器。關於什麼是nsenter請參考如下文章:
https://github.com/jpetazzo/nsenter
在了解了什麼是nsenter之後,我們需要把nsenter安裝到主機中(注意是主機而非容器或鏡像),具體的安裝命令如下:

[plain] view plain
$ wget https:/。。。r.gz
$ tar -xzvf util-linux-2.24.tar.gz
$ cd util-linux-2.24/
$ ./configure --without-ncurses
$ make nsenter
$ sudo cp nsenter /usr/local/bin
安裝好nsenter之後可以查看一下該命令的使用。

nsenter可以訪問另一個進程的名稱空間。所以為了連接到某個容器我們還需要獲取該容器的第一個進程的PID。可以使用docker inspect命令來拿到該PID。
docker inspect命令使用如下:

[plain] view plain
$ sudo docker inspect --help

inspect命令可以分層級顯示一個鏡像或容器的信息。比如我們當前有一個正在運行的容器

可以使用docker inspect來查看該容器的詳細信息。

[plain] view plain
$ sudo docker inspect 44fc0f0582d9

由其該信息非常多,此處只截取了其中一部分進行展示。如果要顯示該容器第一個進行的PID可以使用如下方式

[plain] view plain
$ sudo docker inspect -f {{.State.Pid}} 44fc0f0582d9

在拿到該進程PID之後我們就可以使用nsenter命令訪問該容器了。

[plain] view plain
$ sudo nsenter --target 3326 --mount --uts --ipc --net --pid
其中的3326即剛才拿到的進程的PID

當然,如果你認為每次都輸入那麼多參數太麻煩的話,網上也有許多做好的腳本供大家使用。
地址如下:

四、使用docker exec進入Docker容器
除了上面幾種做法之外,docker在1.3.X版本之後還提供了一個新的命令exec用於進入容器,這種方式相對更簡單一些,下面我們來看一下該命令的使用:

[plain] view plain
$ sudo docker exec --help

接下來我們使用該命令進入一個已經在運行的容器

[plain] view plain
$ sudo docker ps
$ sudo docker exec -it 775c7c9ee1e1 /bin/bash

網上還有一種做法是使用nsinit,沒有親身實踐過所以不在此羅列了,有興趣的話可以嘗試一下。

② 請教 容器內與容器外訪問的意思,特點

容器內, 也就是你的web工程內文件的相互訪問, 容器外, 即為外部, 比如客戶端, 或是建立在別的伺服器上的網站, 或是統一伺服器, 不同容器的文件, 這個多用webservice 你看看webservice估計就理解了

③ C++中支持隨機訪問的容器有哪些

stl容器包含順序容器和關聯容器。關聯容器主要有vector,list,deque,關聯容器主要是pair、set、map、multiset和multimap,所以總共算是7種。
所謂隨機訪問,我的理解是按照數組的方式在內存中順序存放,只需要根據首地址和相應下標就能定址到相應的元素。
所以逐個分析如下:
vector的實現原理是數組,所以支持隨機訪問。
list的實現原理是雙向鏈表,所以不支持。
deque的實現原理是類似數組的雙端隊列,支持隨機訪問。
pair是個二元組,一共就兩個值,談不上隨機訪問。
set、multiset、map、multimap的實現原理是紅黑樹,不支持隨機訪問。

所以在上述七種容器中只有vector和deque兩種是支持隨機訪問的。

④ win7怎麼訪問docker容器

安裝Docker
藉助apt-get命令,安裝Docker是件輕而易舉的事。
$
sudo
apt-get
install
docker.io
為了允許非根用戶也可以運行Docker,將你自己添加到docker群組。下面這個命令會允許當前用戶運行Docker,無需根用戶許可權。
$
sudo
usermod
-a
-G
docker
$USER
退出,然後重新登錄,以激活群組成員的變化。
下一步,編輯Docker配置文件,以便更新Docker二進制代碼的位置。
$
sudo
vi
/etc/default/docker.io
DOCKER="/usr/bin/docker.io"
重啟Docker服務。
$
sudo
service
docker.io
restart
管理Docker容器
如果你想啟動Ubuntu操作系統的一個新的Docker容器,首先需要獲取Ubuntu
Docker映像文件。下面這個命令會通過網路下載Docker映像文件。
$
docker
pull
ubuntu
你可以以一種交互模式來開啟Ubuntu
Docker,如下所示。最後一個參數「/bin/bash」是一旦啟動就將在容器裡面執行的命令,這里是一個簡單的bash外殼命令。
$
docker
run
-i
-t
ubuntu
/bin/bash

⑤ docker 容器埠怎麼訪問

Docker容器運行後,如何進入容器進行操作呢?起初我是用SSH。如果只啟動一個容器,用SSH還能應付,只需要將容器的22埠映射到本機的一個埠即可。當我啟動了五個容器後,每個容器默認是沒有配置SSH Server的,安裝配置SSHD,映射容器SSH埠,實在是麻煩。 我發現很多Docker鏡像都是沒有安裝SSHD服務的,難道有其他方法進入Docker容器?有很多種方法,包括使用 docker attach 命令或 nsenter 工具等。
使用 attach 命令有時候並不方便。當多個窗口同時 attach 到同一個容器的時候,所有窗口都會同步顯示。
nsenter 可以訪問另一個進程的名字空間。
為了連接到容器,你還需要找到容器的第一個進程的 PID,可以通過下面的命令獲取。
PID=$(docker inspect –format 「{{ .State.Pid }}」 <container>) //將<container>換成你的容器id
通過這個 PID,就可以連接到這個容器:

⑥ Docker容器使用--net=host的方式啟動後怎樣訪問

&amp;lt;ol&amp;gt;&amp;lt;li&amp;gt;如果容器里沒有運行sshd,可以登錄宿主機後執行docker exec -it CONTAINER_NAME_OR_ID /bin/sh&amp;lt;/li&amp;gt;&amp;lt;li&amp;gt;可以在容器里運行個sshd,通過SSH客戶端登錄。 但由於是用的host網路,所以容器里的sshd進程無法使用默認埠,需要修改其配置文件把埠改成非22埠&amp;lt;/li&amp;gt;&amp;lt;/ol&amp;gt;

⑦ 訪問Docker容器有哪些方法

docker attach
docker exec

⑧ docker 容器的網路設為host, 其他容器怎麼訪問

容器設置為host網路模式,是復用了主機網路來運行容器,直接訪問主機 IP 就可以了。

⑨ 關於容器的容器訪問!

沒事。
unitVec[i]會返回一個vector<_Unit>的引用。
VX也不是萬能的,也不是它就總是正確的。
關鍵是你自己要把握好。
要訪問每個_Unit,兩個for就OK了。

⑩ docker從容器中怎麼訪問宿主機

例如你的docker環境的虛擬IP是192.168.99.100,那麼宿主機同樣會託管一個和192.168.99.100同網段的虛擬IP,並且會是主IP:192.168.99.1,那麼就簡單了,在容器中訪問192.168.99.1這個地址就等於訪問宿主機。

注意,通過192.168.99.1訪問宿主機,等於換了一個ip,如果資料庫或中間件限制了本機訪問或者做了ip段限制,要記得添加192.168.99.1到白名單。

Docker容器運行的時候有 host 、 bridge 、 none 三種網路可供配置。默認是 bridge ,即橋接網路,以橋接模式連接到宿主機; host 是宿主網路,即與宿主機共用網路; none 則表示無網路,容器將無法聯網。

當容器使用 host 網路時,容器與宿主共用網路,這樣就能在容器中訪問宿主機網路,那麼容器的 localhost 就是宿主機的 localhost 。

(10)容器訪問方式擴展閱讀

宿主機和容器通信原理的問題:

考慮重啟速度:在實際的運維過程中,部分場景下,會出現主機卡死,或者docker進程卡死, 這時,最快恢復業務的方法是重啟主機。

容器在主機重啟後,可以自動恢復,因此可以做到在1到2分鍾內快速恢復業務。這一點太重要了,物理機重啟由於需要做各種硬體檢測,重啟時間一般在5到10分鍾, 虛擬機重啟一般在1分鍾以內 , 物理機顯然無法滿足需求。

重建能力很重要:

容器平台經常需要更新操作系統,或者根據需要調整主機規格。

運行一段時間後,發現內存配置偏少了, 需要添加內存。這時候申請一台新的機器加入到集群中,將舊機器下線即可。

運行多年的 ubuntu 12.04 官方已經不再維護, 需要全量替換,工作量相當大。好的方法就是使用全新的伺服器替換舊伺服器。

當發生故障,主機無法恢復時, 直接申請新伺服器加入集群即可。

熱點內容
三國志戰略版打9級礦什麼配置 發布:2025-05-15 11:41:29 瀏覽:951
安卓加速器怎麼關 發布:2025-05-15 11:38:16 瀏覽:463
密碼鎖壞了如何打開 發布:2025-05-15 11:30:19 瀏覽:837
怎樣增加共享文件夾連接數量 發布:2025-05-15 11:24:50 瀏覽:961
安卓如何關閉單應用音量 發布:2025-05-15 11:22:31 瀏覽:351
抖音電腦後台伺服器中斷 發布:2025-05-15 11:11:59 瀏覽:307
sql2008伺服器 發布:2025-05-15 11:03:27 瀏覽:306
我的世界pe伺服器創造 發布:2025-05-15 10:51:17 瀏覽:608
移動端打吃雞要什麼配置 發布:2025-05-15 10:48:16 瀏覽:756
我的世界哪五個伺服器被炸了 發布:2025-05-15 10:36:16 瀏覽:994