Можно ли использовать SQS -> Lambda -> API Gateway -> Lambda -> DB?
Ответ: Да, вы можете это сделать, см. Следующий пример, замените ваш вызов наapi getway url и hit rest call, но не решение вашей проблемы.
var https = require('https');
exports.handler = (event, context, callback) => {
var params = {
host: "bittrex.com",
path: "/api/v1.1/public/getmarketsummaries"
};
var req = https.request(params, function(res) {
let data = '';
console.log('STATUS: ' + res.statusCode);
res.setEncoding('utf8');
res.on('data', function(chunk) {
data += chunk;
});
res.on('end', function() {
console.log("DONE");
console.log(JSON.parse(data));
});
});
req.end();
};
Other Approch:
После выполнения лямбда-функции AWS Lambda поддерживает контекст выполнения длянекоторое время в ожидании другого вызова лямбда-функции.По сути, служба замораживает контекст выполнения после завершения лямбда-функции и оттаивает контекст для повторного использования, если AWS Lambda выбирает повторное использование контекста при повторном вызове лямбда-функции.Этот подход повторного использования контекста выполнения имеет следующие последствия:
Любые объявления в вашем коде функции Lambda (вне кода обработчика, см. Модель программирования) остаются инициализированными, обеспечивая дополнительную оптимизацию при повторном вызове функции.Например, если ваша функция Lambda устанавливает соединение с базой данных, а не восстанавливает соединение, исходное соединение используется в последующих вызовах.Вы можете добавить логику в свой код, чтобы проверить, существует ли уже соединение перед его созданием.
Пример:
import sys
import logging
import rds_config
import pymysql
#rds settings
rds_host = "rds-instance-endpoint"
name = rds_config.db_username
password = rds_config.db_password
db_name = rds_config.db_name
logger = logging.getLogger()
logger.setLevel(logging.INFO)
try:
conn = pymysql.connect(rds_host, user=name, passwd=password, db=db_name, connect_timeout=5)
except:
logger.error("ERROR: Unexpected error: Could not connect to MySQL instance.")
sys.exit()
logger.info("SUCCESS: Connection to RDS MySQL instance succeeded")
def handler(event, context):
"""
This function fetches content from MySQL RDS instance
"""
item_count = 0
with conn.cursor() as cur:
cur.execute("create table Employee3 ( EmpID int NOT NULL, Name varchar(255) NOT NULL, PRIMARY KEY (EmpID))")
cur.execute('insert into Employee3 (EmpID, Name) values(1, "Joe")')
cur.execute('insert into Employee3 (EmpID, Name) values(2, "Bob")')
cur.execute('insert into Employee3 (EmpID, Name) values(3, "Mary")')
conn.commit()
cur.execute("select * from Employee3")
for row in cur:
item_count += 1
logger.info(row)
#print(row)
conn.commit()
return "Added %d items from RDS MySQL table" %(item_count)
Выполнение pymysql.connect () вне обработчика позволяет вашей функции повторно использовать соединение с базой данных для повышения производительности.