QuickStart

For this quickstart, you will locally run the components of Hippo, create a hello world application, and then run it on Hippo. While you would not normally run local Hippo or Bindle services, this allows you to understand Hippo’s architecture and try it out before public services are available.

Prerequisites

  • Node.js installed with npm.
  • WASI compatible programming language installed, either AssemblyScript, C, Rust, or Swift.
  • PowerShell v6+, if using Windows.
  • Git installed. This is a temporary development dependency until Hippo and WAGI are publishing releases.
  • .NET 5. This is temporary development dependency until Hippo is publishing releases.
  • Rust. This is a temporary development dependency until WAGI is publishing releases.
  • POSIX developer environment such as linux, macos or WSL, with developer tools such as make, bash, curl, etc installed. This is a temporary development dependency until WAGI is publishing releases.

Concepts

For this quickstart, the main concepts that you will use include:

  • WebAssembly

    A binary containing your application which has been compiled to byte code understood by WebAssembly runtimes. Normally your application may be compiled so that it runs natively on an operating system and architecture, such as linux/amd64. Applications must be compiled for wasm+WASI in order to be runnable by Hippo.

    Not familiar with WebAssembly? Take a quick tour of WebAssembly in a Hurry to get up to speed.

  • Bindle

    A versioned package containing your WebAssembly module and supporting files.

  • Hippo

    The platform that serves WebAssembly modules.

Tasks

  1. Run a Bindle Server
  2. Install WAGI
  3. Run a Hippo Server
  4. Create a WebAssembly application
  5. Publish the application to Hippo

Run a Bindle Server

First, set up a local installation of Bindle Server. This is where you will publish revisions of your application.

  1. Download the latest release of bindle for your operating system. Extract the bindle and bindle-server binaries and move them to a directory that is in your PATH.

    linux

    curl -sL -o /tmp/bindle-v0.3.1-linux-amd64.tar.gz https://bindle.blob.core.windows.net/releases/bindle-v0.3.1-linux-amd64.tar.gz
    mkdir -p /tmp/bindle-v0.3.1-linux-amd64
    tar -C /tmp/bindle-v0.3.1-linux-amd64 -xzf /tmp/bindle-v0.3.1-linux-amd64.tar.gz
    mv /tmp/bindle-v0.3.1-linux-amd64/bindle* /usr/local/bin/
    

    macos

    curl -sL -o /tmp/bindle-v0.3.1-macos-amd64.tar.gz https://bindle.blob.core.windows.net/releases/bindle-v0.3.1-macos-amd64.tar.gz
    mkdir -p /tmp/bindle-v0.3.1-macos-amd64
    tar -C /tmp/bindle-v0.3.1-macos-amd64 -xzf /tmp/bindle-v0.3.1-macos-amd64.tar.gz
    mv /tmp/bindle-v0.3.1-macos-amd64/bindle* /usr/local/bin/
    

    powershell

    (New-Object System.Net.WebClient).DownloadFile("https://bindle.blob.core.windows.net/releases/bindle-v0.3.1-windows-amd64.tar.gz", "$env:TEMP\bindle-v0.3.1-windows-amd64.tar.gz")
    mkdir -force -path $env:TEMP\bindle-v0.3.1-windows-amd64
    tar -C $env:TEMP\bindle-v0.3.1-windows-amd64 -xzf $env:TEMP\bindle-v0.3.1-windows-amd64.tar.gz
    mkdir -force -path $env:USERPROFILE\bin
    mv -force $env:TEMP\bindle-v0.3.1-windows-amd64\bindle* $env:USERPROFILE\bin\
    $env:PATH+=";$env:USERPROFILE\bin"
    

    In order to persist the changes to your Windows PATH environment variable, create a PowerShell Profile if you do not have one, and then add $env:PATH+=";$env:USERPROFILE\bin" to it.

  2. Run the Bindle server in the background, using the default configuration which listens on localhost port 8080.

    bindle-server &
    
  3. Set the BINDLE_SERVER_URL environment variable, used by the remainder of this quickstart for bindle, hippofactory and hippo server.

    posix

    export BINDLE_SERVER_URL="http://localhost:8080/v1"
    

    powershell

    $env:BINDLE_SERVER_URL="http://localhost:8080/v1"
    
  4. Verify that your Bindle server is available by listing all registered bindles:

    bindle search
    

    You should see an empty set of results without any errors.

    query = ""
    strict = true
    offset = 0
    limit = 50
    total = 0
    more = false
    yanked = false
    invoices = []
    

Now that you have a Bindle server up and running, the next step is to run a local Hippo server.

Install WAGI

Instructions pending published releases of WAGI. For now you must install WAGI from source.

  1. Clone the WAGI repository to your local development environment.

    git clone https://github.com/deislabs/wagi.git
    
  2. Compile the wagi binary.

    cd wagi
    make build
    
  3. Move the wagi binary to a location in your PATH.

    posix

    mv target/release/wagi /usr/local/bin
    

    powershell

    mv -force target\release\wagi.exe $env:USERPROFILE\bin\
    $env:PATH+=";$env:USERPROFILE/bin"
    

Run a Hippo Server

Instructions pending published releases of Hippo. For now you must run Hippo from source.

  1. Clone the Hippo repository to your local development environment.

    git clone https://github.com/deislabs/hippo.git
    
  2. Restore Hippo’s dependencies.

    dotnet restore
    cd Hippo
    npm run build
    
  3. Run Hippo:

    dotnet run
    
  4. Open your web browser to https://localhost:5001 and accept the self-signed certificate to view the Hippo control panel.

    hippo control panel - you are not logged in

  5. Click login from the left hand navigation and log in with the username admin and the password Passw0rd!.

    hippo control panel - login page

  6. Once you are logged in, you should be redirected to the Applications page, displaying a preseeded helloworld application.

    hippo control panel - application page with helloworld preseeded

Troubleshooting

  • npm run build fails with error gyp: No Xcode or CLT version detected

    This is a problem with MacOS Catalina and higher. Follow the xcode troubleshooting steps from this article to address it.

  • The Hippo control panel CSS isn’t rendering properly

    Repeat the npm run build command in the Hippo directory in the hippo repository. Check the logs for any errors (such as the one above in the previous troubleshooting step) and address them.

Install yo-wasm

Instructions pending the v0.4 release of yo-wasm. For now you must install yo-wasm from source.

We have created a tool, [yo-wasm], that scaffolds a new application in either AssemblyScript, C, Rust, or Swift that is ready to be compiles to WebAssembly, and pushed to Hippo.

  1. Open a new terminal window so that you can continue the quickstart while the Hippo server runs in the other session.

  2. Install [Yeoman] if it is not already installed.

    npm install -g yo
    
  3. Clone the yo-wasm repository.

    git clone https://github.com/deislabs/yo-wasm.git
    
  4. Install the yo-wasm module from source.

    cd yo-wasm
    npm install
    npm run compile
    npm link
    

Create a WebAssembly application

Use yo-wasm to generate your application.

  1. Define the following environment variables. These are used by yo-wasm, and hippofactory.

    posix

    export HIPPO_SERVICE_URL=HIPPO_SERVICE_URL=https://localhost:5001
    export BINDLE_SERVER_URL=http://localhost:8080/v1/
    export HIPPO_USERNAME=admin
    export HIPPO_PASSWORD=Passw0rd!
    

    powershell

    $env:HIPPO_SERVICE_URL="HIPPO_SERVICE_URL=https://localhost:5001"
    $env:BINDLE_SERVER_URL="http://localhost:8080/v1/"
    $env:HIPPO_USERNAME="admin"
    $env:HIPPO_PASSWORD="Passw0rd!"
    
  2. Create a new directory for your application.

    mkdir quickstart
    cd quickstart
    
  3. Disable strict SSL certificate checking because our Hippo server is using a self-signed certificate.

    posix

    export GLOBAL_AGENT_FORCE_GLOBAL_AGENT=false
    

    powershell

    $env:GLOBAL_AGENT_FORCE_GLOBAL_AGENT=false
    
  4. Run yo wasm and answer the interactive questions to generate your application.

    • Accept the default name.
      ? What is the name of the WASM module? (quickstart)
      
    • Select “Web service or application using WAGI”.
      ? What type of application is the module? (Use arrow keys)
        Console or batch job
      ❯ Web service or application using WAGI
      
    • Change the author name to your username, without using any spaces.
      ? What is the name of the author? (Your Name) myname
      
    • Select “Rust” for the programming language.
      ? What programming language will you write the module in? (Use arrow keys)
        AssemblyScript
        C
      ❯ Rust
        Swift
      
    • Select “Hippo” for the publish destination.
      ? Where do you plan to publish the module? (Use arrow keys)
      ❯ Azure Container Registry
        Hippo
        I don't want to publish the module
      
    • Use “https://localhost:5001” for the Hippo Service URL. This defaults to the HIPPO_SERVICE_URL environment variable which should be set.
      ? What is the URL of your Hippo service? (https://localhost:5001)
      
    • Use “http://localhost:8080/v1/” for the Bindle Server URL. This defaults to the BINDLE_SERVER_URL environment variable should should be set.
      ? What is the URL of your Hippo's Bindle server? (http://localhost:8080/v1/)
      
    • Select the default Y (yes) to register the application with Hippo.
      ? Would you like to create a new Hippo application for this project? (Y/n)
      
    • Accept teh default storage ID for the application.
      ? What storage ID (bindle name) would you like for your Hippo app? (myname/quickstart)
      
    • Accept the default Hippo user name “admin”. This defaults to the HIPPO_USERNAME environment variable which should be set.
      ? Enter your Hippo user name (will become app owner) (admin)
      
    • Accept the default Hippo password, which is hidden and not displayed. This defaults to the HIPPO_PASSWORD environment variable which should be set.
      ? Enter your Hippo password [hidden]
      
  5. Compile and run your application locally to try it out. It should print “Hello, world!”.

    cargo run
    
  6. Open your web browser to the Hippo control panel at https://localhost:5001 and then navigate to Applications. You should see a second application named quickstart in the list of registered applications.

    hippo control panel - application page with the quickstart app

Troubleshooting

  • The yo wasm command fails with “connect ECONNREFUSED 1127.0.0.1:80”

    Setting up your Hippo application...
    Setup failed! You will need to create the Hippo app manually.
    The error was: Error: connect ECONNREFUSED 127.0.0.1:80
    

    This error indicates that either your Bindle Server URL or Hippo Service URL were invalid URLs and could not be parsed. Verify that you have BINDLE_SERVER_URL and HIPPO_SERVICE_URL set correctly, and then re-run yo wasm.

  • The yo wasm command fails with “unable to verify the first certificate”

    Setting up your Hippo application...
    Setup failed! You will need to create the Hippo app manually.
    The error was: Error: unable to verify the first certificate
    

    If you see the above message from yo-wasm, you need to disable strict SSL certificate checking by setting the GLOBAL_AGENT_FORCE_GLOBAL_AGENT environment variable to false, and hen re-run yo wasm.

Publish the application to Hippo

At this point, your application is only registered with Hippo, but it is not yet being served. You need to first compile the application, package it into a bindle, and then push it to a Bindle server. Then Hippo will note the new version and deploy it.

  1. Compile your application to WebAssembly with WASI support.

    cargo build --target wasm32-wasi --release
    
  2. yo-wasm generated a file named HIPPOFACTS, which defines how to package your application into a bindle, and includes information for the WAGI runtime on how to serve it.

    [bindle]
    name = "myname/quickstart"
    version = "0.1.0"
    authors = ["myname"]
    
    [[handler]]
    route = "/"
    name = "target/wasm32-wasi/release/quickstart.wasm"
    

    The quickstart application defines a single endpoint that is handled by the WebAssembly module. Learn more about how to Configure an application with HIPPOFACTS.

  3. Use hippofactory to package your application into a bindle and push it to your local Bindle server. This command relies upon HIPPO_SERVICE_URL, HIPPO_USERNAME, and HIPPO_PASSWORD.

    hippofactory -k -v production HIPPOFACTS
    

    You should see the following output:

    pushed: myname/quickstart/0.1.0
    
  4. In the original terminal window where you started the Hippo server, look at the logs, and look for the line that says where you newly deployed application is running.

    INFO  wagi] => Starting server on 127.0.0.1:32768
    
  5. Open your web browser and navigate to http://127.0.0.1:32768. You should see “Hello, world!” printed on the page.

Troubleshooting

  • hippofactory fails with the error “No such file or directory”

    This can occur when you try to publish before the application is compiled to wasm+WASI. Check that all files referenced by your HIPPOFACTS file, such as the handler for target/wasm32-wasi/release/quickstart.wasm, exits.

Summary

Let’s stop and consider what we have seen, and how it demonstrates the potential of Hippo. We do not expect developers to run Hippo or Bindle themselves, it was necessary only to see it in action before public services are available. So putting those pieces aside for a moment, what does the developer experience look like with Hippo?

  1. Scaffold an application for WebAssembly in a number of languages with the yo wasm.
  2. Test and iterate locally on your application using standard tools, targeting your development machine’s architecture, not wasm. Essentially, develop your application just as you do today.
  3. Register your application with a Hippo server when you are ready to share it.
  4. Publish new versions of your application to a Bindle server, triggering Hippo deployments automatically.

You focus on your application, and Hippo takes care of hosting it.

Next Steps