8

运行节点应用程序时出现配置错误。错误是:

{ ConfigError: Missing region in config
at Request.VALIDATE_REGION (C:\Users\chris\Documents\AWS API 
TEST\myapp\node_modules\aws-sdk\dist\aws-sdk-react-native.js:12027:47)
at Request.callListeners (C:\Users\chris\Documents\AWS API 
TEST\myapp\node_modules\aws-sdk\dist\aws-sdk-react-native.js:11804:22)
at callNextListener (C:\Users\chris\Documents\AWS API 
TEST\myapp\node_modules\aws-sdk\dist\aws-sdk-react-native.js:11794:14)
at C:\Users\chris\Documents\AWS API TEST\myapp\node_modules\aws-
sdk\dist\aws-sdk-react-native.js:12021:11
at finish (C:\Users\chris\Documents\AWS API TEST\myapp\node_modules\aws-
sdk\dist\aws-sdk-react-native.js:10842:9)
at Config.getCredentials (C:\Users\chris\Documents\AWS API 
TEST\myapp\node_modules\aws-sdk\dist\aws-sdk-react-native.js:10887:9)
at Request.VALIDATE_CREDENTIALS (C:\Users\chris\Documents\AWS API 
TEST\myapp\node_modules\aws-sdk\dist\aws-sdk-react-native.js:12016:28)
at Request.callListeners (C:\Users\chris\Documents\AWS API 
TEST\myapp\node_modules\aws-sdk\dist\aws-sdk-react-native.js:11800:20)
at Request.emit (C:\Users\chris\Documents\AWS API 
TEST\myapp\node_modules\aws-sdk\dist\aws-sdk-react-native.js:11776:12)
at Request.emit (C:\Users\chris\Documents\AWS API 
TEST\myapp\node_modules\aws-sdk\dist\aws-sdk-react-native.js:13792:16)
message: 'Missing region in config',
code: 'ConfigError',

我的代码是:

//Authenticate AWS:
var myCredentials = new AWS.CognitoIdentityCredentials({IdentityPoolId:'us-west-2a:"Identity Pool ID"'});
var myConfig = new AWS.Config({
          credentials: myCredentials, region: 'us-west-2a'
});

这是在使用 ejs 和节点的快速服务器上运行的。我正在使用亚马逊 JavaScript 开发工具包。

我在这里尝试了解决方案:

AWSCognito 配置错误中缺少区域

这没有帮助。

编辑1:

按照下面的要求,我附上了完整的代码:

var express = require('express');
var AWS = require('aws-sdk');
var EC2 = require('aws-ec2')('access key', 'secret');
var scale = require('aws-scale');
var router = express.Router();

//Authenticate AWS:
var myCredentials = new AWS.CognitoIdentityCredentials({
  IdentityPoolId:'us-west-2:b0efe3c7-e4c9-420f-836b-6d776e2a9271'
}); 

var myConfig = new AWS.Config({
  credentials: myCredentials, region: 'us-west-2'
});

AWS.config = myConfig

var minInst = 1;
var maxInst = 3;

var ec2 = new AWS.EC2();
//Set up parameters for EC2 Instances:
var params = {
  ImageId: 'ami-6e1a0117',
  MaxCount: minInst,
  MinCount: maxInst, 
  InstanceInitiatedShutdownBehavior: 'terminate',
  InstanceType: 't2.micro',
  Monitoring: {
    Enabled: true 
  },
  NetworkInterfaces: [{
    AssociatePublicIpAddress: true,
    DeleteOnTermination: true,
  }],
  Placement: {
    AvailabilityZone: 'us-west-2',
  },
  SecurityGroupIds: [
    'sg-b0307ccd',
  ],
  SecurityGroups: [
    'CAB432Assignment2SG',
  ],

};
ec2.runInstances(params, function(err, data) {
  if (err){
    console.log(err, err.stack); //An error occurred
  }
  else{
    console.log(data); //Successful Response
  }
});
4

4 回答 4

9

在您的配置中添加区域,如下所示:

AWS.config.update({
    region: "REGION" //Here add you region
});

请将其添加到最顶层(行上方var ec2 = new AWS.EC2();

于 2017-10-30T06:37:17.747 回答
7

俄勒冈地区的正确代码是us-west-2。您已将其设置为us-west-2a在两个地方。

在提及身份池 ID 时,更正以下代码并尝试:

AWS.config.update({region:'us-west-2'});
var myCredentials = new AWS.CognitoIdentityCredentials({
    IdentityPoolId:'us-west-2:"Identity Pool ID"'
});

如果您没有传递API CognitoIdentityCredentials的区域,那么它将从AWS.config中提取数据。

此外,在您的代码中,在使用区域名称初始化AWS.CONFIG时,您使用了. 更正它,如果您要使用它而不是 AWS.config.updateus-west-2a

var myConfig = new AWS.Config({
    credentials: myCredentials, region: 'us-west-2'
});

更新

我发现了另一个问题。问题是,您正在初始化AWS.configvar myConfig = new AWS.Config()但您没有用它更新AWS.config类。缺少的代码是 : AWS.config = myConfig

由于您没有将其更新回来,并且您也没有更新现有的默认类AWS.config.update({region:'us-west-2'});,因此它会引发Missing region in config错误。

正确的代码片段

var AWS = require('aws-sdk');
var myCredentials = new AWS.CognitoIdentityCredentials({
    IdentityPoolId:'us-west-2:identity-pool-id'
}); 
var myConfig = new AWS.Config({
    credentials: myCredentials, region: 'us-west-2'
});
AWS.config = myConfig
于 2017-10-30T07:20:07.100 回答
3

上面的答案是正确的。但是,因为aws-sdk-js-v3您不能AWS.config全局设置。因此,解决方法是:

process.env.AWS_REGION = 'us-west-2'

此外,如果您"169.254.169.254:80/latest/meta-data/iam/security-credentials/"在 CI 构建期间收到有关无法访问的错误,您可能希望以相同的方式设置假凭据:

process.env.AWS_REGION = 'us-west-2'
process.env.AWS_ACCESS_KEY_ID = 'test-key'
process.env.AWS_SECRET_ACCESS_KEY = 'test-secret'
于 2021-01-14T10:42:56.480 回答
0

在您的情况下,这是执行顺序(这就是副作用不好的原因)。

错误的:

var myCredentials = new AWS.CognitoIdentityCredentials({
  IdentityPoolId:'us-west-2:b0efe3c7-e4c9-420f-836b-6d776e2a9271'
}); 

var myConfig = new AWS.Config({
  credentials: myCredentials, region: 'us-west-2'
});

正确的:

// update the config
var myConfig = new AWS.Config({
  credentials: myCredentials, region: 'us-west-2'
});

// then create the instance
var myCredentials = new AWS.CognitoIdentityCredentials({
  IdentityPoolId:'us-west-2:b0efe3c7-e4c9-420f-836b-6d776e2a9271'
}); 
于 2021-05-18T22:40:00.397 回答