CentOS上Python自动化运维如何实现
导读:CentOS上Python自动化运维实现指南 1. 准备工作:环境与依赖配置 在CentOS上开展Python自动化运维前,需先搭建基础环境: 安装Python 3:通过sudo yum install python3安装Python 3...
CentOS上Python自动化运维实现指南
1. 准备工作:环境与依赖配置
在CentOS上开展Python自动化运维前,需先搭建基础环境:
- 安装Python 3:通过
sudo yum install python3
安装Python 3(建议版本≥3.6),并验证安装:python3 --version
。 - 安装pip:Python包管理工具,通过
sudo yum install python3-pip
安装,验证:pip3 --version
。 - 配置虚拟环境:避免项目依赖冲突,使用
python3 -m venv myenv
创建虚拟环境,激活:source myenv/bin/activate
。 - 安装核心库:通过pip安装常用运维库,如
paramiko
(SSH远程连接)、psutil
(系统监控)、smtplib
(邮件告警)、fabric
(自动化部署)等。
2. 核心运维场景实现
(1)系统监控与告警
使用psutil
库获取系统资源状态(CPU、内存、磁盘),并通过邮件发送告警。示例代码:
import psutil
import smtplib
from email.mime.text import MIMEText
def get_system_info():
"""获取系统资源使用率"""
return {
&
x27;
cpu&
x27;
: psutil.cpu_percent(interval=1),
&
x27;
memory&
x27;
: psutil.virtual_memory().percent,
&
x27;
disk&
x27;
: psutil.disk_usage(&
x27;
/&
x27;
).percent
}
def send_alert(subject, message):
"""发送邮件告警"""
msg = MIMEText(message)
msg[&
x27;
Subject&
x27;
] = subject
msg[&
x27;
From&
x27;
] = &
x27;
your_email@example.com&
x27;
msg[&
x27;
To&
x27;
] = &
x27;
admin@example.com&
x27;
with smtplib.SMTP(&
x27;
smtp.example.com&
x27;
, 587) as server:
server.starttls()
server.login(&
x27;
your_email@example.com&
x27;
, &
x27;
your_password&
x27;
)
server.sendmail(&
x27;
your_email@example.com&
x27;
, [&
x27;
admin@example.com&
x27;
], msg.as_string())
def monitor():
"""监控并触发告警"""
system_info = get_system_info()
if system_info[&
x27;
cpu&
x27;
] >
80 or system_info[&
x27;
memory&
x27;
] >
80 or system_info[&
x27;
disk&
x27;
] >
80:
alert_msg = f"服务器资源告警:\nCPU使用率:{
system_info[&
x27;
cpu&
x27;
]}
%\n内存使用率:{
system_info[&
x27;
memory&
x27;
]}
%\n磁盘使用率:{
system_info[&
x27;
disk&
x27;
]}
%"
send_alert(&
x27;
CentOS服务器资源告警&
x27;
, alert_msg)
if __name__ == &
x27;
__main__&
x27;
:
monitor()
说明:脚本每分钟运行一次(通过crontab配置),当CPU、内存或磁盘使用率超过80%时,向管理员发送邮件告警。
(2)远程服务器管理
使用paramiko
库实现SSH远程连接,执行命令或传输文件。示例代码:
import paramiko
def remote_execute(hostname, username, password, command):
"""远程执行命令"""
ssh = paramiko.SSHClient()
ssh.set_missing_host_key_policy(paramiko.AutoAddPolicy())
ssh.connect(hostname, port=22, username=username, password=password)
stdin, stdout, stderr = ssh.exec_command(command)
output = stdout.read().decode()
error = stderr.read().decode()
ssh.close()
return output, error
def remote_transfer(hostname, username, password, local_file, remote_path):
"""SFTP文件传输(上传)"""
transport = paramiko.Transport((hostname, 22))
transport.connect(username=username, password=password)
sftp = paramiko.SFTPClient.from_transport(transport)
sftp.put(local_file, remote_path)
sftp.close()
transport.close()
使用示例
output, _ = remote_execute(&
x27;
192.168.1.100&
x27;
, &
x27;
root&
x27;
, &
x27;
password&
x27;
, &
x27;
ls -l /tmp&
x27;
)
print(output)
remote_transfer(&
x27;
192.168.1.100&
x27;
, &
x27;
root&
x27;
, &
x27;
password&
x27;
, &
x27;
/local/monitor.py&
x27;
, &
x27;
/remote/monitor.py&
x27;
)
说明:可用于批量执行远程命令(如重启服务)、传输配置文件或脚本,适用于多服务器管理。
(3)自动化部署
使用fabric
库简化远程部署流程(如代码拉取、依赖安装、服务重启)。示例代码:
from fabric import Connection
def deploy_app():
"""自动化部署Django应用"""
conn = Connection(
host=&
x27;
192.168.1.100&
x27;
,
user=&
x27;
root&
x27;
,
connect_kwargs={
&
x27;
password&
x27;
: &
x27;
password&
x27;
}
)
with conn.cd(&
x27;
/var/www/myapp&
x27;
):
conn.run(&
x27;
git pull origin main&
x27;
) 拉取最新代码
conn.run(&
x27;
pip install -r requirements.txt&
x27;
) 安装依赖
conn.run(&
x27;
python manage.py migrate&
x27;
) 数据库迁移
conn.run(&
x27;
systemctl restart gunicorn&
x27;
) 重启服务
conn.close()
if __name__ == &
x27;
__main__&
x27;
:
deploy_app()
说明:通过fabric.Connection
建立SSH连接,执行一系列部署命令,实现“一键部署”,减少人工操作错误。
(4)文件自动化处理
使用os
和shutil
库实现批量文件操作(如重命名、备份)。示例代码:
import os
import shutil
def batch_rename(folder_path, old_prefix, new_prefix):
"""批量重命名文件"""
for filename in os.listdir(folder_path):
if filename.startswith(old_prefix):
new_name = filename.replace(old_prefix, new_prefix)
os.rename(
os.path.join(folder_path, filename),
os.path.join(folder_path, new_name)
)
print(f"已将{
folder_path}
下以{
old_prefix}
开头的文件重命名为{
new_prefix}
_开头")
def backup_files(src_dir, dest_dir):
"""批量备份文件"""
if not os.path.exists(dest_dir):
os.makedirs(dest_dir)
for file in os.listdir(src_dir):
src_file = os.path.join(src_dir, file)
if os.path.isfile(src_file):
shutil.copy(src_file, dest_dir)
print(f"已将{
src_dir}
下的文件备份到{
dest_dir}
")
使用示例
batch_rename(&
x27;
/var/log&
x27;
, &
x27;
app&
x27;
, &
x27;
app_backup&
x27;
) 将/var/log下以app开头的文件重命名
backup_files(&
x27;
/var/www/static&
x27;
, &
x27;
/backup/static&
x27;
) 备份静态文件
说明:适用于日志归档、配置文件备份等场景,减少手动复制工作量。
3. 定时任务调度
使用crontab
设置周期性任务,让Python脚本自动运行。操作步骤:
- 编辑当前用户的crontab:
crontab -e
。 - 添加定时任务(如每分钟运行监控脚本):
说明:* * * * * /usr/bin/python3 /path/to/monitor.py > > /var/log/monitor.log 2> & 1
* * * * *
表示每分钟执行一次,> > /var/log/monitor.log
将脚本输出追加到日志文件,2> & 1
将错误输出重定向到标准输出。
4. 最佳实践
- 模块化代码:将重复功能(如连接服务器、发送邮件)封装成函数或模块,提高复用性。
- 错误处理与日志:使用
try-except
捕获异常,通过logging
库记录日志(如logging.basicConfig(filename='app.log', level=logging.INFO)
),便于排查问题。 - 敏感信息管理:避免在代码中明文存储密码,使用环境变量(如
os.getenv('DB_PASSWORD')
)或加密工具(如cryptography
库)管理敏感信息。 - 测试与验证:脚本开发完成后,在测试环境验证功能,确保不会影响生产环境。
通过以上步骤,可在CentOS上实现Python自动化运维,覆盖系统监控、远程管理、部署、文件处理等常见场景,提升运维效率与可靠性。
声明:本文内容由网友自发贡献,本站不承担相应法律责任。对本内容有异议或投诉,请联系2913721942#qq.com核实处理,我们将尽快回复您,谢谢合作!
若转载请注明出处: CentOS上Python自动化运维如何实现
本文地址: https://pptw.com/jishu/714948.html