Non-web workloads

When I try to run a non-http workload with the default Go buildpack by putting a line like this in my Procfile:

work: bin/subscriber

I’m getting this error from the kubernetes pod:

ERROR: failed to launch: determine start command: ││ process type web was not found

Which makes sense, because I don’t have a web process.

It looks like I can start a different workload from the docker image locally by passing in the process name like this:

docker run my-image work

Is there a way to override the command somewhere in the waypoint config? Or a way to specify which process to run from the Procfile?

I think the default build packs (we don’t maintain these, these are Cloud Native Buildpacks) expect a web process… I think. To use a purely non-web container with buildpacks it may require a custom buildpack. Someone who is more familiar with buildpacks may be able to respond.

If you use the plain Docker builder then it should work, although features such as the URL service won’t work but this makes sense.

Do you have multiple processes you want to run? If it’s just the one process, then this example worked for me without listening to a web port. You shouldn’t need a Procfile if you only have one process type.

Another tip for playing with buildpacks, try using the pack CLI as shown here.

Yeah, I can see how to get it working with a custom buildpack or just bringing my own Dockerfile, but was trying to see how far I could get with the off-the-shelf buildpack.

That said, if it’s not intended to work without a web process, that’s fine, just a little unexpected I guess? Given that the buildpack allows processes other than “web” as part of its API.

Looking at the pack documentation (thank you, @jbayer!) , it seems like what I want to be able to do is set default-process in the Waypoint pack stanza.

Or, even easier, just specify the docker command to run after building the image to run a non-default process.

Yes, I see what you mean. Right now the pack plugin variables are very limited. I created https://github.com/hashicorp/waypoint/issues/598 to track this.

Excellent, thank you!!

A few other challenges for non-HTTP workloads using Kubernetes:

  1. The liveness/readiness probes assume an HTTP endpoint, which you may not have if it’s not an HTTP workload.
  2. Waypoint creates a Service resource which you probably don’t want if you’re not exposing your workload over HTTP
1 Like

Yup, we were laser focused on HTTP workloads for the 0.1 so we plan to start extending from there to non-web. Is the service that you’re deploying TCP based? Or is it not something that directly consumes client requests of any kind?

@evanphx Yeah, so I’ve been working on systems composed out of services consuming messages off of NATS queues, so they don’t accept any TCP connections other than connecting to the broker.

It’s possible that I’d still do health checks through HTTP, especially if I’m already spinning up a prometheus endpoint or something, but I definitely wouldn’t need/want a kubernetes Service resource since I don’t intend to expose that at all.

Makes sense to focus on HTTP for now, though. Nice work on this!

So, thinking this through there are a few bits to consider:

  1. Flexibility of liveness probes. This is pretty easy, we could expose exec or even the ability to just turn it off, not a big issue.
  2. Disable Service object. This isn’t a huge deal though it means effectively having no release functionality either because there is no Service object to pivot between.
  3. Probably manipulating one Deployment object for rollout, rather than creating a new one. Right now Kubernetes creates a new Deployment object for each waypoint deploy, to allow the release phase the ability to point between 2 independent sets. For your use case, I think you’d not want that and instead want just one Deployment object that gets manipulated on each waypoint deploy.

Does that all seem right?

Yeah, I think that mostly sounds right.

For #3, the default deployment behavior is probably fine, even if HTTP traffic isn’t being routed there, especially if the rollout behavior is configurable.

I could see release process that does something like:

  1. Spin up a new deployment
  2. Check some metrics to make sure message ratios remain the same or that there’s not a spike in exceptions or error messages
  3. Continue with deploy or rollback depending on result of #2

That said, there are other projects that do this (Argo Rollouts, for example), so maybe that’s not really the responsibility of Waypoint.

1 Like

Can we revisit this topic since some time has passed? I have a node.js web app I’m deploying using waypoint using the pack + ecs plugins. I am now adding background worker functionality using graphile/worker. I’m not sure what my options are for adjusting my waypoint usage to support this.

Ideally, our waypoint up would create both web and worker ECS tasks using the one image and be able to independently control the number of instances of the web tasks and the worker tasks.

Is there a suitable way to accomplish this today with waypoint?

It seems like you’re facing a challenge with the default Go buildpack. You can try specifying a different process type in your Procfile, like ‘worker,’ instead of ‘web.’ Then, update your Waypoint 3d laser config to reflect this change. This should allow you to run your non-HTTP workload. Hope this helps.

It seems like you’re facing an issue with running a non-http workload using the default Go buildpack in Kubernetes. The error message indicates that the web process type is not found, which makes sense if you don’t have a web process.

To specify a different workload to run from your Docker image locally, you can pass in the process name like this: docker run my-image work.

Regarding your question about overriding the command in the Waypoint config or specifying the process to run from the Procfile dubai movers, it would depend on the specific configuration and tools you’re using. It’s best to consult the documentation or seek advice from the relevant community or support channels to understand how to achieve your desired outcome.

It seems like you’re facing an issue with the default Go buildpack and the Procfile configuration. To specify which process to run from the Procfile, you can update your Procfile like this:

bashCopy code

work: bin/subscriber

In this example, “work” is the process name you want to use. Then, you can reference this process in your Waypoint configuration file (waypoint.hcl) by specifying the “entrypoint” attribute Golden Visa UAE:

hclCopy code

app "my-app" {
  build {
    use "pack" {
      builder = "heroku/buildpacks:18"
    }
  }
  deploy {
    use "kubernetes" {
      // Other Kubernetes configuration options
      entrypoint = "work"
    }
  }
}

By setting the “entrypoint” attribute in your Waypoint configuration to “work,” you can specify which process to run when deploying to Kubernetes, even if it’s not a web process. This should resolve the error you’re encountering.

Facing a similar challenge, you can customize the command executed by specifying an entry in your Waypoint configuration file. Use the ‘command’ field in the ‘build’ block to define the startup command. Check the Waypoint documentation For Soul detailed guidance. Happy coding

Hey there! To address the ‘process type web not found’ error, you can specify the process to run in your Waypoint configuration using the ‘command’ field. Simply add it under ‘app’ in your waypoint.hcl file. For example:

hclCopy code

app "your-app" {
  # ... other configurations ...
  command = ["work"]
}

This should help you override the Invisible Text command and run your non-HTTP workload. Let me know if you need further assistance.

i found 404 error on my page b12 in Scottsdale anyone can tell me discuss

To resolve this issue, you can specify the process type in your waypoint.hcl file. Use the entrypoint or command field to define the process you want to run. For example:

project = "my-project"

app "my-app" {
  build {
    use "pack" {}
  }

  deploy {
    use "kubernetes" {}
  }

  release {
    use "kubernetes" {
      command = "work"
    }
  }
}

Alternatively, you can specify the process in your Procfile like this:

work: bin/subscriber

This way, Waypoint will use the correct process type when running your application.