溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點(diǎn)擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

如何從零開始搭建自動部署docker環(huán)境

發(fā)布時間:2021-10-12 10:03:05 來源:億速云 閱讀:174 作者:柒染 欄目:云計算

本篇文章給大家分享的是有關(guān)如何從零開始搭建自動部署docker環(huán)境,小編覺得挺實(shí)用的,因此分享給大家學(xué)習(xí),希望大家閱讀完這篇文章后可以有所收獲,話不多說,跟著小編一起來看看吧。

從0開始搭建自動部署環(huán)境

前言

從Docker改變使用動態(tài)庫后,DooD不再可行,而Dind依然可行。針對此改變,重新整理并記錄自動部署環(huán)境配置步驟。

此環(huán)境是實(shí)現(xiàn)微服務(wù)自動部署的基礎(chǔ),使用jenkins持續(xù)集成工具,并內(nèi)置了java和maven,并實(shí)現(xiàn)了容器內(nèi)運(yùn)行Docker命令的功能。

軟件環(huán)境

  • 宿主機(jī)win10

  • 虛擬機(jī)CentOS-7-x86_64-Minimal-1708

  • Docker 17.09.0-ce

  • apache-maven-3.5.2

  • jdk 1.8.0_151

  • jenkins 2.73.3

虛擬機(jī)安裝配置

1. 安裝Docker

參考官方教程Get Docker CE for CentOS 可選項:更換源。官方源下載Docker可能很慢,更換成國內(nèi)的Docker源,比如阿里云的Docker源https://download.docker.com/linux/centos/docker-ce.repo

2. 啟動Docker并設(shè)置開機(jī)自啟

$ sudo service docker start
$ sudo chkconfig docker on

3. 更換Docker鏡像源

從Docker官方源下載鏡像可能很慢,更換成阿里云的源即可。阿里云專屬加速器地址。教程照搬一下,方便查閱。

安裝/升級你的Docker客戶端

推薦安裝1.10.0以上版本的Docker客戶端,參考文檔 docker-ce

如何配置鏡像加速器
針對Docker客戶端版本大于1.10.0的用戶

您可以通過修改daemon配置文件/etc/docker/daemon.json來使用加速器:

sudo mkdir -p /etc/docker
sudo tee /etc/docker/daemon.json <<-'EOF'
{
  "registry-mirrors": ["https://a2srrwpd.mirror.aliyuncs.com"]
}
EOF
sudo systemctl daemon-reload
sudo systemctl restart docker

容器安裝配置

1. 創(chuàng)建Dockerfile

該Dockerfile已實(shí)現(xiàn):

  1. 安裝openjdk1.8、maven、jenkins、git

  2. maven配置阿里云鏡像源

  3. jenkins自啟

  4. 時區(qū)調(diào)整成中國上海

Dockerfile內(nèi)容如下:

FROM centos:centos7.4.1708

MAINTAINER "Simon Sun"<simon.sun.dev@hotmail.com>

ADD http://www-us.apache.org/dist/maven/maven-3/3.5.2/binaries/apache-maven-3.5.2-bin.tar.gz /opt

USER root

RUN tar -zxvf /opt/apache-maven-3.5.2-bin.tar.gz -C /opt \
&& yum install -y wget \
&& yum install -y initscripts \
&& yum install -y sudo \
&& yum install -y java-1.8.0-openjdk \
&& yum install -y java-1.8.0-openjdk-devel \
&& yum install -y git

# install jenkins
RUN wget -O /etc/yum.repos.d/jenkins.repo https://pkg.jenkins.io/redhat-stable/jenkins.repo \
&& rpm --import https://pkg.jenkins.io/redhat-stable/jenkins.io.key \
&& yum install -y jenkins

# install docker with aliyun mirror source
RUN yum install -y yum-utils \
  device-mapper-persistent-data \
  lvm2 \
&& yum-config-manager \
    --add-repo \
    https://mirrors.aliyun.com/docker-ce/linux/centos/docker-ce.repo \
&& yum-config-manager --disable docker-ce-edge \
&& yum install -y docker-ce

RUN chmod a+x /opt/apache-maven-3.5.2/bin/mvn

# add user jenkins and add user jenkins to group docker
# set root password to root
RUN echo "jenkins ALL=(ALL) NOPASSWD: ALL" >> /etc/sudoers \
&& gpasswd -a jenkins docker \
&& echo "root:root" | chpasswd

ENV JAVA_HOME /usr/lib/jvm/java
ENV PATH $JAVA_HOME/bin:$PATH
ENV MAVEN_HOME /opt/apache-maven-3.5.2
ENV PATH $MAVEN_HOME/bin:$PATH

ENV TZ=Asia/Shanghai
RUN ln -snf /usr/share/zoneinfo/$TZ /etc/localtime && echo $TZ > /etc/timezone

# add aliyun maven mirror source
RUN sed -i '/<\/mirrors>/i\<mirror>\n  <id>nexus-aliyun<\/id>\n  <mirrorOf>central<\/mirrorOf>\n  <name>Nexus aliyun<\/name>\n  <url>http://maven.aliyun.com/nexus/content/groups/public<\/url>\n<\/mirror>' /opt/apache-maven-3.5.2/conf/settings.xml

USER jenkins

CMD sudo service jenkins start && tail -F /var/log/jenkins/jenkins.log

2. 編譯Dockerfile

docker build -t jeesun/java-jenkins .

3. 啟動容器

docker run --privileged -i -t -v /var/run/docker.sock:/var/run/docker.sock -p 8080:8080 jeesun/java-jenkins

此時我已經(jīng)使用jenkins賬戶登錄到容器中,根據(jù)Dockerfile,此時jenkins已經(jīng)自啟,且目前正在運(yùn)行命令tail -F /var/log/jenkins/jenkins.log

  1. Ctrl+P+Q退出bash。命令Ctrl+P+Q保證退出容器不關(guān)閉容器。

  2. 訪問http://localhost:8080。當(dāng)然,因?yàn)槲已b的是minimal版的CentOS,沒有圖形界面,只能在宿主機(jī)上通過http://虛擬機(jī)ip:8080來訪問??墒褂妹?code>ip addr查看虛擬機(jī)ip地址。

  3. 使用docker ps查看CONTAINER ID。

  4. 使用docker exec -it container_id /bin/bash進(jìn)入容器。

  5. 首次訪問該地址需要使用/var/lib/jenkins/secrets/initialAdminPassword中的初始管理員密碼來解鎖jenkins。 執(zhí)行cat /var/lib/jenkins/secrets/initialAdminPassword就可以知道密碼了。

  6. 按照頁面指示繼續(xù),jenkins會推薦下載一些插件。我默認(rèn)都安裝了。如果安裝失敗重試即可。然后就是填入新的管理員賬號密碼。完成后正式進(jìn)入jenkins管理頁面。

5. 測試

選擇新建,填入項目名稱,選擇構(gòu)建一個自由風(fēng)格的軟件項目。 構(gòu)建——》增加構(gòu)建步驟——》Execute shell——》填入docker run hello-world——》保存。選擇立即構(gòu)建。如果不報錯,氣球?yàn)樗{(lán)色,說明成功。

6.自動部署

從0開始搭建自動部署環(huán)境(續(xù))

報錯解決

1. 錯誤1

錯誤內(nèi)容
Got permission denied while trying to connect to the Docker daemon socket at unix:///var/run/docker.sock: Get http://%2Fvar%2Frun%2Fdocker.sock/v1.34/version: dial unix /var/run/docker.sock: connect: permission denied
解決方案
  1. 優(yōu)先參考官方Manage Docker as a non-root user。

  2. 關(guān)閉虛擬機(jī)的selinux(可能有用)。參考查看 SELinux狀態(tài)及關(guān)閉SELinux。

  3. 在虛擬機(jī)中修改/var/run/docker.sock的權(quán)限。(很危險?。。。?/p>

$ sudo chmod 777 /var/run/docker.sock

2. 錯誤2

錯誤內(nèi)容
Failed to get D-Bus connection: Operation not permitted
解決方案

忽略。

3. 錯誤3

錯誤內(nèi)容
Couldn't connect to Docker daemon at http+unix://var/run/docker.sock - is it running?
解決方案

權(quán)限問題。解決辦法同錯誤1。

以上就是如何從零開始搭建自動部署docker環(huán)境,小編相信有部分知識點(diǎn)可能是我們?nèi)粘9ぷ鲿姷交蛴玫降?。希望你能通過這篇文章學(xué)到更多知識。更多詳情敬請關(guān)注億速云行業(yè)資訊頻道。

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報,并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI