cat /etc/redhat-release
uname -a
1、測試環境安裝docker
1.檢查linux內核版本,如果低於4.4,請執行步驟2升級系統,如果已經是4.4,請跳過步驟2
命令
uname -a
執行結果:
Linux xxxxx 4.4.138-1.el7.elrepo.x86_64 #1 SMP Sat Jun 16 09:57:50 EDT 2018 x86_64 x86_64 x86_64 GNU/Linux
2.升級Linux內核
升級系統請切換至root用戶,如果沒有root權限,請聯系值班運維協助升級:
suto su -
在root用戶下執行以下升級腳本:
注意: 升級系統會重啟虛擬機,如有應用在運行請留意
#!/bin/bash
cd /tmp && wget http://10.57.17.7/soft/kernel-lt-4.4.138-1.el7.elrepo.x86_64.rpm
cd /tmp && wget http://10.57.17.7/soft/kernel-lt-devel-4.4.138-1.el7.elrepo.x86_64.rpm
chattr -ai /boot/grub2/grub.cfg
cd /tmp && yum -y install kernel-lt-4.4.138-1.el7.elrepo.x86_64.rpm kernel-lt-devel-4.4.138-1.el7.elrepo.x86_64.rpm
awk -F\' '$1=="menuentry "{print $2}' /etc/grub2.cfg
grub2-set-default 0
chattr +ai /boot/grub2/grub.cfg
reboot
3.安裝docker
使用admin用戶登錄虛擬機,執行以下安裝腳本,腳本執行完后docker環境已經啟動 .
#!/bin/bash yum install -y yum-utils device-mapper-persistent-data lvm2 echo "proxy=http://10.57.22.8:3128/" >> /etc/yum.conf yum-config-manager --add-repo http://mirrors.aliyun.com/docker-ce/linux/centos/docker-ce.repo yum makecache fast yum install docker-ce -y systemctl restart docker
2、初始化測試環境docker基礎鏡像
添加本機ssh key 至測試環境
驗證可登陸,並有admin權限
//remoteHost為測試環境機子ip
ssh ${remoteHost}
//例如
ssh admin@10.xx.xx.xx
注冊公司docker倉庫下載基礎鏡像
注冊公司docker參考
下載基礎鏡像(本地安裝docker ,下載上傳)
docker pull registry.xxx.me/library/centos7.2-java8-tomcat8:1.1.1
注:必須采用1.1.1版本基礎鏡像,否則下面腳本會執行失敗
導出基礎鏡像至本地
命令
docker save [OPTIONS] IMAGE [IMAGE...]
例如
docker save registry.xxx.me/library/centos7.2-java8-tomcat8:1.1.1 > /Users/xxx/work/test/docker/base.tar.gz
初始化腳本initImages.sh
#!/bin/bash
export USER_HOME=`pwd`
FILE_HOME=${USER_HOME}
REMOTE_HOST=${1}
die() {
if [ $# != 2 ] ; then
echo " The first is return code,the second error message!"
echo " e.g.: die 1 'error message'"
exit 1;
fi
code=$1
msg=$2
echo "${msg}" && exit "${code}"
}
process(){
#1、檢查是否含有base.tar.gz鏡像包
cd "${FILE_HOME}" || die 2 "cd ${FILE_HOME} failed"
if [ ! -f "./base.tar.gz" ]; then
die 1 "init failed, not found base.tar.gz"
fi
#2、上傳至服務器
scp ./base.tar.gz $REMOTE_HOST:/home/admin/ || die 3 "upload failed, check ssh is already linked"
#3、登錄服務器並導入鏡像
ssh $REMOTE_HOST "sudo cd /home/admin;sudo docker load < base.tar.gz;sudo rm -rf ./base.tar.gz;exit" || die 4 "load failed..."
}
check() {
if [ -z "$REMOTE_HOST" ]; then
die 5 "check failed,remote host param not input"
fi
}
main() {
check
process
}
main
將initImages.sh放到導出鏡像目錄下執行
命令
//remoteHost為測試環境機子ip
sh initImages.sh ${remoteHost}
例如
sh initImages.sh admin@10.57.17.247
初始化成功返回示例
Loaded image: xxxxxxx
3、本地化部署項目改造
- 文件添加
- 項目根目錄添加env文件
- env
ENV SHUTTER=10.x.xx.xxx:xxx ENV CLUSTER=octopus-xxx ENV GRAYLOG_HOST=10.x.x.xx ENV GRAYLOG_PORT=80 ENV APP_PORT=8088 ENV ENV=test-xx ENV APPNAME=octopus-xxx ENV APP_RUN_MODE=fg ENV LIMIT_CPU=2 ENV LIMIT_MEM=2 ENV CONSOLE_LEVEL=DEBUG
- 注意:以上配置根據自身項目需要作出修,不可直接復制!!!!
- 項目根目錄添加本地化部署build腳本
#!/bin/bash
export APPNAME=`sed '/APPNAME/!d;s/.*=//' env | tr -d '\r'`
export USER_HOME=`pwd`
APP_HOME=${USER_HOME}
die() {
if [ $# != 2 ] ; then
echo " The first is return code,the second error message!"
echo " e.g.: die 1 'error message'"
exit 1;
fi
code=$1
msg=$2
echo "${msg}" && exit "${code}"
}
#初始化環境變量
init(){
cp Dockerfile DockerfileBak
sed -i "" "/^ENV.*/d" Dockerfile
sed -i "" "2 r env" Dockerfile
}
# 編譯打包
build() {
cd "${APP_HOME}" || die 2 "cd ${APP_HOME} failed"
# 輸出commit id
echo -n "$(git rev-parse HEAD|awk '{print substr($0,1,11)}')" > "${APP_HOME}/commit_id"
mvn clean package -Dmaven.test.skip=true || die 301 "Failed compiling project"
rm -rf output
mkdir output
tar czf "output/${APPNAME}-dist.tar.gz" commit_id deploy/tomcat/* deploy/target/* start.shprestop.shstop.shvalidate.sh Dockerfile > /dev/null 2>&1 || die 301 "tar failed"
}
check() {
cd "${APP_HOME}" || die 2 "cd ${APP_HOME} failed"
if [ ! -f "./output/${APPNAME}-dist.tar.gz" ]; then
die 1 "package not generated and build fail..."
fi
die 0 "package generated and build success..."
}
clean(){
rm -rf Dockerfile
rm -rf commit_id
mv DockerfileBak Dockerfile
}
main() {
init
build
clean
check
}
main
注:此文件直接復制,不用做任何更改
項目修改
說明
由於本地化部署打包文件保存至新文件夾output下,為了不上傳至gitlab,因此項目需要做小小的改動
最外層pom.xml中的clean插件中fileset添加
<fileset>
<directory>output</directory>
<includes>
<include>**/*</include>
</includes>
</fileset>
.ignore文件添加output文件夾忽略
output
4、用docker啟動項目
- 將output下tar.gz包上傳服務器admin目錄下
-
命令
scp -r local_folder remote_ip:remote_folder
-
舉例
scp -r ./octopus-xxx-dist.tar.gz admin@10.x.x.xx:/home/admin/
-
新建項目文件夾並將壓縮包
cd /home/admin mkdir ${APP_NAME} tar zxf ${APP_NAME}-dist.tar.gz -C ./${APP_NAME/
-
在解壓后的目錄下啟動docker
-
命令
//打包鏡像 sudo docker build -t name:tag . //啟動鏡像 docker run -d -p 8088:8088 name:tag
- 注意:build語句最后面有個點
-
舉例
sudo docker build -t xxx:20190303 . sudo docker run -d -p 8088:8088 xxx:20190303
-
驗證
- 方法一
-
命令
sudo docker ps -a
-
結果
status One of created, restarting, running, removing, paused, exited, or dead Up x seconds : 成功 Exited x seconds: 停止
- 方法二
-
命令
sudo docker exec -it ${containerId} /bin/bash -
結果
//進入容器內部查看 ps -ef | grep java
- 方法三
-
命令
curl -I -m 10 -o /dev/null -s -w "%{http_code}" "http://127.0.0.1:${APP_PORT}/ok.htm" -
回滾、持續發布....
- 待續...
- docker 常用命令
查看鏡像 docker images 查看容器 docker ps -a 停止容器 docker stop container_id 運行容器 docker run -d -p name:tag 進入容器 sudo docker exec -it CONTAINER /bin/bash 執行容器命令 sudo docker exec -i CONTAINER /bin/bash xxx.sh 構建Dockerfile docker build -t name:tag 啟動docker systemctl start docker 守護進程重啟 sudo systemctl daemon-reload 重啟docker服務 systemctl restart docker 重啟docker服務 sudo service docker restart 關閉docker service docker stop 關閉docker systemctl stop docker
