-
将docker镜像导出为tar文件;
-
将tar文件上传到K8S服务器;
-
将probedemo.yaml文件发送到K8S服务器;
-
通过sshpass远程执行命令,将docker镜像导入K8S服务器的本地docker仓库;
-
通过sshpass远程执行命令,部署deployment和service;
-
auto_deploy.sh的完整内容如下:
#!/bin/bash
判断是否安装了sshpass
if ! [ -x “$(command -v sshpass)” ]; then
echo ‘请安装sshpass后再使用此脚本!’
exit 1
fi
镜像名
IMAGE_NAME=‘bolingcavalry/probedemo’
TAG名
TAG_NAME=‘0.0.1’
配置了deployment和service的yaml文件名
DEPLOY_SERVICE_YAML=‘probedemo.yaml’
K8S环境的IP地址
K8S_IP_ADDRESS=‘192.168.50.135’
K8S环境的SSH账号
K8S_SSH_ACCOUNT=‘root’
8S环境的SSH密码
K8S_SSH_PSWD=‘888888’
K8S上存放tar和yaml文件的位置
K8S_FILE_PATH=‘~/deploy_temp’
当前名目录
CURRENT_DIR=pwd
echo ‘开始自动构建和部署,当前目录是:’${CURRENT_DIR}
执行maven命令构建项目
mvn clean package -U -DskipTests
echo “构建镜像文件:” I M A G E N A M E / {IMAGE_NAME}/ IMAGENAME/{TAG_NAME}
docker build -t I M A G E N A M E / {IMAGE_NAME}/ IMAGENAME/{TAG_NAME} .
echo “将镜像导出为tar文件:” I M A G E N A M E / {IMAGE_NAME}/ IMAGENAME/{TAG_NAME}
docker save I M A G E N A M E / {IMAGE_NAME}/ IMAGENAME/{TAG_NAME} > ${CURRENT_DIR}/image.tar
echo “在K8S服务器创建存放文件的目录:”${K8S_FILE_PATH}
sshpass -p ${K8S_SSH_PSWD} ssh K 8 S S S H A C C O U N T @ {K8S_SSH_ACCOUNT}@ K8SSSHACCOUNT@{K8S_IP_ADDRESS} “mkdir -p ${K8S_FILE_PATH}”
echo “将yaml文件发送到K8S服务器:” I M A G E N A M E / {IMAGE_NAME}/ IMAGENAME/{TAG_NAME}
sshpass -p ${K8S_SSH_PSWD} scp C U R R E N T D I R / {CURRENT_DIR}/ CURRENTDIR/{DEPLOY_SERVICE_YAML} K 8 S S S H A C C O U N T @ {K8S_SSH_ACCOUNT}@ K8SSSHACCOUNT@{K8S_IP_ADDRESS}😒{K8S_FILE_PATH}/
echo “将镜像tar文件发送到K8S服务器:” I M A G E N A M E / {IMAGE_NAME}/ IMAGENAME/{TAG_NAME}
sshpass -p ${K8S_SSH_PSWD} scp ${CURRENT_DIR}/image.tar K 8 S S S H A C C O U N T @ {K8S_SSH_ACCOUNT}@ K8SSSHACCOUNT@{K8S_IP_ADDRESS}😒{K8S_FILE_PATH}/
echo “如果K8S环境之前已经部署过,就先清理:” I M A G E N A M E / {IMAGE_NAME}/ IMAGENAME/{TAG_NAME}
sshpass -p ${K8S_SSH_PSWD} ssh K 8 S S S H A C C O U N T @ {K8S_SSH_ACCOUNT}@ K8SSSHACCOUNT@{K8S_IP_ADDRESS} “kubectl delete -f K 8 S F I L E P A T H / {K8S_FILE_PATH}/ K8SFILEPATH/{DEPLOY_SERVICE_YAML}”
echo “等待10秒”
sleep 10
echo “清理之前加载到本地仓库的镜像:” I M A G E N A M E / {IMAGE_NAME}/ IMAGENAME/{TAG_NAME}
sshpass -p ${K8S_SSH_PSWD} ssh K 8 S S S H A C C O U N T @ {K8S_SSH_ACCOUNT}@ K8SSSHACCOUNT@{K8S_IP_ADDRESS} “docker rmi I M A G E N A M E / {IMAGE_NAME}/ IMAGENAME/{TAG_NAME}”
echo “从tar文件加载镜像:” I M A G E N A M E / {IMAGE_NAME}/ IMAGENAME/{TAG_NAME}
sshpass -p ${K8S_SSH_PSWD} ssh K 8 S S S H A C C O U N T @ {K8S_SSH_ACCOUNT}@ K8SSSHACCOUNT@{K8S_IP_ADDRESS} “docker load < ${K8S_FILE_PATH}/image.tar”
echo “部署:” I M A G E N A M E / {IMAGE_NAME}/ IMAGENAME/{TAG_NAME}
sshpass -p ${K8S_SSH_PSWD} ssh K 8 S S S H A C C O U N T @ {K8S_SSH_ACCOUNT}@ K8SSSHACCOUNT@{K8S_IP_ADDRESS} “kubectl apply -f K 8 S F I L E P A T H / {K8S_FILE_PATH}/ K8SFILEPATH/{DEPLOY_SERVICE_YAML}”
echo “删除tar文件:”${CURRENT_DIR}/image.tar
rm -rf ${CURRENT_DIR}/image.tar
echo “删镜像:” I M A G E N A M E / {IMAGE_NAME}/ IMAGENAME/{TAG_NAME}
docker rmi I M A G E N A M E / {IMAGE_NAME}/ IMAGENAME/{TAG_NAME}
自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。
深知大多数Java工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则几千的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!
因此收集整理了一份《2024年Java开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。
既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Java开发知识点,真正体系化!
由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!
如果你觉得这些内容对你有帮助,可以扫码获取!!(备注Java获取)
![img](https://img-blog.csdnimg.cn/img_convert/82d9031d0f3f7f2d4929cb2086eed85b.jpeg)
最后
总而言之,面试官问来问去,问的那些Redis知识点也就这么多吧,复习的不够到位,知识点掌握不够熟练,所以面试才会卡壳。将这些Redis面试知识解析以及我整理的一些学习笔记分享出来给大家参考学习
还有更多学习笔记面试资料也分享如下:
《互联网大厂面试真题解析、进阶开发核心学习笔记、全套讲解视频、实战项目源码讲义》点击传送门即可获取!
还有更多学习笔记面试资料也分享如下:
[外链图片转存中…(img-ZJE69TwR-1712919415132)]
《互联网大厂面试真题解析、进阶开发核心学习笔记、全套讲解视频、实战项目源码讲义》点击传送门即可获取!