Ubuntu 上用 Python 实现远程控制的常用方案
方案一 SSH 远程执行与文件传输(推荐)
pip install paramikoimport paramiko
# 1) 远程执行命令
def remote_execute(hostname, username, password, command, port=22):
ssh = paramiko.SSHClient()
ssh.set_missing_host_key_policy(paramiko.AutoAddPolicy())
try:
ssh.connect(hostname, port=port, username=username, password=password, timeout=10)
stdin, stdout, stderr = ssh.exec_command(command)
out = stdout.read().decode()
err = stderr.read().decode()
if err:
print("STDERR:", err)
print("STDOUT:", out)
finally:
ssh.close()
# 2) SFTP 上传/下载
def sftp_transfer(hostname, username, password, local_path, remote_path, action="put", port=22):
ssh = paramiko.SSHClient()
ssh.set_missing_host_key_policy(paramiko.AutoAddPolicy())
try:
ssh.connect(hostname, port=port, username=username, password=password, timeout=10)
sftp = ssh.open_sftp()
if action == "put":
sftp.put(local_path, remote_path)
print(f"Uploaded {local_path} -> {remote_path}")
elif action == "get":
sftp.get(remote_path, local_path)
print(f"Downloaded {remote_path} -> {local_path}")
sftp.close()
finally:
ssh.close()
# 使用示例
remote_execute("192.168.1.100", "ubuntu", "your_password", "ls -l /tmp")
sftp_transfer("192.168.1.100", "ubuntu", "your_password",
"./local.py", "/home/ubuntu/remote.py", action="put")
&& 或 ; 合并为一条字符串传入 exec_command,避免 cd 后无效的问题。pkey=paramiko.RSAKey.from_private_key_file(...) 更安全。方案二 图形桌面远程控制(VNC 或 RDP)
sudo apt update
sudo apt install xrdp
sudo systemctl enable --now xrdp
sudo ufw allow 3389/tcp # 如启用防火墙
sudo apt install x11vnc
x11vnc -storepasswd # 设置 VNC 密码
sudo tee /etc/systemd/system/x11vnc.service >/dev/null <<'EOF'
[Unit]
Description=Start x11vnc at startup
After=multi-user.target
[Service]
Type=simple
ExecStart=/usr/bin/x11vnc -display :0 -auth /home/ubuntu/.Xauthority -forever -loop -noxdamage -repeat -rfbauth /home/ubuntu/.vnc/passwd -rfbport 5900 -shared
User=ubuntu
Group=ubuntu
[Install]
WantedBy=multi-user.target
EOF
sudo systemctl daemon-reload
sudo systemctl enable --now x11vnc
方案三 无公网 IP 或复杂网页登录的自动化
import time
import requests
from selenium import webdriver
from selenium.webdriver.chrome.options import Options
def is_connected():
try:
requests.get("https://www.baidu.com", timeout=5)
return True
except Exception:
return False
def portal_login(driver_path, url, user, pwd):
opts = Options()
opts.add_argument("--headless")
opts.add_argument("--disable-gpu")
driver = webdriver.Chrome(executable_path=driver_path, options=opts)
try:
driver.get(url)
time.sleep(3) # 等待页面加载
driver.find_element("xpath", "//input[@id='username']").send_keys(user)
driver.find_element("xpath", "//input[@id='password']").send_keys(pwd)
driver.find_element("xpath", "//button[@type='submit']").click()
time.sleep(5)
finally:
driver.quit()
# 使用:portal_login("/usr/local/bin/chromedriver", "https://portal.example.com", "user", "pass")
补充建议与常见做法
scp 将脚本拷入服务器:scp script.py ubuntu@192.168.1.100:/home/ubuntu/
ssh ubuntu@192.168.1.100 "python3 /home/ubuntu/script.py"
# 每小时执行
0 * * * * /usr/bin/python3 /home/ubuntu/script.py