亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

使用非root用戶安裝及啟動(dòng)docker的問題(rootless模式運(yùn)行)

 更新時(shí)間:2022年05月21日 08:50:59   作者:字母哥哥  
docker是使用--userns-remap容器用戶映射宿主機(jī)用戶的方式來解決問題,用戶和組的映射由兩個(gè)配置文件來控制,分別是/etc/subuid和/etc/subgid,本文給大家介紹非root用戶啟動(dòng)docker的問題,感興趣的朋友一起看看吧

通過我之前的文章已經(jīng)可以驗(yàn)證,在root用戶下安裝啟動(dòng)的容器存在安全問題。究其原因是因?yàn)椋?/p>

  • 容器內(nèi)的root用戶就是宿主機(jī)的root用戶,容器內(nèi)uid=1000的用戶就是宿主機(jī)uid=1000的用戶
  • docker的守護(hù)進(jìn)程是root權(quán)限的

既然我們知道了原因,那么我們就來解決一下這兩個(gè)問題。

一、容器用戶與宿主機(jī)用戶映射

docker是使用--userns-remap容器用戶映射宿主機(jī)用戶的方式來解決問題,具體的方法描述如下:

用戶和組的映射由兩個(gè)配置文件來控制,分別是/etc/subuid/etc/subgid

echo "zimug:100000:65536" | tee /etc/subuid;
echo "zimug:100000:65536" | tee /etc/subgid;

subuid(sub子uid用戶id):對于subuid的這一行表示,宿主機(jī)用戶zimug的用戶ip段為[100000,10000+65535]。也就是說,使用zimug這個(gè)宿主機(jī)啟動(dòng)容器,容器內(nèi)的用戶uid與宿主機(jī)內(nèi)的用戶uid存在關(guān)系。也就是說按照上面的配置

  • zimug這個(gè)用戶的容器子用戶id(subuid),只能在[100000-165535]之間進(jìn)行分配。[0-99999]這個(gè)區(qū)間范圍內(nèi)的uid仍然保留給宿主機(jī)進(jìn)行使用。
  • 使用zimug啟動(dòng)的第一個(gè)容器,容器用戶root(uid=0)對應(yīng)的宿主機(jī)用戶應(yīng)該是uid=100000(不是宿主機(jī)root用戶)
  • 使用zimug啟動(dòng)的第二個(gè)容器,容器用戶root(uid-0)對應(yīng)的宿主機(jī)用戶可能是uid=101000(也不是宿主機(jī)root用戶)
  • subgid表示的是用戶組id的映射關(guān)系,映射原理和uid是一致的。

二、在非root用戶下運(yùn)行docker守護(hù)進(jìn)程

2.1.docker版本要求

既然root用戶的提權(quán)問題解決了,我們就要解決下一個(gè)問題:docker的守護(hù)進(jìn)程是root權(quán)限的,即運(yùn)行docker守護(hù)進(jìn)程的用戶仍然是root。我們需要做如下修正:

也就是我們要在非root用戶下安裝docker,并啟動(dòng)docker守護(hù)進(jìn)程,這種安裝及運(yùn)行模式被稱為“RootLess”模式。可以安裝但是存在先決條件:“RootLess”模式是在 Docker Engine v19.03 中作為實(shí)驗(yàn)性功能引入的,從 Docker Engine v20.10 開始提供正式使用。

2.2. 前置條件

需要安裝newuidmapnewgidmap工具shadow-utils,即配置上文中的/etc/subuid/etc/subuid需要這兩個(gè)工具的支持。安裝之前使用yum list installed shadow-utils確認(rèn)下是否已經(jīng)安裝過或者操作系統(tǒng)自帶,如果存在就不要安裝了,但第三步的配置是需要的。
第一步:添加一個(gè)軟件包安裝源,該源下面包含shadow-utils46-newxidmap

curl -o /etc/yum.repos.d/vbatts-shadow-utils-newxidmap-epel-7.repo https://copr.fedorainfracloud.org/coprs/vbatts/shadow-utils-newxidmap/repo/epel-7/vbatts-shadow-utils-newxidmap-epel-7.repo

第二步: yum install -y shadow-utils46-newxidmap
第三步:在/etc/sysctl.conf文件中修改系統(tǒng)參數(shù)user.max_user_namespaces = 28633,修改完成之后執(zhí)行sysctl --system命令讓參數(shù)生效。

echo user.max_user_namespaces=28633 >> /etc/sysctl.d/userns.conf;
sudo sysctl -p /etc/sysctl.d/userns.conf;

該參數(shù)默認(rèn)值是0,即不允許操作系統(tǒng)用戶存在subuid空間。上面的操作完成之后使用sysctl --all --pattern user_namespaces命令驗(yàn)證修改的結(jié)果。

2.3.開始rootless模式安裝

root用戶下確保已經(jīng)執(zhí)行下列命令進(jìn)行用戶id關(guān)系配置

echo "zimug:100000:65536" | tee /etc/subuid;
echo "zimug:100000:65536" | tee /etc/subgid;

我已經(jīng)新建了一個(gè)linux用戶zimug,使用su - zimug切換到該用戶下,執(zhí)行安裝腳本,該安裝腳本需要連網(wǎng)。

curl -fsSL https://get.docker.com/rootless | sh

腳本執(zhí)行完成之后,顯示的內(nèi)容如下:

將上圖中安裝過程提示的export內(nèi)容添加到 ~/.bashrc 文件中,添加完使用source ~/.bashrc命令使環(huán)境變量生效。注意:你的環(huán)境變量和我的一定不一致,要copy上圖中紅色部分。

export XDG_RUNTIME_DIR=/home/zimug/.docker/run
export PATH=/home/zimug/bin:$PATH
export DOCKER_HOST=unix:///home/zimug/.docker/run/docker.sock

2.4.啟動(dòng)守護(hù)進(jìn)程運(yùn)行容器

在zimug用戶下使用下面的腳本啟動(dòng)docker守護(hù)進(jìn)程,該腳本在上文中的環(huán)境變量PATH目錄下,所以我們不用寫全路徑。注意:我們這里使用了 --experimental --storage-driver vfs參數(shù)啟動(dòng),因?yàn)槲业膌inux內(nèi)核版本比較低所以需要加這個(gè)參數(shù),后文我會(huì)說明原因。

dockerd-rootless.sh --experimental --storage-driver vfs

啟動(dòng)一個(gè)容器我們嘗試一下,注意宿主機(jī)映射的端口不能小于1024,因?yàn)閘inux非root用戶不能使用1024以下的端口。

docker run -d --name nginx-zimug -p  8080:80  nginx

訪問nginx服務(wù)看到界面就證明nginx服務(wù)沒有問題,同時(shí)注意宿主機(jī)防火墻開放8080端口訪問,這個(gè)我就不說了。

三、存在若干已知的限制。

官方文檔說的是known-limitations,也就是已知的受限因素是下面這些,未知的受限因素還不一定有多少呢。所以筆者針對rootless模式目前也只是研究,還沒有在生產(chǎn)上能夠正式使用(2022年4月6日)。雖然它很安全,但是如果坑太多的話,我也受不了啊。

  • 目前僅支持以下存儲(chǔ)驅(qū)動(dòng)程序:
  • overlay2(僅當(dāng)使用內(nèi)核 5.11 或更高版本或 Ubuntu 發(fā)行版本的內(nèi)核運(yùn)行時(shí),才能夠支持這個(gè)存儲(chǔ)驅(qū)動(dòng))。上文中我的內(nèi)核版本是3.10達(dá)不到要求。
  • fuse-overlayfs(僅當(dāng)使用內(nèi)核 4.18 或更高版本運(yùn)行并fuse-overlayfs被安裝時(shí))
  • btrfs(僅當(dāng)使用內(nèi)核 4.18 或更高版本運(yùn)行,或者~/.local/share/docker使用user_subvol_rm_allowed掛載選項(xiàng)掛載時(shí))
  • vfs 兼容性最好,但這個(gè)存儲(chǔ)驅(qū)動(dòng)目前僅能用于實(shí)驗(yàn),不能用于生產(chǎn)。
  • 只有在使用 cgroup v2 和 systemd 運(yùn)行時(shí)才支持 Cgroup。
  • 不支持以下功能:
  • AppArmor
  • Checkpoint
  • Overlay網(wǎng)絡(luò)模式
  • 暴漏SCTP 端口

四、卸載Rootless docker

在非root用戶(我用的是zimug用戶)下執(zhí)行下列命令,完成docker rootless卸載
第一步:

rootlesskit rm -rf ~/.local/share/docker

第二步:

$ cd ~/bin 
$ rm -f containerd containerd-shim containerd-shim-runc-v2 ctr docker docker-init docker-proxy dockerd dockerd-rootless-setuptool.sh dockerd-rootless.sh rootlesskit rootlesskit-docker-proxy runc vpnkit

第三步: 把上文中在 ~/.bashrc 文件中添加的環(huán)境變量刪掉。

到此這篇關(guān)于使用非root用戶安裝及啟動(dòng)docker(rootless模式運(yùn)行)的文章就介紹到這了,更多相關(guān)非root用戶啟動(dòng)docker內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • Docker搭建PHP運(yùn)行環(huán)境完整步驟(圖文教程)

    Docker搭建PHP運(yùn)行環(huán)境完整步驟(圖文教程)

    PHP是一種廣泛使用的編程語言,被用于Web開發(fā)和服務(wù)器管理等各種用途,而Docker則是一種非常流行的容器化平臺(tái),可以方便地管理應(yīng)用程序和環(huán)境,這篇文章主要給大家介紹了關(guān)于Docker搭建PHP運(yùn)行環(huán)境的完整步驟,需要的朋友可以參考下
    2023-09-09
  • 完美卸載Docker的詳細(xì)步驟

    完美卸載Docker的詳細(xì)步驟

    Docker是一種流行的容器化平臺(tái),但是有時(shí)候我們可能需要卸載Docker,無論是因?yàn)樾枰匦掳惭b版本,還是因?yàn)椴辉傩枰褂肈ocker,無論何種原因,正確地卸載Docker是很重要的,以確保系統(tǒng)的干凈和穩(wěn)定,下面跟大家詳細(xì)介紹如何徹底卸載Docker的方法,讓你能夠輕松地清理干凈
    2023-11-11
  • docker nginx 部署多個(gè)項(xiàng)目的示例方法

    docker nginx 部署多個(gè)項(xiàng)目的示例方法

    這篇文章主要介紹了docker nginx 部署多個(gè)項(xiàng)目的示例方法,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2018-11-11
  • Docker搭建Gazee的實(shí)現(xiàn)示例

    Docker搭建Gazee的實(shí)現(xiàn)示例

    Gazee 是一個(gè) Web 應(yīng)用,專門用于閱讀和管理數(shù)字漫畫,本文主要介紹了Docker搭建Gazee的實(shí)現(xiàn)示例,具有一定的參考價(jià)值,感興趣的可以了解一下
    2024-04-04
  • docker安裝nginx并配置ssl證書的方法步驟

    docker安裝nginx并配置ssl證書的方法步驟

    本文主要介紹了docker安裝nginx并配置ssl證書的方法步驟,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2023-06-06
  • Docker部署搭建WebDav服務(wù)的詳細(xì)過程

    Docker部署搭建WebDav服務(wù)的詳細(xì)過程

    這篇文章主要介紹了Docker部署WebDav服務(wù),小編綜合了各種共享方式后最終選擇了使用 WebDav 來共享文件,下面小編把搭建部署過程分享給大家,需要的朋友可以參考下
    2022-08-08
  • Docker中忽略文件的實(shí)現(xiàn)

    Docker中忽略文件的實(shí)現(xiàn)

    Docker忽略文件是指在Docker鏡像構(gòu)建過程中,用于忽略指定文件或目錄的一種機(jī)制,本文主要介紹了Docker中忽略文件的實(shí)現(xiàn),具有一定的參考價(jià)值,感興趣的可以了解一下
    2023-10-10
  • 基于Docker部署GitLab環(huán)境搭建的方法步驟

    基于Docker部署GitLab環(huán)境搭建的方法步驟

    這篇文章主要介紹了基于Docker部署GitLab環(huán)境搭建的方法步驟,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-10-10
  • ubuntu vps安裝docker報(bào)錯(cuò):Cannot connect to the Docker daemon at unix:///var/run/docker.sock.問題解決

    ubuntu vps安裝docker報(bào)錯(cuò):Cannot connect to the Docker daemon at

    這篇文章主要介紹了解決ubuntu vps安裝docker時(shí)報(bào)錯(cuò):Cannot connect to the Docker daemon at unix:///var/run/docker.sock.問題的相關(guān)資料,文中介紹非常詳細(xì),需要的朋友可以參考借鑒,下面來一起看看吧。
    2017-04-04
  • Docker安裝部署單機(jī)版Rocket及基礎(chǔ)講解

    Docker安裝部署單機(jī)版Rocket及基礎(chǔ)講解

    RocketMQ是阿里巴巴旗下一款開源的MQ框架,經(jīng)歷過雙十一考研、Java編程語言實(shí)現(xiàn),有非常好完整生態(tài)系統(tǒng),這篇文章主要介紹了用Docker部署安裝單機(jī)版Rocket及基礎(chǔ)講解,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值
    2022-07-07

最新評論