摘要:針對此改變,重新整理并記錄自動部署環(huán)境配置步驟。官方源下載可能很慢,更換成國內(nèi)的源,比如阿里云的源啟動并設(shè)置開機自啟更換鏡像源從官方源下載鏡像可能很慢,更換成阿里云的源即可。阿里云專屬加速器地址。
前言
從Docker改變使用動態(tài)庫后,DooD不再可行,而Dind依然可行。針對此改變,重新整理并記錄自動部署環(huán)境配置步驟。
此環(huán)境是實現(xiàn)微服務(wù)自動部署的基礎(chǔ),使用jenkins持續(xù)集成工具,并內(nèi)置了java和maven,并實現(xiàn)了容器內(nèi)運行Docker命令的功能。
軟件環(huán)境宿主機win10
虛擬機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
虛擬機安裝配置 1. 安裝Docker參考官方教程Get Docker CE for CentOS
可選項:更換源。官方源下載Docker可能很慢,更換成國內(nèi)的Docker源,比如阿里云的Docker源https://download.docker.com/linux/centos/docker-ce.repo
$ sudo service docker start $ sudo chkconfig docker on3. 更換Docker鏡像源
從Docker官方源下載鏡像可能很慢,更換成阿里云的源即可。阿里云專屬加速器地址。教程照搬一下,方便查閱。
安裝/升級你的Docker客戶端推薦安裝1.10.0以上版本的Docker客戶端,參考文檔 docker-ce
如何配置鏡像加速器您可以通過修改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已實現(xiàn):
安裝openjdk1.8、maven、jenkins、git
maven配置阿里云鏡像源
jenkins自啟
時區(qū)調(diào)整成中國上海
Dockerfile內(nèi)容如下:
FROM centos:centos7.4.1708 MAINTAINER "Simon Sun"2. 編譯DockerfileADD 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 "//i " /opt/apache-maven-3.5.2/conf/settings.xml USER jenkins CMD sudo service jenkins start && tail -F /var/log/jenkins/jenkins.log nexus-aliyun central Nexus aliyun http://maven.aliyun.com/nexus/content/groups/public
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)自啟,且目前正在運行命令tail -F /var/log/jenkins/jenkins.log。
按Ctrl+P+Q退出bash。命令Ctrl+P+Q保證退出容器不關(guān)閉容器。
訪問http://localhost:8080。當(dāng)然,因為我裝的是minimal版的CentOS,沒有圖形界面,只能在宿主機上通過http://虛擬機ip:8080來訪問??墒褂妹?b>ip addr查看虛擬機ip地址。
使用docker ps查看CONTAINER ID。
使用docker exec -it container_id /bin/bash進入容器。
首次訪問該地址需要使用/var/lib/jenkins/secrets/initialAdminPassword中的初始管理員密碼來解鎖jenkins。 執(zhí)行cat /var/lib/jenkins/secrets/initialAdminPassword就可以知道密碼了。
按照頁面指示繼續(xù),jenkins會推薦下載一些插件。我默認都安裝了。如果安裝失敗重試即可。然后就是填入新的管理員賬號密碼。完成后正式進入jenkins管理頁面。
5. 測試選擇新建,填入項目名稱,選擇構(gòu)建一個自由風(fēng)格的軟件項目。
構(gòu)建——》增加構(gòu)建步驟——》Execute shell——》填入docker run hello-world——》保存。選擇立即構(gòu)建。如果不報錯,氣球為藍色,說明成功。
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解決方案
優(yōu)先參考官方Manage Docker as a non-root user。
關(guān)閉虛擬機的selinux(可能有用)。參考查看 SELinux狀態(tài)及關(guān)閉SELinux。
在虛擬機中修改/var/run/docker.sock的權(quán)限。(很危險!?。。?/p>
$ sudo chmod 777 /var/run/docker.sock2. 錯誤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。
參考內(nèi)容https://askubuntu.com/questions/477551/how-can-i-use-docker-without-sudo
Docker in Docker
DooD(不再有用,因為新版Docker使用了動態(tài)庫)
Dockerfile: ADD vs COPY
Maven鏡像更換為阿里云中央倉庫(精)
tailf、tail -f、tail -F三者區(qū)別
[How to automatically start a service when running a docker container?
](https://stackoverflow.com/que...
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/70625.html
摘要:從開始搭建自動部署環(huán)境續(xù)前言上一篇從開始搭建自動部署環(huán)境雖然環(huán)境搭建起來了,但是配置少了一部分步驟。創(chuàng)建本地倉庫參考新建項目項目是我寫的一個用來測試環(huán)境的項目,代碼托管在上。 從0開始搭建自動部署環(huán)境(續(xù)) 前言 上一篇從0開始搭建自動部署環(huán)境雖然環(huán)境搭建起來了,但是配置少了一部分步驟。本來應(yīng)該寫到上一篇中,但是這樣做篇幅過長了。另外,此篇會使用自動部署一個同步在Github上的Spr...
摘要:從開始搭建自動部署環(huán)境續(xù)前言上一篇從開始搭建自動部署環(huán)境雖然環(huán)境搭建起來了,但是配置少了一部分步驟。創(chuàng)建本地倉庫參考新建項目項目是我寫的一個用來測試環(huán)境的項目,代碼托管在上。 從0開始搭建自動部署環(huán)境(續(xù)) 前言 上一篇從0開始搭建自動部署環(huán)境雖然環(huán)境搭建起來了,但是配置少了一部分步驟。本來應(yīng)該寫到上一篇中,但是這樣做篇幅過長了。另外,此篇會使用自動部署一個同步在Github上的Spr...
摘要:針對此改變,重新整理并記錄自動部署環(huán)境配置步驟。官方源下載可能很慢,更換成國內(nèi)的源,比如阿里云的源啟動并設(shè)置開機自啟更換鏡像源從官方源下載鏡像可能很慢,更換成阿里云的源即可。阿里云專屬加速器地址。 前言 從Docker改變使用動態(tài)庫后,DooD不再可行,而Dind依然可行。針對此改變,重新整理并記錄自動部署環(huán)境配置步驟。 此環(huán)境是實現(xiàn)微服務(wù)自動部署的基礎(chǔ),使用jenkins持續(xù)集成工具...
摘要:和比特幣協(xié)議有所不同的是,以太坊的設(shè)計十分靈活,極具適應(yīng)性。超級賬本區(qū)塊鏈的商業(yè)應(yīng)用超級賬本超級賬本是基金會下的眾多項目中的一個。證書頒發(fā)機構(gòu)負責(zé)簽發(fā)撤 showImg(https://segmentfault.com/img/bV2ge9?w=900&h=385); 從比特幣開始 一個故事告訴你比特幣的原理及運作機制 這篇文章的定位會比較科普,盡量用類比的方法將比特幣的基本原理講出來...
閱讀 2900·2021-11-23 09:51
閱讀 3419·2021-11-22 09:34
閱讀 3319·2021-10-27 14:14
閱讀 1519·2019-08-30 15:55
閱讀 3352·2019-08-30 15:54
閱讀 1078·2019-08-30 15:52
閱讀 1897·2019-08-30 12:46
閱讀 2855·2019-08-29 16:11