ansible-app2k8s

#1 介绍

#2 主要功能

  • 镜像构建并推送到镜像仓库
  • 环境初始化(创建 namespace、储存卷、驱动等)
  • 部署监控(prometheus、grafana、loki)
  • 构建与部署服务到 k8s(主要用途)

#3 运行环境

  • 系统 Ubuntu 20
  • ansible 2.7 (高版本可能出现语法兼容性问题)
  • kubenertes(能被kubectl客户端连接即可)

#4 原理与结构

原理很简单,使用ansible管理模板,调用kubectl执行部署

ansible-templates -> deploy.yml -> kubectl -> kubenertes



执行过程使用tag标记,如-t deploy执行deploy部分

根据执行过程,大致分为以下步骤模块

  • base-build 基础镜像构建(docker build)
  • push 推送公共镜像到镜像仓库(docker pull)
  • init 环境初始化(如创建 namespace)
  • monitor 监控警报(如 prometheus)
  • build 构建服务镜像(docker build)
  • deploy 部署服务(kubectl apply )
  • ingress 配置域名访问(7 层代理)

模板目录 roles/k8s/templates

根据服务类别分为如下子目录

  • base 基础镜像 dockerfile
  • ingress 域名解析配置
  • init 环境初始化 yaml 文件
  • java jar包构建镜像和部署模板
  • jetty 使用jetty的服务构建和部署模板
  • monitor 监控警报相关 yaml
  • ms 没有单独参数文件的微服务部署模板
  • nignx 前端静态使用 nginx 容器的部署模板

针对不同k8s环境如dev、prod,使用各自参数配置如储存、镜像仓库、资源限制等

使用ansible -i 指定inventory路径并使用对应的组变量

如dev环境的k8s配置文件 group_vars/dev/k8s.yml

服务app-v1的dev环境配置 group_vars/dev/k8s_apps/app-v1.yml

prod环境使用对应配置路径 group_vars/prod/k8s_apps/app-v1.yml

运行截图

#5 dev 环境准备与配置

#5.1 快速安装 k8s
export Ver=1.22.16 #k8s版本
curl -ks http://elvin.vip/ks/k8s/k8s.master.ha.sh |bash # 参考https://www.cnblogs.com/elvi/p/8976305.html
#5.2 获取 ansible-app2k8s
mkdir -p /data/ansible-app2k8s
cd /data/ansible-app2k8s
#gitee
git clone https://gitee.com/alivv/ansible-app2k8s.git ./ #github
#git clone https://github.com/alivv/ansible-app2k8s.git ./
#5.3 运行 ansible-app2k8s 容器

为保证运行ansible版本一致,我做了ansible镜像

#查看shell
cat /data/ansible-app2k8s/files/run.ansible-app2k8s.sh
sudo docker rm -f ansible-app2k8s &>/dev/null
sudo docker run -dit --net=host \
--name ansible-app2k8s -h app2k8s \
-w /data/ansible-app2k8s \
-v /tmp:/tmp \
-v /etc/hosts:/etc/hosts \
-v ~/.ssh:/root/.ssh \
-v /data/ansible-app2k8s:/data/ansible-app2k8s \
registry.cn-shanghai.aliyuncs.com/elvin/ansible:2.7.18-focal sudo docker ps -l
#运行容器 ansible-app2k8s
bash /data/ansible-app2k8s/files/run.ansible-app2k8s.sh #配置别名
alias app2k8s='docker start ansible-app2k8s ; docker exec -it ansible-app2k8s bash' #linux
echo "alias app2k8s='docker start ansible-app2k8s ; docker exec -it ansible-app2k8s bash'" >>~/.bashrc #macOS
echo "alias app2k8s='sudo docker start ansible-app2k8s ; sudo docker exec -it ansible-app2k8s bash'" >>~/.zshrc #进入ansible-app2k8s容器(Ctrl+d退出)
app2k8s #查看ansbile版本
ansible --version
#5.4 初始化 docker-build 节点

本实例把多个功能部署在 docker-build 单节点

为了安全,实际可根据需求可拆分为多个节点

#5.4.1 更改配置

配置 dev 节点 env/dev/k8s.inv

#配置dev环境节点信息 env/dev/k8s.inv
cat > env/dev/k8s.inv <<EOF
[dev:children]
k8s-node
docker-build [docker-build]
build-node1 ansible_ssh_host=192.168.23.45
[k8s-node]
k8s-node1 ansible_ssh_host=192.168.23.30 [k8s:children]
k8s-node
[docker:children]
docker-build
registry
[registry]
build-node1
EOF #IP地址换自己的,节点需要免密登录
#节点需要安装python2
# apt install -y python python2 python-apt
# ln -fs /usr/bin/python2 /usr/bin/python

配置 dev 环境参数 group_vars/dev/k8s.yml

#修改配置IP地址

k8s_version: 1.22.16

kubectl_node: 192.168.23.45
deploy_yml_node: 192.168.23.45

ansible 测试

ansible -i env/dev all -m ping

#获取节点变量
ansible -i env/dev all -m setup
#5.4.2 安装docker-registrynfs-serveryml-node
#安装docker,docker-py(ansible构建镜像依赖)
ansible-playbook docker.yml -D -i env/dev -l docker-build -t docker,py,job #部署docker-registry作为镜像仓库
ansible-playbook docker.yml -i env/dev -D -l registry -t registry,registry-auth
#增加镜像仓库host解析
ansible-playbook docker.yml -i env/dev -D -t hosts-registry #yml文件存放节点
ansible-playbook docker.yml -i env/dev -D -l docker-build -t yml-node #安装nfs服务和创建nfs目录,创建容器存储卷PVC使用
ansible-playbook nfs.yml -i env/dev -D -l docker-build -t nfs-server #使用nfs储存卷,k8s节点需安装nfs client
ansible-playbook nfs.yml -i env/dev -D -l k8s
#5.4.3 安装配置 kubectl

拷贝k8s 节点配置 /etc/kubernetes/admin.conf

替换本实例配置 roles/k8s/files/kubeconfig-dev.yml

可手动配置kubeconfig,文件路径配置在group_vars/dev/k8s.yml

#安装配置kubectl命令行
ansible-playbook k8s.yml -i env/dev -D -l build-node1 -t kubectl,kubeconfig #kubectl测试命令 kubectl get nodes
ansible-playbook k8s.yml -i env/dev -D -t kubectl-test
#5.5 ansible-app2k8s 测试
#查看帮助
ansible-playbook k8s.yml -i env/dev -D -t h #查看资源列表
ansible-playbook k8s.yml -i env/dev -D -t list

构建镜像测试

#查看base基础镜像dockerfile列表
ansible-playbook k8s.yml -i env/dev -D -t baselist #构建镜像nginx_1.22-alpine-www
ansible-playbook k8s.yml -i env/dev -D -t base-build -e baselist=nginx_1.22-alpine-www #构建完成后打开镜像仓库web查看镜像
#默认账户密码 admin docker
#添加本地host解析后打开 http://hub.elvin.vip

#6 app2k8s 部署服务到 k8s

#6.1 推送公共镜像到镜像仓库
#查看列表
ansible-playbook k8s.yml -i env/dev -D -t pushlist #推送所有(有点耗时)
ansible-playbook k8s.yml -i env/dev -D -t push -e pushlist=all
#6.2 k8 环境初始化
#查看yml列表
ansible-playbook k8s.yml -i env/dev -D -t initlist #执行所有
ansible-playbook k8s.yml -i env/dev -D -t init -e initlist=all
#6.3 部署监控 prometheus、grafana、prometheus-adapter、loki
#警报通知使用钉钉机器人,需要改为自己的机器人tonken
grep notice_dingtalk_token group_vars/dev/k8s_ui.yml #查看yml列表
ansible-playbook k8s.yml -i env/dev -D -t monitorlist #执行所有yml
ansible-playbook k8s.yml -i env/dev -D -t monitor

grafana默认用户密码 admin grafana

添加loki数据源地址 http://loki:3100

添加prometheus数据库源地址 http://prometheus:9090

grafana模板 roles/k8s/templates/monitor/grafana-template/

#6.4 部署服务到 k8s
#查看app列表
ansible-playbook k8s.yml -i env/dev -D -t applist #测试,构建与部署app-v1
ansible-playbook k8s.yml -i env/dev -D -t build,deploy -e applist=app-v1 #构建与部署全部
ansible-playbook k8s.yml -i env/dev -D -t build,deploy -e applist=all
#6.5 域名解析 ingress
ansible-playbook k8s.yml -i env/dev -D -t ingress

查看ingress配置,浏览器打开网址查看如下:

#7 部署验证与清理

#添加本机hosts解析
ansible-playbook dev.yml -i env/dev -D -t hosts-local #查看已配置网址列表,浏览器打开测试
ansible-playbook dev.yml -i env/dev -t url

测试完成后,清理 k8s 的 dev 部署

#删除ingress
ansible-playbook k8s.yml -i env/dev -D -t ingress-rm #删除dev环境服务
ansible-playbook k8s.yml -i env/dev -D -t rm -e applist=all #删除监控
ansible-playbook k8s.yml -i env/dev -D -t monitor-rm #删除环境初始化
ansible-playbook k8s.yml -i env/dev -D -t init-rm

#8 功能解说

#8.1 本文常用 ansible 命令

ansible-playbook k8s.yml -i env/dev -D -t rmi,build,deploy -e applist=app-v1

  • ansible-playbook 执行 ansible 剧本命令行
  • k8s.yml 当前目录剧本文件名
  • -i 指定 inventory 节点路径
  • -D 是--diff 简称,显示执行过程中文件修改变化
  • -t 是--tags 简称,执行 tag 标记部分,使用,分隔多个 tag
  • -e 是--extra-vars 简称,命令行指定变量,变量优先级最高
  • -C 是--check 简称,试运行,用于检测运行过程
#8.2 储存卷 PVE

为便于管理与维护,本实例存储卷PVC使用静态储存

使用PVC时挂载路径添加对应服务子路径 subPath

使用 cronJob 每天压缩与清理 PVC 储存的 log 文件

储存实例类型有 NFS、阿里云 NAS、腾讯云 CFS、AWS EFS、Azure Files

路径 roles/k8s/templates/init 前缀是1.4.pvc的文件

#8.3 日志方案(java 服务)
  • 使用 log4j2 配置需要量化的 log 储存到 ElasticSearch
  • 使用 log4j2 配置日志储存到文件,容器挂载 PVC
  • 使用 loki 搜集终端日志,UI 界面使用 grafana

log4j2 配置在 configmap roles/k8s/templates/jetty/configmap/

#8.4 墙裂推荐的 k8s 工具软件 !!!

以下部署 yaml 路径 roles/k8s/templates/init/

#8.5 有状态服务 StatefulSet
  • 有状态服务使用 StatefulSet 方式部署,需要挂载 PVC 储存
  • 因为有状态服务部署后很少更改,放在 init 分类,前缀有 data 的 yml 文件
    • 如 redis roles/k8s/templates/init/3.data-redis-standone.yml
  • 测试环境部署单节点够用,生产环境推荐使用公有云云原生服务
#8.6 监控警报

监控方案为 prometheus, 主要包含如下模块:

其它监控相关

监控警报规则

prometheus 采集和警报规则都在 prometheus-config.yml 文件

包含警报规则如下:

  • k8s 节点 CPU、内存、磁盘使用率,磁盘剩余容量
  • 容器 Pod 状态、CPU 和内存的限制使用率
  • 其它服务如 JVM、Redis、rabbitmq

grafana 模板

JVM 监控 grafana 视图:

#8.7 容器镜像仓库

docker-registry 单独部署使用可以查看我博客

https://www.cnblogs.com/elvi/p/13394449.html

服务部署到公有云,推荐直接使用公有云的镜像储存服务

#8.8 镜像构建
  • 镜像构建 + push 到镜像仓库
  • 构建镜像不包含源码编译,可按需修改 dockerfile 里的下载地址
  • 其它工具如 Jenkins(源码编译) -> 储存编译包 -> 镜像构建 -> 镜像仓库

配置里有 3 个镜像仓库地址(公有云分内网和外网地址)

  • local_repository_url 构建默认 push 到本地镜像仓库
  • push_repository_url 推送到远程镜像仓库地址
  • deploy_repository_url 部署时的镜像仓库地址
#8.9 安全

请按需并自行解决安全问题,提示以下注意事项:

  • yaml 储存节点配置访问控制
  • 使用 ansible-vault 加密 ansible 密码文件
  • 手动配置 kubeconfig, 并限制 k8s-apiserver 访问
#8.10 其它
  • 由于所有部署步骤,模板均可按需更改,自由度很高
  • k8s 所有配置、部署的操作,均保存 yaml 文件,便于以后升级、迁移等维护
  • 若已熟悉 ansible,可使用本项目作为管理 k8s 部署服务的参考
  • 做自动化部署还需结合其它工具,比如使用 Jenkins

使用 Jenkins+ansible+钉钉通知,自动化部署通知:

#9 日常使用命令参考

#更改构建参数后,查看dockerfile变化
ansible-playbook k8s.yml -i env/dev -D -t dockerfile -e applist=app-v1 -C #更改部署参数后查看deployment变化
ansible-playbook k8s.yml -i env/dev -D -t yml -e applist=app-v1 -C #单独更改configmap配置后,服务需要重启生效
ansible-playbook k8s.yml -i env/dev -D -t config,restart -e applist=app-v1 #构建和部署服务,rmi是删除构建节点已存在的相同tag镜像
ansible-playbook k8s.yml -i env/dev -D -t rmi,build,deploy -e applist=app-v1 #部署生产环境,使用upload上传镜像到外网镜像仓库
ansible-playbook k8s.yml -i env/prod -D -t upload,deploy -e applist=app-v1 #更改prometheus监控警报规则后需要reload生效
ansible-playbook k8s.yml -i dev -D -t monitor-config,monitor-reload

#10 作者

Elvin hi@elvin.vip

主要博客 http://blog.elvin.vip

Source

https://gitee.com/alivv/ansible-app2k8s

https://github.com/alivv/ansible-app2k8s

使用ansible-app2k8s管理和部署服务到 kubernetes的更多相关文章

  1. ansible批量管理软件部署及剧本

    服务器版本信息: Centos6.9 [root@db02 ~]# uname -a Linux db02 -.el6.x86_64 # SMP Tue Mar :: UTC x86_64 x86_6 ...

  2. Linux中ansible批量管理软件部署及剧本编写

    服务器版本信息: Centos6.9 [root@db02 ~]# uname -a Linux db02 2.6.32-696.el6.x86_64 #1 SMP Tue Mar 21 19:29: ...

  3. 六.ansible批量管理服务

    期中集群架构-第六章-ansible批量管理服务介绍====================================================================== 01. ...

  4. Linux(11):期中架构(3)--- SSH远程管理服务 & ansible 批量管理服务

    SSH远程管理服务 1. 远程管理服务知识介绍 # 1.1 SSH远程登录服务介绍说明 SSH是Secure Shell Protocol的简写,由 IETF 网络工作小组(Network Worki ...

  5. ansible批量管理服务 上

    1 ansible简介 1.1 ansible批量管理服务概述 (1)是基于python语言开发的自动化软件工具(2)是基于SSH远程管理服务实现远程主机批量管理(3)并行管理,部署简单,应用也简单方 ...

  6. ansible批量管理服务 下

    1 ansible-playbook 任务剧本 1.1 剧本文件概念 (1)playbook可以将多个批量操作模块功能整合,完成一件事情.(2)简化运维工作复杂度(3)playbook通过yaml语法 ...

  7. Ansible状态管理

     转载自:http://xdays.me/ansible状态管理.html 简介 就像所有服务器批量管理工具(puppet有DSL,salt有state)一样,ansible也有自己的状态管理组件 ...

  8. ansible 自动化管理

    1 什么样的情形需要批量部署 1.操作系统的安装 常见的有collber,red hat satelite(redhat)系统专用. 2.操作系统的配置 常见的有cfengine,puppet,che ...

  9. Linux系统——Ansible批量管理工具

    批量管理工具: (1)ansible 操作简单(适用于500台以下服务器) (2)saltstack 比较复杂(一般适用于1000-4w台服务器) (3)puppet超级复杂 systemctl(统一 ...

  10. ansible批量管理常见的配置方法

    第7章 ansible的管理 7.1 ansible概念的介绍 ansible-playbook –syntax            检查语法 ansible-playbook -C         ...

随机推荐

  1. 人工智能 deepface 换脸技术 学习

    介绍 Deepface是一个轻量级的python人脸识别和人脸属性分析(年龄.性别.情感和种族)框架.它是一种混合人脸识别框架缠绕状态的最先进的模型:VGG-Face,Google FaceNet,O ...

  2. vue自定义组件——split-pane

    pre { overflow-y: auto; max-height: 500px } github地址: https://github.com/lxmghct/my-vue-components 组 ...

  3. 【从零开始】Docker Desktop:听说你小子要玩我

    前言 缘由 捡起遗忘的Docker知识 由于本狗近期项目紧任务重,高强度的搬砖导致摸鱼时间下降.在上线项目时,看到运维大神一系列骚操作,docker+k8s的知识如过眼云烟,忘得干净的很.所以想重新恶 ...

  4. v-if与v-show

    v-if的特点 v-if:是真实的条件控制语句,每当我们满足条件的时候就会显示元素,不满足条件的时候不显示元素(不存在元素没有) v-if:有一套自己的条件控制语句v-if; v-else-if; v ...

  5. 基于Mongodb分布式锁简单实现,解决定时任务并发执行问题

    前言 我们日常开发过程,会有一些定时任务的代码来统计一些系统运行数据,但是我们应用有需要部署多个实例,传统的通过配置文件来控制定时任务是否启动又太过繁琐,而且还经常出错,导致一些异常数据的产生 网上有 ...

  6. Sementic Kernel 案例之网梯科技在线教育

    2023年4月25日,微软公布了2023年第一季度财报,营收528亿美元, 微软CEO纳德称,「世界上最先进的AI模型与世界上最通用的用户界面--自然语言--相结合,开创了一个新的计算时代.」该公司有 ...

  7. JSP 的本质原理解析:"编写的时候是JSP,心里想解读的是 java 源码"

    JSP 的本质原理解析:"编写的时候是JSP,心里想解读的是 java 源码" @ 目录 JSP 的本质原理解析:"编写的时候是JSP,心里想解读的是 java 源码&q ...

  8. 网络编程之java简易聊天室实现

    最近浅学习了一些关于网络编程方面的知识,视频是跟着狂神学习的,可能学习的不是很深 说到网络,相信大家都对TCP.UDP和HTTP协议这些都不是很陌生,学习这部分应该先对端口.Ip地址这些基础知识有一定 ...

  9. 我的web系统设计规范

    以下是我自己在工作中总结的,仅供参考. ·应对所有用户输入进行trim()去除两头空格,若是需要空格的应用 转义代替,不应在js里trim(),而应该在数据库端或后端控制,且只在一处拦截控制,更改策略 ...

  10. 2022-06-27:给出一个长度为n的01串,现在请你找到两个区间, 使得这两个区间中,1的个数相等,0的个数也相等, 这两个区间可以相交,但是不可以完全重叠,即两个区间的左右端点不可以完全一样。

    2022-06-27:给出一个长度为n的01串,现在请你找到两个区间, 使得这两个区间中,1的个数相等,0的个数也相等, 这两个区间可以相交,但是不可以完全重叠,即两个区间的左右端点不可以完全一样. ...