章工运维 章工运维
首页
  • linux
  • windows
  • 中间件
  • 监控
  • 网络
  • 存储
  • 安全
  • 防火墙
  • 数据库
  • 系统
  • docker
  • 运维工具
  • other
  • elk
  • K8S
  • ansible
  • Jenkins
  • GitLabCI_CD
  • 随笔
  • 面试
  • 工具
  • 收藏夹
  • Shell
  • python
  • golang
友链
  • 索引

    • 分类
    • 标签
    • 归档
    • 首页 (opens new window)
    • 关于我 (opens new window)
    • 图床 (opens new window)
    • 评论 (opens new window)
    • 导航栏 (opens new window)
周刊
GitHub (opens new window)

章工运维

业精于勤,荒于嬉
首页
  • linux
  • windows
  • 中间件
  • 监控
  • 网络
  • 存储
  • 安全
  • 防火墙
  • 数据库
  • 系统
  • docker
  • 运维工具
  • other
  • elk
  • K8S
  • ansible
  • Jenkins
  • GitLabCI_CD
  • 随笔
  • 面试
  • 工具
  • 收藏夹
  • Shell
  • python
  • golang
友链
  • 索引

    • 分类
    • 标签
    • 归档
    • 首页 (opens new window)
    • 关于我 (opens new window)
    • 图床 (opens new window)
    • 评论 (opens new window)
    • 导航栏 (opens new window)
周刊
GitHub (opens new window)
  • python

    • python基础

    • FastAPI

    • python每日练习脚本

      • 监控系统资源情况并发送邮件告警
      • 备份文件并发送邮件通知
      • 批量修改主机名
      • 监控文件夹大小变化并发送邮件通知
      • 批量修改多台主机的SSH端口
      • 监控Web服务器的HTTP响应状态码并发送警报
      • 自动化服务部署脚本01
      • 自动化服务部署脚本02
      • 自动化的系统健康检查和报告生成工具
      • 自动化的Docker容器生成报告脚本
      • 自动化数据库备份和恢复
    • python3给防火墙添加放行
    • python生成部署脚本
    • python将多个文件内容输出到一个文件中
    • 使用 Aligo 定时备份服务器文件
    • python监控日志文件并发送钉钉告警
    • python监控数据库脚本并发送钉钉告警
    • 使用python编写自动化发布脚本
    • 查询redis列表某个元素
    • centos7安装python3
    • python环境管理工具介绍
    • conda安装和镜像源配置
    • pip更换国内源
    • python爬虫
    • python环境启动服务报错缺少glibc库版本
    • 监控目录或文件变化
    • 批量更改文件
    • python引用数据库
  • shell

  • go

  • 编程
  • python
  • python每日练习脚本
章工运维
2024-06-12

批量修改多台主机的SSH端口

脚本如下

import paramiko
import re

# 设置要修改的新SSH端口号
NEW_SSH_PORT = 2222

# 设置要修改SSH端口的主机信息
HOSTS = [
    {'hostname': '10.0.0.1', 'username': 'root', 'password': 'your_password'},
    {'hostname': '10.0.0.2', 'username': 'root', 'key_file': '/path/to/your/key_file'},
    # 添加更多主机
]

# SSH配置文件路径
SSH_CONFIG_FILE = '/etc/ssh/sshd_config'

def modify_ssh_port(client, new_port):
    """修改SSH端口号"""
    # 读取SSH配置文件内容
    stdin, stdout, stderr = client.exec_command(f'cat {SSH_CONFIG_FILE}')
    ssh_config = stdout.read().decode()

    # 使用正则表达式替换端口号
    new_config = re.sub(r'#?\s*Port\s+\d+', f'Port {new_port}', ssh_config)

    # 备份原始配置文件
    stdin, stdout, stderr = client.exec_command(f'cp {SSH_CONFIG_FILE} {SSH_CONFIG_FILE}.bak')

    # 写入新的配置文件内容
    stdin, stdout, stderr = client.exec_command(f'echo "{new_config}" > {SSH_CONFIG_FILE}')

    # 重启SSH服务
    stdin, stdout, stderr = client.exec_command('systemctl restart sshd')
    print(f'主机 {client.get_transport().getpeername()[0]} 的SSH端口已修改为 {new_port}')

def main():
    for host in HOSTS:
        try:
            client = paramiko.SSHClient()
            client.set_missing_host_key_policy(paramiko.AutoAddPolicy())
            if 'key_file' in host:
                client.connect(hostname=host['hostname'], username=host['username'], key_filename=host['key_file'])
            else:
                client.connect(hostname=host['hostname'], username=host['username'], password=host['password'])
            modify_ssh_port(client, NEW_SSH_PORT)
        except Exception as e:
            print(f'无法修改主机 {host["hostname"]} 的SSH端口: {e}')
        finally:
            client.close()

if __name__ == '__main__':
    main()
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
微信 支付宝
上次更新: 2024/12/04, 17:15:49

← 监控文件夹大小变化并发送邮件通知 监控Web服务器的HTTP响应状态码并发送警报→

最近更新
01
shell脚本模块集合
05-13
02
生活小技巧(认知版)
04-29
03
生活小技巧(防骗版)
04-29
更多文章>
Theme by Vdoing | Copyright © 2019-2025 | 点击查看十年之约 | 鄂ICP备2024072800号
  • 跟随系统
  • 浅色模式
  • 深色模式
  • 阅读模式