ansible批量安装docker(ansible牛逼,不要太爽了)

2024-03-09 14:20

本文主要是介绍ansible批量安装docker(ansible牛逼,不要太爽了),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

ansible简介

Ansible是一个开源的自动化工具,它可以用于配置管理、应用部署、任务自动化等。由Michael DeHaan创立,首个版本在2012年发布。Ansible通过简单易读的YAML(YAML Ain’t Markup Language)语法定义自动化任务,使得它们容易理解和维护。它使用SSH进行通信,无需在远程系统上安装任何代理软件,这简化了管理过程并减少了系统开销。Ansible因其简单性、灵活性和强大的社区支持,已经成为IT自动化领域的一个重要工具。

一、ansible安装配置

1、安装

# 安装EPEL仓库
yum install epel-release# 安装Ansible
yum install -y ansible

验证安装

ansible --version

2、配置

修改/etc/ansible/hosts,添加需要自动化的机器

vim /etc/ansible/hosts
2.1 配置IP和分组

按照需求添加相应的机器IP并按场景进行分组
在这里插入图片描述

2.2 配置账号密码登录(不推荐)

直接在配置文件中配置用户密码提供给ansible访问其他机器,这种方式不推荐

[app]
192.168.1.100 ansible_user=myuser ansible_ssh_pass=mypassword
192.168.1.101 ansible_user=myuser ansible_ssh_pass=mypassword[mysql]
192.168.1.102 ansible_user=myuser ansible_ssh_pass=mypassword[minio]
192.168.1.103
192.168.1.104
192.168.1.105
2.3 配置SSH免密步骤(推荐)

ssh密钥登录更安全一些,如上配置,192.168.1.103/192.168.1.104/192.168.1.105三台机器没有配置用户密码,则需要配置ssh密钥登录

2.3.1 在本地机器上生成SSH密钥对

如果你还没有SSH密钥对(通常是~/.ssh/id_rsa~/.ssh/id_rsa.pub),你可以通过运行以下命令来生成它们:

cd ~/.ssh/# 生成密钥对
ssh-keygen -t rsa -b 4096
2.3.2 将公钥复制到远程服务器
# ssh-copy-id 用户名@远程服务器地址
ssh-copy-id -i id_rsa.pub root@192.168.1.103
ssh-copy-id -i id_rsa.pub root@192.168.1.104
ssh-copy-id -i id_rsa.pub root@192.168.1.105

3、测试

ansible常用命令速查表

# ping一下所有机器
ansible all -m ping

在这里插入图片描述

二、ansible安装配置docker

1、ansible批量安装docker

新建installDocker.xml文件
vim installDocker.xml

将如下yml内容贴进去

---
- name: Install Docker on CentOS 7hosts: commonbecome: yestasks:- name: Install required packagesyum:name:- yum-utils- device-mapper-persistent-data- lvm2state: present- name: Set up the Docker repositoryyum_repository:name: docker-ce-stabledescription: Docker CE Stable - $basearchbaseurl: https://download.docker.com/linux/centos/7/$basearch/stableenabled: 1gpgcheck: 1gpgkey: https://download.docker.com/linux/centos/gpg- name: Install Docker CEyum:name:- docker-ce- docker-ce-cli- containerd.iostate: present- name: Start and enable Docker serviceservice:name: dockerstate: startedenabled: true

如果你其他所有机器均可访问互联网的情况下,直接可以使用ansible-playbook执行此yml进行docker批量安装

ansible-playbook installDocker.xml
测试docker安装结果
ansible all -m shell -a 'docker -v'

成功则放回每台机器对应的docker版本号
在这里插入图片描述

2、ansible批量配置docker

批量修改docker镜像源

逻辑很简单,先修改本机/etc/docker/daemon.json配置并验证无误,再使用ansible批量copy到别的机器

{"registry-mirror": ["https://hub-mirror.c.163.com","https://mirror.baidubce.com"],"insecure-registries": ["reg.xxx.com"]
}

insecure-registries配置为自建harbor镜像仓库

ansible copy批量复制

ansible all -m copy -a 'src=/etc/docker/daemon.json dest=/etc/docker/daemon.json'

解释一下 ansible常用命令速查表

  • ansible:批处理指令
  • all:所有hosts,也可以指定hosts中的分组,如app、db、minio、mysql等
  • -m:module,表示模块的意思,常用模块有 shellcopyping等等
  • copy:复制,这个没啥说的
  • -a:arg表示参数的意思,-m 指定模块,-a为执行这个模块所传递的参数
  • 'src= dest=':-a后面单引号里的内容为具体参数了,srcdestcopy模块所需的参数,src为源文件,dest为目标文件

ansible shell批量脚本

批量重载配置文件并重启docker

ansible all -m shell -a 'systemctl daemon-reload'
ansible all -m shell -a 'systemctl restart docker'

三、扩展网络

如果其他有部分机器不能访问互联网,则需要先将网络打通

1、安装squid代理

yum install -y squid
# 打开配置文件
vim /etc/squid/squid.conf

http_access deny all这一行前面添加如下配置

acl mynetwork src 192.168.131.0/24 # 你的网络或Docker网络的IP范围
http_access allow mynetwork

在这里插入图片描述
端口如果不修改也可以使用默认的

2、配置http_proxy系统代理

新建文件

vim add_http_proxy.yml

将如下yml内容贴进去

- name: Ansible blockinfile 批量新增hosts: all   # 分组become: yes  # 如果需要的话使用sudo权限tasks:- name: Insert a block of textansible.builtin.blockinfile:path: /etc/profile  # 目标文件路径block: |export all_proxy=http://192.168.131.189:31280export http_proxy=http://192.168.131.189:31280export https_proxy=http://192.168.131.189:31280export no_proxy=localhost,127.0.0.1,::1,192.168.131.0/22marker: "# {mark} ANSIBLE MANAGED BLOCK"  # 可选自定义标记state: present

执行ansible-playbook批处理指令

ansible-playbook add_http_proxy.yml

执行source命令使配置生效

ansible all -m shell -a 'source /etc/profile' 

验证执行结果,只要不返回错误,一般也没什么问题

ansible all -m shell -a 'cat /etc/profile | grep proxy'

在这里插入图片描述

3、配置docker代理

3.1、创建http-proxy.conf文件
mkdir -p /etc/systemd/system/docker.service.d
vim /etc/systemd/system/docker.service.d/http-proxy.conf

在http-proxy.conf文件中添加代理配置

[Service]
Environment="HTTP_PROXY=http://192.168.131.10:31280/"
Environment="HTTPS_PROXY=http://192.168.131.10:31280/"
Environment="NO_PROXY=localhost,127.0.0.1,::1,192.168.131.0/22,.your-company.com"
3.2、重载并重启Docker服务

配置完代理之后,重新加载systemd管理器的配置,然后重启Docker服务以应用更改:

systemctl daemon-reload
systemctl restart docker

验证代理配置

systemctl show --property=Environment docker

docker配置代理详解

这篇关于ansible批量安装docker(ansible牛逼,不要太爽了)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/790943

相关文章

基于Python开发一个图像水印批量添加工具

《基于Python开发一个图像水印批量添加工具》在当今数字化内容爆炸式增长的时代,图像版权保护已成为创作者和企业的核心需求,本方案将详细介绍一个基于PythonPIL库的工业级图像水印解决方案,有需要... 目录一、系统架构设计1.1 整体处理流程1.2 类结构设计(扩展版本)二、核心算法深入解析2.1 自

虚拟机Centos7安装MySQL数据库实践

《虚拟机Centos7安装MySQL数据库实践》用户分享在虚拟机安装MySQL的全过程及常见问题解决方案,包括处理GPG密钥、修改密码策略、配置远程访问权限及防火墙设置,最终通过关闭防火墙和停止Net... 目录安装mysql数据库下载wget命令下载MySQL安装包安装MySQL安装MySQL服务安装完成

Python自动化批量重命名与整理文件系统

《Python自动化批量重命名与整理文件系统》这篇文章主要为大家详细介绍了如何使用Python实现一个强大的文件批量重命名与整理工具,帮助开发者自动化这一繁琐过程,有需要的小伙伴可以了解下... 目录简介环境准备项目功能概述代码详细解析1. 导入必要的库2. 配置参数设置3. 创建日志系统4. 安全文件名处

SpringBoot中六种批量更新Mysql的方式效率对比分析

《SpringBoot中六种批量更新Mysql的方式效率对比分析》文章比较了MySQL大数据量批量更新的多种方法,指出REPLACEINTO和ONDUPLICATEKEY效率最高但存在数据风险,MyB... 目录效率比较测试结构数据库初始化测试数据批量修改方案第一种 for第二种 case when第三种

JAVA中安装多个JDK的方法

《JAVA中安装多个JDK的方法》文章介绍了在Windows系统上安装多个JDK版本的方法,包括下载、安装路径修改、环境变量配置(JAVA_HOME和Path),并说明如何通过调整JAVA_HOME在... 首先去oracle官网下载好两个版本不同的jdk(需要登录Oracle账号,没有可以免费注册)下载完

Java JDK1.8 安装和环境配置教程详解

《JavaJDK1.8安装和环境配置教程详解》文章简要介绍了JDK1.8的安装流程,包括官网下载对应系统版本、安装时选择非系统盘路径、配置JAVA_HOME、CLASSPATH和Path环境变量,... 目录1.下载JDK2.安装JDK3.配置环境变量4.检验JDK官网下载地址:Java Downloads

SQL server数据库如何下载和安装

《SQLserver数据库如何下载和安装》本文指导如何下载安装SQLServer2022评估版及SSMS工具,涵盖安装配置、连接字符串设置、C#连接数据库方法和安全注意事项,如混合验证、参数化查... 目录第一步:打开官网下载对应文件第二步:程序安装配置第三部:安装工具SQL Server Manageme

SpringBoot结合Docker进行容器化处理指南

《SpringBoot结合Docker进行容器化处理指南》在当今快速发展的软件工程领域,SpringBoot和Docker已经成为现代Java开发者的必备工具,本文将深入讲解如何将一个SpringBo... 目录前言一、为什么选择 Spring Bootjavascript + docker1. 快速部署与

使用Docker构建Python Flask程序的详细教程

《使用Docker构建PythonFlask程序的详细教程》在当今的软件开发领域,容器化技术正变得越来越流行,而Docker无疑是其中的佼佼者,本文我们就来聊聊如何使用Docker构建一个简单的Py... 目录引言一、准备工作二、创建 Flask 应用程序三、创建 dockerfile四、构建 Docker

SpringBoot+Docker+Graylog 如何让错误自动报警

《SpringBoot+Docker+Graylog如何让错误自动报警》SpringBoot默认使用SLF4J与Logback,支持多日志级别和配置方式,可输出到控制台、文件及远程服务器,集成ELK... 目录01 Spring Boot 默认日志框架解析02 Spring Boot 日志级别详解03 Sp