Pythonで自動運用保守を実装する方法
1. インストール
pip install paramiko
2. モジュールのインポート
import paramiko
3. 使用
def initSshClinet (): '' 初期化、サーバーにログインするための SSH 接続アカウントとパスワード: return: sshClinet '' ip = ""#サーバーの IP アドレス sshClinet = paramiko.SSHClient() sshClinet.set_missing_host_key_policy(paramiko.AutoAddPolicy() ) sshClinet.connect( ip, 22, userName, pw, timeout=360) return sshClinet
def exeCommond(commond): '' シェルコマンドを実行します '' stdin, stdout, stderr = sshClient.exec_command( command) outStr = stdout .readlines() print("\n".join(outStr))
def sftpUploadFile(localPath, RemotePath): #SFTP インスタンスを取得します sftp = sshClinet.open_sftp() #アップロードアクション sftp.put(localPath , RemotePath)
def sftpDownloadFile(localPath, RemotePath): #SFTP インスタンスを取得します sftp = sshClinet.open_sftp() #ダウンロードアクションを実行します sftp.get(localPath, RemotePath)
最後に必ず閉じるようにしてくださいConnection
sshClient.close()
#秘密キーを使用してログインすることもできます:
## 秘密キーを構成しますファイルの場所 private = paramiko.RSAKey.from_private_key_file('/Users/ ch/.ssh/id_rsa')#SSHClientclient = paramiko.SSHClient()#サーバーのホスト名とキー情報を保存するポリシーを自動的に追加します。が追加されていない場合、ローカルの know_hosts ファイルに記録されていないホストはクライアントに接続できません。.set_missing_host_key_policy(paramiko.AutoAddPolicy())#SSH サーバーに接続し、ユーザー名とパスワードで認証します client.connect( hostname='10.0.0.1',port=22,username='root',pkey=private)
Learn
paramiko には、SSHClient と SFTPClient という 2 つのコア コンポーネントが含まれています。 SSHClient は、Linux ssh コマンドに似た機能を持ちます。SSH セッションのカプセル化です。このクラスは、トランスポート、チャネル、および SFTPClient 確立メソッド (open_sftp) をカプセル化します。通常、リモート Order を実行するために使用されます。 SFTPClient の機能は Linux の sftp コマンドに似ており、SFTP クライアントのカプセル化であり、ファイルのアップロード、ダウンロード、ファイル権限の変更などのリモート ファイル操作を実装するために使用されます。 チャネルはソケットの一種であり、安全な SSH 伝送チャネルです。トランスポートは暗号化されたセッションです。使用すると、暗号化されたトンネル (チャネル) が同時に作成されます。このトンネルは ChannelSession と呼ばれ、クライアント間で維持されます接続されたオブジェクトでは、connect()/start_client()/start_server() を使用してセッションを開始しますSSHClient の一般的なメソッドの概要
connect( ): リモート サーバーの接続を実現します。認証では、ホスト名のみがこのメソッドの必須パラメータです。 hostname 接続先ホスト port=SSH_PORT 指定ポート username=なし 検証済みユーザー名password=なし 検証済みユーザーパスワード pkey=なし 秘密鍵認証方式 key_filename=なし ファイル名またはファイルリスト、秘密鍵ファイルタイムアウトを指定=None オプションの tcp 接続タイムアウトallow_agent=True SSH エージェントへの接続を許可するかどうか、デフォルトは Trueです。Allow look_for_keys=True ~/.ssh 内の秘密キー ファイルを検索するかどうか、デフォルトは Trueです。Allow compress=False オンにするかどうかCompressionset_missing_host_key_policy(): リモート サーバーが know_hosts ファイルに記録されていない場合の応答ポリシーを設定します。 MissingHostKeyPolicy のサブクラスを渡します。現在、3 つの戦略がサポートされています: 接続されたリモート ホストにローカル ホスト キーまたは HostKeys オブジェクトがない場合の戦略を設定します。現在、3 つの戦略がサポートされています: AutoAddPolicy は、load_system_host_key の構成に依存せず、ホスト名とホスト キーをローカルの HostKeys オブジェクトに自動的に追加します。つまり、新しい ssh 接続を確立するときに、確認のために「yes」または「no」を入力する必要はありません。WarningPolicy は、不明なホスト キーに対する Python 警告を記録するために使用されます。この機能は AutoAddPolicy に似ていますが、load_system_host_key の設定に応じて、新しい接続 RejectPolicy が不明なホスト名とキーを自動的に拒否するように要求します。これはデフォルトのオプションです。exec_command(): リモート サーバー上で Linux コマンドを実行するメソッドです。 open_sftp(): 現在の ssh セッションに基づいて sftp セッションを作成します。このメソッドは SFTPClient オブジェクトを返します。SFTPClient の一般的なメソッドの概要
from_transport(cls,t): 接続された SFTP クライアント チャネルを作成する put(localpath, Remotepath, callback=None,confirm= True) ): ローカル ファイルをサーバーにアップロードします。 パラメータ確認: stat() メソッドを呼び出してファイルのステータスを確認し、ls -l get(remotepath, localpath, callback=None) の結果を返すかどうか。: ファイルをサーバーからサーバーにダウンロードします。 local mkdir(): サーバー上にディレクトリを作成します。 delete(): サーバー上のディレクトリを削除します。 rename(): サーバー上のディレクトリの名前を変更します。 stat(): サーバーのファイル状態を表示します。 listdir(): サーバー上のファイルを一覧表示します。サーバーディレクトリ以上がPythonで自動運用保守を実装する方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ホットAIツール

Undresser.AI Undress
リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover
写真から衣服を削除するオンライン AI ツール。

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

AI Hentai Generator
AIヘンタイを無料で生成します。

人気の記事

ホットツール

メモ帳++7.3.1
使いやすく無料のコードエディター

SublimeText3 中国語版
中国語版、とても使いやすい

ゼンドスタジオ 13.0.1
強力な PHP 統合開発環境

ドリームウィーバー CS6
ビジュアル Web 開発ツール

SublimeText3 Mac版
神レベルのコード編集ソフト(SublimeText3)

ホットトピック









PHPとPythonにはそれぞれ独自の利点があり、プロジェクトの要件に従って選択します。 1.PHPは、特にWebサイトの迅速な開発とメンテナンスに適しています。 2。Pythonは、データサイエンス、機械学習、人工知能に適しており、簡潔な構文を備えており、初心者に適しています。

PythonはゲームとGUI開発に優れています。 1)ゲーム開発は、2Dゲームの作成に適した図面、オーディオ、その他の機能を提供し、Pygameを使用します。 2)GUI開発は、TKINTERまたはPYQTを選択できます。 TKINTERはシンプルで使いやすく、PYQTは豊富な機能を備えており、専門能力開発に適しています。

DebianシステムのReadDir関数は、ディレクトリコンテンツの読み取りに使用されるシステムコールであり、Cプログラミングでよく使用されます。この記事では、ReadDirを他のツールと統合して機能を強化する方法について説明します。方法1:C言語プログラムを最初にパイプラインと組み合わせて、cプログラムを作成してreaddir関数を呼び出して結果をinclude#include#include inctargc、char*argv []){dir*dir; structdireant*entry; if(argc!= 2){(argc!= 2){

限られた時間でPythonの学習効率を最大化するには、PythonのDateTime、時間、およびスケジュールモジュールを使用できます。 1. DateTimeモジュールは、学習時間を記録および計画するために使用されます。 2。時間モジュールは、勉強と休息の時間を設定するのに役立ちます。 3.スケジュールモジュールは、毎週の学習タスクを自動的に配置します。

この記事では、DebianシステムでNGINXSSL証明書を更新する方法について説明します。ステップ1:最初にCERTBOTをインストールして、システムがCERTBOTおよびPython3-Certbot-Nginxパッケージがインストールされていることを確認してください。インストールされていない場合は、次のコマンドを実行してください。sudoapt-getupdatesudoapt-getinstolcallcertbotthon3-certbot-nginxステップ2:certbotコマンドを取得して構成してlet'sencrypt証明書を取得し、let'sencryptコマンドを取得し、nginx:sudocertbot - nginxを構成します。

DebianでGitLabプラグインを開発するには、特定の手順と知識が必要です。このプロセスを始めるのに役立つ基本的なガイドを以下に示します。最初にgitlabをインストールすると、debianシステムにgitlabをインストールする必要があります。 GitLabの公式インストールマニュアルを参照できます。 API統合を実行する前に、APIアクセストークンを取得すると、GitLabのAPIアクセストークンを最初に取得する必要があります。 gitlabダッシュボードを開き、ユーザー設定で「アクセストーケン」オプションを見つけ、新しいアクセストークンを生成します。生成されます

DebianシステムでHTTPSサーバーの構成には、必要なソフトウェアのインストール、SSL証明書の生成、SSL証明書を使用するWebサーバー(ApacheやNginxなど)の構成など、いくつかのステップが含まれます。 Apachewebサーバーを使用していると仮定して、基本的なガイドです。 1.最初に必要なソフトウェアをインストールし、システムが最新であることを確認し、ApacheとOpenSSL:sudoaptupdatesudoaptupgraysudoaptinstaをインストールしてください

アパッチはインターネットの背後にあるヒーローです。それはWebサーバーであるだけでなく、膨大なトラフィックをサポートし、動的なコンテンツを提供する強力なプラットフォームでもあります。モジュラー設計を通じて非常に高い柔軟性を提供し、必要に応じてさまざまな機能を拡張できるようにします。ただし、モジュール性は、慎重な管理を必要とする構成とパフォーマンスの課題も提示します。 Apacheは、高度にカスタマイズ可能で複雑なニーズを満たす必要があるサーバーシナリオに適しています。
