npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2024 – Pkg Stats / Ryan Hefner

gpueater

v1.5.3

Published

GPUEater API console for nodejs.

Downloads

5

Readme

GPUEater API Console

Getting Started

GPUEater is a cloud computing service focusing on Machine Learning and Deep Learning. Now, AMD Radeon GPUs and NVIDIA Quadro GPUs are available.

This document is intended to describe how to set up this API and how to control your instances through this API.

Before getting started, register your account on GPUEater. https://www.gpueater.com/


AMD RadeonGPU ROCm-TensorFlow information (https://github.com/aieater/rocm_tensorflow_info)

  • How to setup Radeon GPU Driver (ROCm) on Ubuntu16.04/18.04
  • How to setup ROCm-Tensorflow on Ubuntu16.04/18.04
    • ROCm(AMDGPU)-TensorFlow 1.8 Python2.7/Python3.5 + UbuntuOS
    • ROCm(AMDGPU)-TensorFlow 1.10.0-x Python2.7/Python3.5/Python3.6 + UbuntuOS
    • CPU-TensorFlow 1.10.1 Python3.7 + MacOSX
  • Lightweight ROCm-TensorFlow docker
    • ROCm-TensorFlow on GPUEater
    • ROCm-TensorFlow1.8 docker

ROCm information URL : https://github.com/aieater/rocm_tensorflow_info


Prerequisites

  1. NodeJS 8.x is required to run GPUEater API console.
  2. Create a JSON file in accordance with the following instruction.

At first, open your account page(https://www.gpueater.com/console/account) and copy your access_token. The next, create a JSON file on ~/.eater

{
        "gpueater": {
                "access_token":"[YourAccessToken]",
                "secret_token":"[YourSecretToken]"
        }
}

or

{
        "gpueater": {
                "email":"[YourEmail]",
                "password":"[YourPassword]"
        }
}
  • At this time, permission control for each token is not available. Still in development.

Installing GPUEater API on your system

Install GPUEater API

npm install gpueater

Run GPUEater API

Before launching an instance, you need to decide product, ssh key, OS image. Get each info with the following APIs.

Get available on-demand product list

This API returns current available on-demand products.

const g = require('gpueater');

g.ondemand_list((e,res)=>{
    if (e) console.error(e);
    else {
        console.dir(res);
    }
});

Get registered ssh key list

This API returns your registered ssh keys.

const g = require('gpueater');

g.ssh_key_list((e,res)=>{
    if (e) console.error(e);
    else {
        console.dir(res);
    }
});

Get OS image list

This API returns available OS images.

const g = require('gpueater');

g.image_list((e,res)=>{
    if (e) console.error(e);
    else {
        console.dir(res);
    }
});

Instance launch

Specify product, OS image, and ssh_key for instance launching.

const g = require('gpueater');

g.ondemand_list((e,res)=>{
    if (e) console.error(e);
    else {
        let image = res.find_image('Ubuntu16.04 x64');
        let ssh_key = res.find_ssh_key('master_key');
        let product = res.find_product('a1.vegafe');

        if (!image) { console.error(`No available image`);return;}
        if (!ssh_key) { console.error(`No available ssh-key`);return;}
        if (!product) { console.error(`No available product`);return;}

        let form = {
            product_id:product.id,
            image:image.alias,
            ssh_key_id:ssh_key.id,
            tag:`HappyGPUProgramming`,
        };
        g.launch_ondemand_instance(form,(e,res)=>{
            if (e) console.error(e);
            else {
                console.dir(res);
            }
        });
    }
});

In the event, the request has succeeded, then the API returns the following empty data. {}

In the event, errors occurred during the instance instantiation process, then the API returns details about the error.

Launched instance list

This API returns your launched instance info.

const g = require('gpueater');

g.instance_list((e,res)=>{
    if (e) console.error(e);
    else {
        console.dir(res);
    }
});

Terminate instance

Before terminating an instance, get instance info through Launched instance list API. Also, you can directly specify instance_id and machine_resource_id instead of specifing your tag name.

const g = require('gpueater');

g.instance_list((e,res)=>{
    if (e) console.error(e);
    else {
        for (let ins of res) {
            if (ins.tag == 'HappyGPUProgramming') {
                console.dir(ins);
                g.terminate_instance(ins,(e,res)=>{
                    if (e) console.error(e);
                    else {
                        console.dir(res);
                    }
                });
            }
        }
    }
});

API list

const g = require('gpueater');

// func is function(error, response) style.

g.image_list((error,res)=>{
  if (error) console.error(error);
  else {
    console.dir(res);
  }
});
Image

| Version | Function | Required | Description | | ---- | ---- | ---- | ---- | | v0.8 | image_list() | | Listing all OS images | | v1.5 | registered_image_list() | | Listing all user defined OS images | | v1.5 | create_image(form) | instance_id, machine_resource_id | Adding an user defined OS image | | v1.5 | delete_image(form) | image | Deleting an OS image | | v2.0 | snapshot_instance(form) | instance_id, machine_resource_id | Creating a snapshot | | v2.0 | delete_snapshot(form) | instance_id, machine_resource_id | Deleting a snapshot | | v2.5 | import_image(form) | url | Registering an user defined OS image on the internet |

SSH Key

| Version | Function | Required | Description | | ---- | ---- | ---- | ---- | | v0.8 | ssh_key_list(func) | | Listing all ssh keys | | v1.0 | generate_ssh_key(func) | | Generating Key Pair | | v1.0 | register_ssh_key(form, func) | name, public_key | Registering an SSH key | | v1.0 | delete_ssh_key(form, func) | id | Deleting an SSH key |

const g = require('gpueater');
const fs = require('fs');
const os = require('os');
const path = require('path');
const HOME = os.homedir();

g.generate_ssh_key((error,res)=>{
  if (error) console.error(error);
  else {
    let fpath = path.join(HOME,'.ssh','nodejs_ssh_key.pem');
    fs.writeFileSync(fpath,res.private_key);
    g.register_ssh_key({name:"nodejs_ssh_key", public_key:res.public_key},(error, res)=>{
      if (error) console.error(error);
      else {
        console.dir(res);
      }
    });
  }
});

Instance

| Version | Function | Required | Description | | ---- | ---- | ---- | ---- | | v0.8 | ondemand_list() | | Listing all on-demand instances | | v2.0 | subscription_list() | | Listing all subscription instances | | v0.8 | launch_ondemand_instance(form) | product_id, image, ssh_key_id | Launch an on-demand instance | | v2.0 | launch_subcription_instance(form) | subscription_id, image, ssh_key_id | Launch a subscription instance | | v0.8 | instance_list() | | Listing all launched instances | | v1.0 | change_instance_tag(form) | instance_id, tag | Changing an instance tag | | v1.0 | start_instance(form) | instance_id, machine_resource_id | Starting an instance. If the instance is already RUNNING, nothing is going to happen | | v1.0 | ~~stop_instance(form)~~[Deprecated] | instance_id, machine_resource_id | Stopping an instance. If the instance is already STOPPED, nothing is going to happen | | v1.0 | restart_instance(form) | instance_id, machine_resource_id | Restarting an instance | | v0.8 | terminate_instance(form) | instance_id, machine_resource_id | Terminating an instance | | v1.0 | emergency_restart_instance(form) | instance_id, machine_resource_id | Restarting an instance emergently when an instance is hung up |

The "machine_resource_id" is including an instance object. See the following sample code.

Example:

const g = require('gpueater');

g.instance_list((error,res)=>{
  if (error) console.error(error);
  else {
	let instance = res[0]; // instance object has instance_id, and machine_resource_id.
    g.terminate_instance(instance, (error, res)=>{
      if (error) console.error(error);
      else {
        console.dir(res);
      }
    });
  }
});
Network

| Version | Function | Required | Description | | ---- | ---- | ---- | ---- | | v1.0 | port_list(form) | instance_id | Listing all ports | | v1.0 | open_port(form) | instance_id, connection_id, port | Opening a port for inbound traffic | | v1.0 | close_port(form) | instance_id, connection_id, port | Closing a port for inbound traffic | | v1.0 | renew_ipv4(form) | instance_id | Getting a new IPv4 address | | v1.0 | network_description(form) | instance_id | This API reports current network status |

Storage

| Version | Function | Required | Description | | ---- | ---- | ---- | ---- | | v2.0 | create_volume(form) | size | Creating an extended volume | | v2.0 | attach_volume(form) | volume_id, instance_id | Attaching an extended volume to an instance | | v2.0 | delete_volume(form) | volume_id | Deleting an extended volume | | v2.0 | transfer_volume(form) | volume_id, region_id | Transferring an extended volume to another region |

Subscription

| Version | Function | Required | Description | | ---- | ---- | ---- | ---- | | v2.0 | subscription_instance_list() | | Listing all subscription instances | | v2.0 | subscription_storage_list() | | Listing all storage volumes | | v2.0 | subscription_network_list() | | Listing all subscription networks | | v2.0 | subscribe_instance(form) | subscription_id | Subscribing a subscription instance | | v2.0 | unsubscribe_instance(form) | subscription_id | Canceling a subscription instance | | v2.0 | subscribe_storage(form) | subscription_id | Subscribing a storage volume | | v2.0 | unsubscribe_storage(form) | subscription_id | Canceling a storage volume | | v2.0 | subscribe_network(form) | subscription_id | Subscribing a network product | | v2.0 | unsubscribe_network(form) | subscription_id | Canceling a network product |

Special

| Version | Function | Required | Description | | ---- | ---- | ---- | ---- | | v2.5 | live_migration(form) | product_id, region_id, connection_id | Moving a running instance to another physical machine without termination | | v2.5 | cancel_transaction(form) | transaction_id | Canceling a transaction | | v2.5 | peak_transaction(form) | transaction_id | checking a current transaction status |

Payment

| Version | Function | Required | Description | | ---- | ---- | ---- | ---- | | v1.0 | invoice_list(func) | | Listing invoices for on-demand instances | | v2.0 | subscription_invoice_list(func) | | Listing invoices for subscription instances | | v2.5 | make_invoice(form, func) | invoice_id | Obtain a pdf invoice |

Extensions

| Version | Function | Required | Description | | ---- | ---- | ---- | ---- | | v1.7 | copy_file(form, func) | action("get"or"put"), src, dst | Copying a file. "get" obtains a file from a remote host to your local host, and "put" is the opposite. "src" is a source file path, and "dst" is a destination file path | | v1.7 | delete_file(form, func) | src, recursive | Deleting a remote file | | v1.7 | make_directory(form, func) | dst | Making a directory in a remote host | | v1.7 | file_list(form, func) | src | Listing all files in a remote host | | v1.7 | synchronize_files(form, func) | action, src, dst | This API is similar to the "rsync" | | v1.7 | login_instance(form, func) | instance_id | Logging in a specific instance through the SSH | | v1.7 | tunnel(form, func) | instance_id, port | This API enables a port tunneling between your local and a remote host |

License

This project is licensed under the MIT License - see the LICENSE.md file for details