Ansible跳板机自动部署
首先,安装ansible,略过此步骤。
一、控制机(jenkens、ansible所在机器与跳板机之间互信,跳板机与目的机之间互信)
1.在客户端生成公钥私钥对
命令:ssh-keygen -t rsa
一路默认回车,系统在/root/.ssh下生成id_rsa、id_rsa.pub
2.查看系统生成的公钥私钥对
命令:ls /root/.ssh
可以看到如下的文件
3.将生成的公钥私钥对id_rsa.pub发送到其他的服务器上。
命令:ssh-copy-id -i /root/.ssh/id_rsa.pub 192.168.137.129
注:命令可简单记忆为 ssh-copy-id -i 公钥私钥对文件 服务器ip地址
可以看到成功将公钥私钥对发送到了其他服务器,更多服务器一样操作即可。
4.现在可以测试连接其他服务器是否不需要密码登录,可以看到确实成功了。
登录其他服务器命令:ssh 192.168.137.130 #ssh serverid
二、跳板机安装nc命令
1、上传(此文件备份在jenkens服务器192.168.3.83的/opt目录)至跳板机
2、执行rpm -iUv nc-1.84-22.el6.x86_64.rpm
3、执行nc -help确认命令是否成功安装
三、测试ssh通过跳板机代理连接目的机是否成功
ssh -o "ProxyCommand ssh -p 22 root@192.168.40.115 nc -w 1000 %h %p" -p 22 root@192.168.40.116
四、修改ansible操作主机配置文件及编写ansible执行剧本
1、vi /etc/ansible/hosts
增加配置(以下举例)
[webservers] # 这是目的机别名
192.168.40.116
[webservers:vars]# 这是目的机对应配置变量,这里用ansible代理,192.168.40.115作为跳板机
ansible_ssh_common_args=' -o "ProxyCommand ssh -o ConnectTimeout=6000000 -p 22 root@192.168.40.115 nc -w 100000 %h %p"'
2、编写ansible剧本playbook
新增剧本,取名*.yaml
---
- hosts: webservers ---操作主机别名
tasks:
- name: 获取本地jar包
local_action: shell ls /var/lib/jenkins/workspace/ttt/target/alarmprovince*.jar
register: file_name
- name: 删除目标主机上面的备份jar包
shell: rm -f /tmp/alarmprovince.jar.bak
ignore_errors: true
- name: 备份原来jar包
shell: mv /tmp/alarmprovince.jar /tmp/alarmprovince.jar.bak
ignore_errors: true
- name: 拷贝jar包到目标机器
copy: src="{{ file_name.stdout }}" dest=/tmp/alarmprovince.jar
- name: 关闭java进程
shell: ps -ef|grep alarmprovince|grep jar|grep -v grep |awk '{print $2}' |xargs kill -9
ignore_errors: true
- name: 后台不挂起启动
shell: nohup java -jar /tmp/alarmprovince*.jar &
- name: 删除本地jar包
local_action: shell rm -f /var/lib/jenkins/workspace/ttt/target/alarmprovince*.jar
五、配置jenkens
1、配置项目git路径

2、配置mvn构建

3、新增ansible剧本执行(配置操作主机(别名)及指定执行剧本)
六、构建及发布
点击构建,发布成功


(ps:修改ansible_config配置文件,将ssh_timeout时间调大,避免超时)
Ansible跳板机自动部署的更多相关文章
- SecureCRT实现跳板机自动登录
背景: 1.通常运维会开放几个内网的机器能跳转到外网机器进行访问,这样的就是跳板机. 2.比如线上有120.0.0.2这台机器,而内网192.168.1.2这台连接了VPN,能通过SSH登录120.0 ...
- jumpserver(0.3.2版本)开源跳板机系统部署
1. 介绍 JumpServer亮点: 集成Ansible,批量执行命令: 支持WebTerminal wiki地址:https://github.com/jumpserver/jumpserver/ ...
- Linux下使用expect实现跳板机自动跳转/免密登录/自动登录(转)
shell脚本实现ssh自动登录远程服务器示例: #!/usr/bin/expect spawn ssh root@192.168.22.194 expect "*password:&quo ...
- docker-compose之跳板机jumpserver部署
下载docker-compose curl -L https://get.daocloud.io/docker/compose/releases/download/1.24.1/docker-comp ...
- 【自动部署】Ansible 怎么通过堡垒机/跳板机 访问目标机器
Ansible机器的 /root/.ssh/config 配置如下即可:Host 目标机器IP User root IdentityFile=/root/.ssh/xxx_id_rsa ProxyCo ...
- Jenkins + Maven + Ansible + Tomcat 实现JAVA代码自动部署
自动部署过程: jenkins从svn拉取代码,调用maven去打war包,用ansible去解压war包,最后重启tomcat. 前情回顾:在前面的文章我的环境已经有Jenkins+ansible ...
- 使用Ansible进行项目的自动部署(Tomcat、Weblogic)
原文:https://github.com/x113773/testall/issues/4 问题:Weblogic/Tomcat 通过JAVA直接远程调用或者调用本地Shell还是通过Ansible ...
- jenkins + supervisor + ansible 实现netcore程序的多机一键部署
上一篇我们简单的说到了使用jenkins+supervisor实现了一个单机版的多副本部署,但是在更多的场景下还是需要netcore程序的多机一键部署,那么多 机器间如何分发呢? 肯定不能使用scp这 ...
- Linux系统——JumpServer跳板机的搭建和部署
公网源部署jumpserver跳板机 建立阿里云公网源yum仓库(服务端)[root@localhost ~]# lsanaconda-ks.cfg install.log.syslog jumpse ...
随机推荐
- python GIL全局解释器锁与互斥锁 目录
python 并发编程 多线程 GIL全局解释器锁基本概念 python 并发编程 多线程 GIL与Lock python 并发编程 多线程 GIL与多线程
- 从零开始学习GDI+ (三) 画笔与画刷
- C语言作业08
问题 答案 这个作业属于那个课程 C语言程序设计II 这个作业要求在哪里 https://i.cnblogs.com/EditPosts.aspx?opt=1 我在这个课程的目标是 在学好C语言编程的 ...
- hive_server2的权限控制
CDH的core-sit开启: 第一个false表示用系统用户来和hive用户的权限绑定,但经测试并没有生效,所以可以改为true 第二项设置成ALL,表示创建者对其创建的表拥有所有的权限,这样也是比 ...
- 面试题 | 数据库笔试题集合·之·SQL语句(2)
第2章 SQL 语句 2.1 选择2.1.1 DELETE FROM S WHERE 年龄>60 语句的功能是( A ) A.从 S 表中彻底删除年龄大于 60 岁的记录B.S 表中年龄大于 6 ...
- 利用ansible进行主机信息收集
--- - hosts: myjob gather_facts: True vars: IP: "{{ ansible_default_ipv4['address'] }}" HO ...
- 04: CI(持续集成)/CD(持续交付/持续部署)
1.1 持续集成.持续交付 介绍 参考博客:https://www.cnblogs.com/cay83/p/8856231.html 1.传统交付 1. 传统软件的开发与交付的周期都很漫长,从需求 ...
- php程序Apache,IIS 7,nginx 伪静态配置方法总汇
一,Apache 环境伪静态配置方法: 在根目录下放置一个.htaccess 文件,内容如下: <IfModule mod_rewrite.c> Options +FollowSymlin ...
- 在springboot中集成jsp开发
springboot就是一个升级版的spring.它可以极大的简化xml配置文件,可以采用全注解形式开发,一个字就是很牛.在springboot想要使用jsp开发,需要集成jsp,在springboo ...
- linux如何配置使用sendEmail发送邮件
sendEmail是一个轻量级.命令行的SMTP邮件客户端.如果你需要使用命令行发送邮件,那么sendEmail是非常完美的选择.使用简单并且功能强大.这个被设计用在php.bash.perl和web ...