從Docker改變使用動態庫後,DooD再也不可行,而Dind依然可行。針對此改變,從新整理並記錄自動部署環境配置步驟。html
此環境是實現微服務自動部署的基礎,使用jenkins持續集成工具,並內置了java和maven,並實現了容器內運行Docker命令的功能。java
參考官方教程Get Docker CE for CentOS
可選項:更換源。官方源下載Docker可能很慢,更換成國內的Docker源,好比阿里雲的Docker源https://download.docker.com/linux/centos/docker-ce.repolinux
$ sudo service docker start $ sudo chkconfig docker on
從Docker官方源下載鏡像可能很慢,更換成阿里雲的源便可。阿里雲專屬加速器地址。教程照搬一下,方便查閱。git
推薦安裝1.10.0以上版本的Docker客戶端,參考文檔 docker-cedocker
您能夠經過修改daemon配置文件/etc/docker/daemon.json來使用加速器:shell
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
該Dockerfile已實現:apache
Dockerfile內容以下:json
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
docker build -t jeesun/java-jenkins .
docker run --privileged -i -t -v /var/run/docker.sock:/var/run/docker.sock -p 8080:8080 jeesun/java-jenkins
此時我已經使用jenkins帳戶登陸到容器中,根據Dockerfile,此時jenkins已經自啓,且目前正在運行命令tail -F /var/log/jenkins/jenkins.log
。ubuntu
Ctrl+P+Q
退出bash。命令Ctrl+P+Q
保證退出容器不關閉容器。http://虛擬機ip:8080
來訪問。可以使用命令ip addr
查看虛擬機ip地址。docker ps
查看CONTAINER ID。docker exec -it container_id /bin/bash
進入容器。/var/lib/jenkins/secrets/initialAdminPassword
中的初始管理員密碼來解鎖jenkins。 執行cat /var/lib/jenkins/secrets/initialAdminPassword
就能夠知道密碼了。選擇新建,填入項目名稱,選擇構建一個自由風格的軟件項目。
構建——》增長構建步驟——》Execute shell——》填入docker run hello-world
——》保存。選擇當即構建。若是不報錯,氣球爲藍色,說明成功。centos
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
/var/run/docker.sock
的權限。(很危險!!!)$ sudo chmod 777 /var/run/docker.sock
Failed to get D-Bus connection: Operation not permitted
忽略。
Couldn't connect to Docker daemon at http+unix://var/run/docker.sock - is it running?
權限問題。解決辦法同錯誤1。