日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

Docker学习笔记1 :镜像制作

發(fā)布時間:2023/12/10 编程问答 33 豆豆
生活随笔 收集整理的這篇文章主要介紹了 Docker学习笔记1 :镜像制作 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.

參考資源:

http://blog.csdn.net/kongxx?viewmode=contents

http://my.oschina.net/feedao/blog

==============================

  • 運(yùn)行環(huán)境

win8.1 + virtual box, 運(yùn)行 centos6.4 64bit, 內(nèi)網(wǎng)通過代理上網(wǎng)。

如下操作基本都在root下進(jìn)行。

  • 目的

嘗試自己建立Docker鏡像

  • 基礎(chǔ)工作

1,阿里云鏡像

執(zhí)行如下腳本,將資源鏡像執(zhí)行阿里云

#!/bin/bash mv /etc/yum.repos.d/CentOS-Base.repo /etc/yum.repos.d/CentOS-Base.repo.backup wget -O /etc/yum.repos.d/CentOS-Base.repo http://mirrors.aliyun.com/repo/Centos-6.repo mv /etc/yum.repos.d/epel.repo /etc/yum.repos.d/epel.repo.backup mv /etc/yum.repos.d/epel-testing.repo /etc/yum.repos.d/epel-testing.repo.backup wget -O /etc/yum.repos.d/epel.repo http://mirrors.aliyun.com/repo/epel-6.repo yum makecache

在windows下編輯后,回車換行符需要替換

使用dos2unix命令

$ dos2unix -k sample.txt

?2,wget上網(wǎng)代理

root用戶

增加/root/.wgetrc 文件,定義代理服務(wù)器及用戶名密碼

http-proxy=proxy_ip:port https-proxy=proxy_ip:port ftp-proxy=proxy_ip:port proxy-user=username proxy-passwd=password

重新登錄一下

聯(lián)網(wǎng)不使用代理時使用?--no-proxy 參數(shù)

?

  • Docker ubuntu 鏡像制作

1,安裝docker

對于CentOS6,可以使用EPEL庫安裝Docker,命令如下

# yum install http://mirrors.yun-idc.com/epel/6/i386/epel-release-6-8.noarch.rpm # yum install docker-io

安裝之后啟動Docker服務(wù),并讓它隨系統(tǒng)啟動自動啟動。

#?service?docker?start #?chkconfig?docker?on

2,安裝工具debbootstrap

yum -y install debootstrap

3,編寫自己的Dockerfile,以ubuntu 14.04 ssh為例: *在docker build 時使用

# 選擇一個已有的os鏡像作為基礎(chǔ) FROM ubuntu# 鏡像的作者 MAINTAINER Leonard Tian "leonard.tianlb@gmail.com"# 安裝openssh-server和sudo軟件包,并且將sshd的UsePAM參數(shù)設(shè)置成no RUN apt-get install -y openssh-server sudo RUN sed -i 's/UsePAM yes/UsePAM no/g' /etc/ssh/sshd_config# 添加測試用戶tianlb,密碼123456,并且將此用戶添加到sudoers里 RUN useradd tianlb RUN echo "tianlb:123456" | chpasswd RUN echo "tianlb ALL=(ALL) ALL" >> /etc/sudoers# 下面這兩句比較特殊,在centos6上必須要有,否則創(chuàng)建出來的容器sshd不能登錄 # RUN ssh-keygen -t dsa -f /etc/ssh/ssh_host_dsa_key # RUN ssh-keygen -t rsa -f /etc/ssh/ssh_host_rsa_key# 啟動sshd服務(wù)并且暴露22端口 RUN mkdir /var/run/sshd EXPOSE 22 CMD ["/usr/sbin/sshd", "-D"]

注意Dockerfile文件的首字母大寫

將鏡像源轉(zhuǎn)換為阿里云的,參考1.阿里云鏡像

4, 創(chuàng)建image

debootstrap --arch amd64 --include=vim,openssh-server,openssh-client trusty ubuntu-trusty http://mirrors.aliyun.com/ubuntu/ cd ubuntu-trusty tar -c . | docker import - ubuntu1404-base # docker build -t ubuntu1404-ssh .

* docker build 目前有問題

查看docker image

# docker images

  REPOSITORY     TAG   IMAGE ID   CREATED         VIRTUAL SIZE
  ubuntu1404-base  latest 6457f5dac973 About an hour ago   287.5 MB

5, 創(chuàng)建容器

docker run -t -i ubuntu1404-base /bin/bash

直接進(jìn)入容器,可以進(jìn)行基本操作,如ls等。

6, ?異常處理

Docker在CentoOS6運(yùn)行一個容器的時候出現(xiàn)下面的錯誤

# docker run -i -t ubuntu1404-base /bin/bash unable to remount sys readonly: unable to mount sys as readonly max retries reached

碰到這個問題需要修改Docker的配置參數(shù)把/etc/sysconfig/docker文件中的other-args更改為:

other_args="--exec-driver=lxc --selinux-enabled"

然后重新啟動Docker服務(wù)

sudo /etc/init.d/docker restart

7, 其他命令

#查看docker容器,及狀態(tài) docker ps -a #啟動容器 docker start ID #停止容器 docker stop ID #刪除容器 docker rm ID

?--End--

轉(zhuǎn)載于:https://www.cnblogs.com/rakuhin/p/3997903.html

總結(jié)

以上是生活随笔為你收集整理的Docker学习笔记1 :镜像制作的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯,歡迎將生活随笔推薦給好友。