The resource 'projects/<my project>' was not found" error when trying to get list of running instances
Asked Answered
S

4

6

My goal is to test out google's orchestrator and the compute engine api by first retrieving a list of active instances. The orchestrator project including the servlet file is stored in a jar.

I'm trying to test out the java google compute engine client api. I have a cron job which calls on the orchestrator servlet. The target for the cron is a backend. From which I try to get the list of instances:

...
AppIdentityCredential credential = getCredential(computeScope);

String appName = ConfigProperties.getInstance().getGceConfigProperties().get("projectId");

try {
    httpTransport = GoogleNetHttpTransport.newTrustedTransport();

    final Compute compute = new Compute.Builder(
        httpTransport, JSON_FACTORY, credential).setApplicationName(appName)
        .build();
    logger.info("================== Listing Compute Engine Instances ==================");

    Compute.Instances.List instances = compute.instances().list(projectId, zone);
    InstanceList list = instances.execute();

    if (list.getItems() == null) {
        logger.info("No instances found. Sign in to the Google APIs Console and create "
            + "an instance at: code.google.com/apis/console");
    } else {
        for (Instance instance : list.getItems()) {
            logger.info(instance.toPrettyString());
        }
    }
...

There error response I get is(I omitted my project name from the response, I confirmed that I'm using the correct project id in my code):

com.google.cloud.solutions.sampleapps.orchestration.orchestrator.server.GceClientApiUtils      
getInstances: com.google.api.client.googleapis.json.GoogleJsonResponseException: 404 OK
{
  "code" : 404,
  "errors" : [ {
    "domain" : "global",
    "message" : "The resource 'projects/<project-name-here>' was not found",
    "reason" : "notFound"
  } ],
  "message" : "The resource 'projects/<project-name_here>' was not found"
}

I've also attempted this by retrieving an access token and making a RESTful call to get the list of instances and i received the exact same response. I confirmed the Url constructed was correct by comparing it against a successful query of the instances using the api explorer.

EDIT: I determined the solution to the issue with help of another post: I was finally able to find the solution in the post Compute Engine API call fails with http 404

I needed to add my app engine service account as a team member with edit capabilities, which it does not have by default. Once I did this, the code worked as expected. I had to do this through cloud.google.com/console, as if done through appengine.google.com, a pending status will be given to the service account and will not have access.

Sedative answered 2/7, 2014 at 18:7 Comment(0)
R
2

Do you have access to the developers console https://console.developers.google.com? It seems that the user account @appspot.gserviceaccount.com has not access to compute engine. In my case I see @developer.gserviceaccount.com.

If you don't have one, visit https://developers.google.com/console/help/new/#generatingoauth2 to create a new Client ID

Riot answered 7/7, 2014 at 14:46 Comment(1)
I was finally able to find the solution in the post #21062786. I needed to add my app engine service account as a team member with edit capabilities, which it does not have by default. Once I did this, the code worked as expected. I had to do this through cloud.google.com/console, as if done through appengine.google.com, a pending status will be given to the service account and will not have access.Sedative
B
5

For me i had to make sure i had authorization. Try this in the terminal gcloud auth login

Bunt answered 30/7, 2014 at 21:44 Comment(0)
R
3

Make sure you are in the right project, you can run this command on your vm to see if you are in the right project: gcloud config list

Take a look at this post in Google Groups

Riot answered 3/7, 2014 at 15:58 Comment(2)
The code is running in a jar within the app engine application. I verified by calling getServiceAccountName(). The result was <my-project>@appspot.gserviceaccount.comSedative
I successfully retrieve the token using AppIdentityCredential. However, when I make a call to compute using this credential it returns that the resource could not be found.Sedative
R
2

Do you have access to the developers console https://console.developers.google.com? It seems that the user account @appspot.gserviceaccount.com has not access to compute engine. In my case I see @developer.gserviceaccount.com.

If you don't have one, visit https://developers.google.com/console/help/new/#generatingoauth2 to create a new Client ID

Riot answered 7/7, 2014 at 14:46 Comment(1)
I was finally able to find the solution in the post #21062786. I needed to add my app engine service account as a team member with edit capabilities, which it does not have by default. Once I did this, the code worked as expected. I had to do this through cloud.google.com/console, as if done through appengine.google.com, a pending status will be given to the service account and will not have access.Sedative
C
0

Once you have verified the gcloud installation. gcloud compute ssh example user@instance-name make sure to enter the VM instance user and instance name.

Clonus answered 8/8, 2024 at 18:26 Comment(0)

© 2022 - 2025 — McMap. All rights reserved.