目錄
什麼是數位海洋?
數位海洋 API
設定存取金鑰
我們的控制台應用程式
配置 API 存取
取得 Droplet
获取图像
自动化快照
下一步是什么?
相关链接
首頁 後端開發 php教程 使用 Digital Ocean API 管理雲端實例

使用 Digital Ocean API 管理雲端實例

Sep 03, 2023 pm 01:29 PM

使用 Digital Ocean API 管理云实例

什麼是數位海洋?

Digital Ocean 是成長最快的網路主機之一,部分原因在於其基於 SSD 的快速伺服器和每月 5 美元的廉價託管計劃。在 Digital Ocean 上啟動實例進行測試或長期使用是快速、簡單且經濟實惠的。

在 Digital Ocean 建立用於轉售的應用程式映像中,我向您介紹如何啟動 WordPress(或其他應用程式)實例並為客戶重複複製它。在本教程中,我將指導您使用 Digital Ocean API 以程式設計方式管理我們的實例(也稱為 Droplet),並自動執行常見任務。我還將提供一個範例程式碼庫,用於運行在 Yii Framework for PHP 中編寫的非常基本的 API 操作;您可以在 Github 上取得程式碼。

數位海洋 API

Digital Ocean API 可讓您使用 HTTP 請求以簡單的程式設計方式管理 Droplet 和資源。您在 Digital Ocean 控制面板中熟悉的所有功能也可以透過 API 取得,讓您能夠根據您的情況需求編寫複雜操作的腳本。

在本教學中,我們將把開發人員 Antoine Corcy 的 Digital Ocean V2 PHP API 函式庫整合到基於 Yii 的控制台應用程式中。您不需要了解 Yii 即可使用該應用程序,但您可以在此處了解更多資訊:Yii 框架簡介。

#Digital Ocean API 透過 OAuth 驗證您的帳戶,由近十幾個進階區域組成:

  • 帳戶:提供有關您的 Digital Ocean 帳戶的基本資訊。
  • 操作:您帳戶中 Droplet 的操作歷史日誌。
  • 網域名稱和網域名稱記錄:讓您可以管理帳戶中 Droplet 上使用的網域名稱以及與其關聯的 DNS 記錄。
  • Droplet 和 Droplet 操作:允許您為 Droplet 建立、關閉、重新啟動、快照等。
  • 映像與映像操作:允許您列舉並管理您帳戶中為 Droplet 拍攝的快照影像。
  • SSH 金鑰:允許您在建立 Droplet 時註冊要安裝的 SSH 金鑰,這樣就不需要密碼安全性。
  • 區域:列舉可以在其中創建數位海洋水滴的地理區域。
  • 尺寸:枚舉創建液滴時可以使用的液滴尺寸。

現在您已經了解了一些 API,讓我們深入了解我們自己的應用程式。

設定存取金鑰

為了使用 API,您需要為您的帳戶啟動個人存取權杖。登入您的帳戶並造訪設定應用程式頁面:https://cloud.digitalocean.com/settings/applications。點選產生新令牌,如下圖:

使用 Digital Ocean API 管理云实例

記下下面您的訪問令牌 - Digital Ocean 只會向您顯示一次:

使用 Digital Ocean API 管理云实例

現在,讓我們轉到範例控制台應用程式。

我們的控制台應用程式

在本教程中,我們將探索我建立的一個小型控制台應用程序,該應用程式執行一些與管理 Droplet 相關的任務。您可以從 Tuts GitHub 儲存庫自行安裝應用程序,並自訂或擴充它以實現您想要的其他 API 功能。我已經在我的網站上發布了控制台應用程式的詳細安裝指南。您也可以瀏覽我的 Digital Ocean 應用程式通用安裝指南。

配置 API 存取

我們再次使用 Antoine Corcy 的 Digital Ocean V2 PHP API 函式庫來存取 API。

我們建立了一個名為 Ocean.php 的元件,它充當使用他的函式庫的模型。它位於 /app/protected/components/Ocean.php

Yii 從 Ocean.ini 檔案載入您的存取權杖(如《數位海洋控制台應用程式安裝指南》所述),並實例化 digitalOcean API 物件。

<?php

use DigitalOceanV2\Adapter\BuzzAdapter;
use DigitalOceanV2\DigitalOceanV2;

class Ocean extends CComponent
{
  private $adapter;
  private $digitalOcean;
  
   function __construct() {     
     // create an adapter with your access token which can be
     // generated at https://cloud.digitalocean.com/settings/applications
     $this->adapter = new BuzzAdapter(Yii::app()->params['ocean']['access_key']);
     // create a digital ocean object with the previous adapter
     $this->digitalOcean = new DigitalOceanV2($this->adapter);
  }
登入後複製

取得 Droplet

使用 Digital Ocean API 管理云实例

現在,讓我們來取得活躍 Droplet 的清單。在 /app/protected/models/Droplet.php 中,我們的 sync 方法呼叫 Ocean 元件並取得 Droplet:

    public function sync() {
    $ocean = new Ocean();
    $droplets = $ocean->getDroplets();
    foreach ($droplets as $d) {
      $droplet_id = $this->add($d);
    }	      
  }
登入後複製

Ocean getDroplets 方法如下:

  public function getDroplets() {
    // return the action api
    $action  = $this->digitalOcean->droplet();
    // return a collection of Action entity
    $actions = $action->getAll();    
    return $actions;
  }
登入後複製

注意:基本控制台應用程式僅對我們的 Droplet 清單進行單向下載同步。您可以自行實現更多功能,包括刪除已在雲端刪除的水滴。

這是我們的 Droplet 模型的 add 函數。如果 Droplet 已經存在,我們只需更新記錄:

public function add($droplet) {
     $d = Droplet::model()->findByAttributes(array('droplet_id'=>$droplet->id));
    if (empty($d)) {
      $d = new Droplet;
    }
    $d->user_id = Yii::app()->user->id;
      $d->droplet_id = $droplet->id;
      $d->name = $droplet->name;
      $d->vcpus = $droplet->vcpus;
      $d->memory = $droplet->memory;
      $d->disk = $droplet->disk;
      $d->status = $droplet->status;
      $d->active =1;
     $d->created_at = $d->created_at;
     $d->modified_at =new CDbExpression('NOW()');          
     $d->save();
    return $d->id;
   }
登入後複製

如果您希望扩展模型的功能,Digital Ocean 提供了各种 Droplet API 操作,Corcy 在此列出了清晰的示例。

获取图像

接下来,我们将使用 API 来获取当前图像的列表。映像是快照,本质上是备份,是在给定时间点从服务器实例获取的。

使用 Digital Ocean API 管理云实例

我们的 Snapshot.php 模型有一个 sync 操作,它会请求图像列表并添加将它们分别写入数据库:

   public function sync() {
     $ocean = new Ocean();
     $snapshots = $ocean->getSnapshots();
     foreach ($snapshots as $i) {
       $image_id = $this->add($i);
       if ($image_id!==false) {
         echo $image_id;lb();
         pp($i);        
       }
     }          
   }
登入後複製

这是海洋组件 getSnapshots 代码:

  public function getSnapshots() {
    // return the action api
    $action  = $this->digitalOcean->image();
    // return a collection of Action entity
    $actions = $action->getAll();    
    return $actions;
  }
登入後複製

这是快照模型 add 代码 - 我们忽略 Digital Ocean 的库存应用程序映像,这些映像被区分为公共:

   public function add($snapshot) {
      $i = Snapshot::model()->findByAttributes(array('image_id'=>$snapshot->id));
     if (empty($i)) {
       $i = new Snapshot;
       $i->created_at =new CDbExpression('NOW()');          
     }
     if (isset($snapshot->public) and $snapshot->public ==1) {
       return false; // no need to save public images right now
     } else 
       $i->user_id = Yii::app()->user->id;       
       $i->image_id = $snapshot->id;
       $i->name = $snapshot->name;
       $i->region = $snapshot->regions[0];
       $i->active =1;
       $i->modified_at =new CDbExpression('NOW()');          
      $i->save();
    return $i->id;
    }	
登入後複製

自动化快照

正如我们在构建要在 Digital Ocean 进行转售的应用映像中所讨论的那样,自动创建可传输给客户和顾客的快照非常有用。遗憾的是,目前无法通过引用克隆或传输图像;每次您将快照转移到另一个帐户时,它就会消失。

由于 Digital Ocean 要求您将图像实例化为 Droplet,并在拍摄新快照之前将其关闭,因此重复创建快照是一个耗时的手动过程。 Digital Ocean 在拍摄快照后再次启动水滴并没有什么帮助,这只会减慢进程。

由于 API 在其他操作挂起时不接受请求,因此我们必须构建一个表来跟踪后台操作并使用 cron 作业来重复断电、快照操作。其工作原理如下:

访问图像页面,然后单击您想要克隆的快照的查看。然后,单击右侧的复制菜单选项。

使用 Digital Ocean API 管理云实例

这将创建一个 Droplet 并使用此 image_iddroplet_idend_stage 是一个常量,您可以设置它来指示要创建的重复项的数量。

使用 Digital Ocean API 管理云实例

这是 Snapshot 模型的 replicate() 方法:

    public function replicate($id) {
        // look up image_id
      $snapshot = Snapshot::model()->findByAttributes(array('id'=>$id));
  	  // create the droplet 
      $ocean = new Ocean();
      $droplet_id = $ocean->launch_droplet($snapshot->name,$snapshot->region,$snapshot->image_id);
  	  // add command to action table with droplet_id and image_id
      $a = new Action();
      $a->droplet_id = $droplet_id;
      $a->snapshot_id = $snapshot->image_id;
      $a->action = Action::ACTION_SNAPSHOT;
      $a->status = Action::STATUS_ACTIVE;
      $a->stage = 0;
    // user settable constant for number of replications to make
      $a->end_stage = Snapshot::NUMBER_REPLICATIONS;
      $a->last_checked = 0;
      $a->modified_at =new CDbExpression('NOW()');          
      $a->created_at =new CDbExpression('NOW()');          
      $a->save(); 
    }
登入後複製

cron 任务将 ping http://ocean.yourdomain.com/daemon/index 以定期处理操作表。任何未完成的逾期项目都将请求另一个快照。

这是 Action 模型的 process() 方法:

    public function process() {
	  set_time_limit(0);
	  // look for overdue actions	  
	  $todo = Action::model()->overdue()->findAllByAttributes(array('status'=>self::STATUS_ACTIVE));
	  foreach ($todo as $item) {
	    if ($item->action == self::ACTION_SNAPSHOT) {
          $result = Snapshot::model()->take($item->id);          
	    }
	  }
	}
登入後複製

快照过程将关闭 Droplet,暂停 20 秒等待 Droplet 关闭,并请求快照。

使用 Digital Ocean API 管理云实例

这是 Snapshot 模型的 take() 方法:

 public function take($action_id) {
    $result = false;
      $a = Action::model()->findByPk($action_id);
    $snapshot = Snapshot::model()->findByAttributes(array('image_id'=>$a->snapshot_id));
    $ocean = new Ocean();
    // attempt shutdown
    // take snapshot
    $result = $ocean->snapshot($a->stage,$a->droplet_id,$snapshot->name,$snapshot->region,$snapshot->image_id);
    // if snapshot was successful
    if ($result) {
      // increment stage
      $a->stage+=1;
      // if last snapshot replication complete, end action
      if ($a->stage >= $a->end_stage)  
        $a->status = Action::STATUS_COMPLETE;
    } 
	  // either way, update last_checked
    $a->last_checked = time();
    $a->save();              
	  return $result;
  }
登入後複製

以下是 Ocean 组件中用于实际进行 API 调用的代码:

public function snapshot($stage,$droplet_id,$name,$region,$image_id,$begin=1,$count=3,$size='512mb') {
    $no_sleep = false;
    $name = str_replace("_","-",$name);
    $droplet  = $this->digitalOcean->droplet();
      try {
        echo 'Shutting down '.$droplet_id;lb();
        $shutdown = $droplet->shutdown($droplet_id);
      } catch (Exception $e) {
          $err = $e->getMessage();
          echo 'Caught exception: ',  $e->getMessage(), "\n";
          if (stristr ( $err , 'already powered off')===false)
            return false;
          else
            $no_sleep = true;
      }
    if (!$no_sleep) {
      echo 'Sleep 20 seconds for power off...';lb();
      sleep(20);              
    }
    echo 'Take snapshot of '.$droplet_id.' named '.$name.'-copy-'.$stage;lb();
    try {
      $snapshot = $droplet->snapshot($droplet_id, $name.'-copy-'.$stage); 
    } catch (Exception $e) {
        echo 'Caught exception: ',  $e->getMessage(), "\n";
        return false;
    }
    // shutdown and snapshot successful
    return true;
  }
登入後複製

如果您访问 Digital Ocean 网站查看 Droplet,您将看到正在进行的操作:

使用 Digital Ocean API 管理云实例

如果快照成功,则返回Snapshot模型以递增阶段。当阶段复制完成后,操作完成。

您可以访问 Digital Ocean 网站的图像页面来查看复制的快照:

使用 Digital Ocean API 管理云实例

创建图像后,您可以手动删除 Droplet,或者您可以扩展代码以在 STATUS_COMPLETE 已达到。如果您不删除 Droplet,我们将向您收取费用。

请注意,目前 API 不提供将快照传输到电子邮件地址的功能,因此您需要继续通过网络界面手动执行此操作。

下一步是什么?

我希望您喜欢本教程,并发现 Digital Ocean 是您的工具和托管提供商组合中的一项有用服务。在下一个教程中,我们将探索 Digital Ocean DNS 服务。

请随时在下面发表您的问题和评论。您也可以通过 Twitter @reifman 联系我或直接给我发电子邮件。请关注我的 Tuts+ 讲师页面,查看本系列后续文章。

相关链接

  • 数字海洋 API
  • Digital Ocean V2 PHP API 库
  • 数字海洋控制台应用程序安装指南

以上是使用 Digital Ocean API 管理雲端實例的詳細內容。更多資訊請關注PHP中文網其他相關文章!

本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

在PHP API中說明JSON Web令牌(JWT)及其用例。 在PHP API中說明JSON Web令牌(JWT)及其用例。 Apr 05, 2025 am 12:04 AM

JWT是一種基於JSON的開放標準,用於在各方之間安全地傳輸信息,主要用於身份驗證和信息交換。 1.JWT由Header、Payload和Signature三部分組成。 2.JWT的工作原理包括生成JWT、驗證JWT和解析Payload三個步驟。 3.在PHP中使用JWT進行身份驗證時,可以生成和驗證JWT,並在高級用法中包含用戶角色和權限信息。 4.常見錯誤包括簽名驗證失敗、令牌過期和Payload過大,調試技巧包括使用調試工具和日誌記錄。 5.性能優化和最佳實踐包括使用合適的簽名算法、合理設置有效期、

會話如何劫持工作,如何在PHP中減輕它? 會話如何劫持工作,如何在PHP中減輕它? Apr 06, 2025 am 12:02 AM

會話劫持可以通過以下步驟實現:1.獲取會話ID,2.使用會話ID,3.保持會話活躍。在PHP中防範會話劫持的方法包括:1.使用session_regenerate_id()函數重新生成會話ID,2.通過數據庫存儲會話數據,3.確保所有會話數據通過HTTPS傳輸。

描述紮實的原則及其如何應用於PHP的開發。 描述紮實的原則及其如何應用於PHP的開發。 Apr 03, 2025 am 12:04 AM

SOLID原則在PHP開發中的應用包括:1.單一職責原則(SRP):每個類只負責一個功能。 2.開閉原則(OCP):通過擴展而非修改實現變化。 3.里氏替換原則(LSP):子類可替換基類而不影響程序正確性。 4.接口隔離原則(ISP):使用細粒度接口避免依賴不使用的方法。 5.依賴倒置原則(DIP):高低層次模塊都依賴於抽象,通過依賴注入實現。

在PHPStorm中如何進行CLI模式的調試? 在PHPStorm中如何進行CLI模式的調試? Apr 01, 2025 pm 02:57 PM

在PHPStorm中如何進行CLI模式的調試?在使用PHPStorm進行開發時,有時我們需要在命令行界面(CLI)模式下調試PHP�...

框架安全功能:防止漏洞。 框架安全功能:防止漏洞。 Mar 28, 2025 pm 05:11 PM

文章討論了框架中的基本安全功能,以防止漏洞,包括輸入驗證,身份驗證和常規更新。

如何在系統重啟後自動設置unixsocket的權限? 如何在系統重啟後自動設置unixsocket的權限? Mar 31, 2025 pm 11:54 PM

如何在系統重啟後自動設置unixsocket的權限每次系統重啟後,我們都需要執行以下命令來修改unixsocket的權限:sudo...

解釋PHP中的晚期靜態綁定(靜態::)。 解釋PHP中的晚期靜態綁定(靜態::)。 Apr 03, 2025 am 12:04 AM

靜態綁定(static::)在PHP中實現晚期靜態綁定(LSB),允許在靜態上下文中引用調用類而非定義類。 1)解析過程在運行時進行,2)在繼承關係中向上查找調用類,3)可能帶來性能開銷。

See all articles