怎么在Docker中利用SSH連接docker容器-創新互聯

本篇文章給大家分享的是有關怎么在Docker中利用SSH連接docker容器,小編覺得挺實用的,因此分享給大家學習,希望大家閱讀完這篇文章后可以有所收獲,話不多說,跟著小編一起來看看吧。

創新互聯建站從2013年創立,是專業互聯網技術服務公司,擁有項目網站設計、成都做網站網站策劃,項目實施與項目整合能力。我們以讓每一個夢想脫穎而出為使命,1280元東湖做網站,已為上家服務,為東湖各地企業和個人服務,聯系電話:13518219792

什么是Docker

Docker 是一個開源項目,誕生于 2013 年初,最初是 dotCloud 公司內部的一個業余項目。它基于 Google 公司推出的 Go 語言實現。 項目后來加入了 Linux 基金會,遵從了 Apache 2.0 協議,項目代碼在 GitHub 上進行維護。

Docker 自開源后受到廣泛的關注和討論,以至于 dotCloud 公司后來都改名為 Docker Inc。Redhat 已經在其 RHEL6.5 中集中支持 Docker;Google 也在其 PaaS 產品中廣泛應用。

Docker 項目的目標是實現輕量級的操作系統虛擬化解決方案。 Docker 的基礎是 Linux 容器(LXC)等技術。

在 LXC 的基礎上 Docker 進行了進一步的封裝,讓用戶不需要去關心容器的管理,使得操作更為簡便。用戶操作 Docker 的容器就像操作一個快速輕量級的虛擬機一樣簡單。

下面的圖片比較了 Docker 和傳統虛擬化方式的不同之處,可見容器是在操作系統層面上實現虛擬化,直接復用本地主機的操作系統,而傳統方式則是在硬件層面實現。

怎么在Docker中利用SSH連接docker容器

怎么在Docker中利用SSH連接docker容器

為什么要用Docker

作為一種新興的虛擬化方式,Docker 跟傳統的虛擬化方式相比具有眾多的優勢。

首先,Docker 容器的啟動可以在秒級實現,這相比傳統的虛擬機方式要快得多。 其次,Docker 對系統資源的利用率很高,一臺主機上可以同時運行數千個 Docker 容器。

容器除了運行其中應用外,基本不消耗額外的系統資源,使得應用的性能很高,同時系統的開銷盡量小。傳統虛擬機方式運行 10 個不同的應用就要起 10 個虛擬機,而Docker 只需要啟動 10 個隔離的應用即可。

具體說來,Docker 在如下幾個方面具有較大的優勢。

更快速的交付和部署

對開發和運維(devop)人員來說,最希望的就是一次創建或配置,可以在任意地方正常運行。

開發者可以使用一個標準的鏡像來構建一套開發容器,開發完成之后,運維人員可以直接使用這個容器來部署代碼。 Docker 可以快速創建容器,快速迭代應用程序,并讓整個過程全程可見,使團隊中的其他成員更容易理解應用程序是如何創建和工作的。 Docker 容器很輕很快!容器的啟動時間是秒級的,大量地節約開發、測試、部署的時間。

更高效的虛擬化

Docker 容器的運行不需要額外的 hypervisor 支持,它是內核級的虛擬化,因此可以實現更高的性能和效率。

更輕松的遷移和擴展

Docker 容器幾乎可以在任意的平臺上運行,包括物理機、虛擬機、公有云、私有云、個人電腦、服務器等。 這種兼容性可以讓用戶把一個應用程序從一個平臺直接遷移到另外一個。

更簡單的管理

使用 Docker,只需要小小的修改,就可以替代以往大量的更新工作。所有的修改都以增量的方式被分發和更新,從而實現自動化并且高效的管理。

對比傳統虛擬機總結


特性容器虛擬機
啟動秒級分鐘即
硬盤使用一般為MB一般為GB
性能接近原生弱于
系統支持量單機支持上千個容器一般幾十個

安裝Docker

本來打算在CentOS6上安裝Docker,最終由于CentOS6上自帶的kernel版本太低導致Docker啟動失敗而放棄(kernel升級太繁瑣)。

怎么在Docker中利用SSH連接docker容器

下面使用CentOS7安裝Docker,本人采用虛擬機的方式來安裝,安裝好的虛擬機必須保證能訪問外網。

CentOS7 系統 CentOS-Extras 庫中已帶 Docker,可以直接安裝:

$ sudo yum install docker

安裝之后啟動 Docker 服務,并讓它隨系統啟動自動加載:

$ sudo service docker start
$ sudo chkconfig docker on

獲取鏡像

可以使用 docker pull 命令來從倉庫獲取所需要的鏡像。

下面的例子將從 Docker Hub 倉庫下載一個Centos6并且安裝了jdk7的鏡像:

$ docker pull tcbenkhard/centos6-jdk7

怎么在Docker中利用SSH連接docker容器

列出本地鏡像

使用 docker images 顯示本地已有的鏡像。

$ docker images

怎么在Docker中利用SSH連接docker容器

啟動容器

啟動容器有兩種方式,一種是基于鏡像新建一個容器并啟動,另外一個是將在終止狀態(stopped)的容器重新啟動。

因為 Docker 的容器實在太輕量級了,很多時候用戶都是隨時刪除和新創建容器。

下面的命令則啟動一個 bash 終端,允許用戶進行交互。

$ docker run -t -i docker.io/tcbenkhard/centos6-jdk7 /bin/bash
[root@ffe81683c404 /]#

怎么在Docker中利用SSH連接docker容器

其中,-t 選項讓Docker分配一個偽終端(pseudo-tty)并綁定到容器的標準輸入上,-i 則讓容器的標準輸入保持打開。

當利用 docker run 來創建容器時,Docker 在后臺運行的標準操作包括:

(1)檢查本地是否存在指定的鏡像,不存在就從公有倉庫下載
(2)利用鏡像創建并啟動一個容器
(3)分配一個文件系統,并在只讀的鏡像層外面掛載一層可讀寫層
(4)從宿主主機配置的網橋接口中橋接一個虛擬接口到容器中去
(5)從地址池配置一個 ip 地址給容器
(6)執行用戶指定的應用程序
(7)執行完畢后容器被終止

可以使用下面命令來查看CentOS版本信息:

$ cat /etc/redhat-release

修改root密碼

使用passwd密碼來修改密碼(如提示沒有這個命令行使用yum install passwd安裝):

$ passwd
  xxx密碼
  xxx確認密碼

安裝Openssh

使用下面命令安裝ssh server/ssh client:

$ sudo yum -y install openssh-server
$ sudo yum -y install openssh-clients

修改SSH配置文件以下選項,去掉#注釋,將四個選項啟用:

$ vi /etc/ssh/sshd_config
RSAAuthentication yes #啟用 RSA 認證
PubkeyAuthentication yes #啟用公鑰私鑰配對認證方式
AuthorizedKeysFile .ssh/authorized_keys #公鑰文件路徑(和上面生成的文件同)
PermitRootLogin yes #root能使用ssh登錄

怎么在Docker中利用SSH連接docker容器

重啟ssh服務,并設置開機啟動:

$ service sshd restart
$ chkconfig sshd on

退出容器并保存更改

使用exit命令或者ctrl+C來退出當前運行的容器:

 [root@ffe81683c404 /]# exit

注意:上面ffe81683c404是容器的ID,退出后用于保存的唯一ID。

當結束后,我們使用 exit 來退出,現在我們的容器已經被我們改變了,使用 docker commit 命令來提交更新后的副本。

$ sudo docker commit -m 'install openssh' -a 'Docker Newbee' ffe81683c404 centos6-jdk7:ssh
4f177bd27a9ff0f6dc2a830403925b5360bfe0b93d476f7fc3231110e7f71b1c

其中,-m 來指定提交的說明信息,跟我們使用的版本控制工具一樣;-a 可以指定更新的用戶信息;之后是用來創建鏡像的容器的ID;最后指定目標鏡像的倉庫名和 tag 信息。創建成功后會返回這個鏡像的 ID 信息。

提交后docker中就會多出一個centos6-jdk7:ssh的一個鏡像。

怎么在Docker中利用SSH連接docker容器

啟動新的容器并打通22端口

將新的鏡像啟動,并將docker服務器的50001端口映射到容器的22端口上:

$ docker run -d -p 50001:22 centos6-jdk7:ssh /usr/sbin/sshd -D

ssh連接容器:

怎么在Docker中利用SSH連接docker容器

以上就是怎么在Docker中利用SSH連接docker容器,小編相信有部分知識點可能是我們日常工作會見到或用到的。希望你能通過這篇文章學到更多知識。更多詳情敬請關注創新互聯行業資訊頻道。

網頁名稱:怎么在Docker中利用SSH連接docker容器-創新互聯
分享URL:http://m.kartarina.com/article46/cdsceg.html

成都網站建設公司_創新互聯,為您提供自適應網站動態網站微信公眾號用戶體驗靜態網站網站維護

廣告

聲明:本網站發布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創新互聯

成都網站建設公司
主站蜘蛛池模板: 精品少妇无码AV无码专区| 免费A级毛片无码A∨男男| 亚洲AV无码成人网站久久精品大| 亚洲国产成人片在线观看无码 | 中文字幕丰满乱子无码视频| 亚洲精品无码不卡在线播放HE| 无码精品A∨在线观看中文| 久久天堂av综合色无码专区| 亚洲精品无码mv在线观看网站| 蜜芽亚洲av无码一区二区三区| 亚洲精品无码MV在线观看| 亚洲人成网亚洲欧洲无码| 久久久久无码专区亚洲av| 伊人久久大香线蕉无码| 国产成人无码av| 尤物永久免费AV无码网站| 秋霞无码一区二区| 无码视频在线观看| 亚洲午夜福利精品无码| 无码日本精品XXXXXXXXX| 久久久久无码国产精品一区| 亚洲精品无码永久在线观看| 四虎国产精品永久在线无码| 精品少妇无码AV无码专区| 亚洲av无码片在线播放| 国产AⅤ无码专区亚洲AV| 亚洲中文字幕无码专区| 免费无码看av的网站| 亚洲熟妇无码八V在线播放| 无码专区—VA亚洲V天堂| 久久久久无码精品亚洲日韩 | 青青草无码免费一二三区| 国产成人无码一区二区三区在线 | 国产精品亚洲а∨无码播放不卡| 无码人妻丰满熟妇啪啪网站| 精品无码久久久久久午夜| 色噜噜综合亚洲av中文无码| 日韩精品无码一本二本三本 | 无码中文字幕av免费放| 亚洲日韩精品无码专区加勒比 | 成人无码AV一区二区|