我有一個簡單的 lambda 函數,它打印一個事件,然后嘗試將一行插入數據庫。它運行時沒有錯誤,但不執行所有代碼。event被打印,但該行永遠不會被插入到表中。任何事情,甚至是我放在后面的打印語句都connection不會被執行。我猜測連接有問題,但據我所知,我無法判斷問題出在哪里。某處還有更多日志嗎?在 CloudWatch 中,我看到最后顯示“任務在 3.00 秒后超時”import boto3import psycopg2s3 = boto3.client('s3')def insert_data(event=None, context=None): print(event) connection = psycopg2.connect(user="xxxx", password="xxxx", host="xxxx", port="xx", database="xxxx") cursor = connection.cursor() postgres_insert_query = "INSERT INTO dronedata (name,lat,long,other) VALUES ('img2','54','43','from lambda')" cursor.execute(postgres_insert_query) connection.commit() count = cursor.rowcount print(count, "Record inserted successfully into mobile table")
2 回答

慕蓋茨4494581
TA貢獻1850條經驗 獲得超11個贊
典型的安全設置是:
AWS Lambda 函數 (
Lambda-SG
) 上的安全組允許所有出站訪問(無需入站規則)數據庫(EC2 實例或 Amazon RDS)上的安全組 (
DB-SG
),允許在適當端口上進行入站訪問Lambda-SG
也就是說,DB-SG
應該在其入站規則中具體引用Lambda-SG
。
添加回答
舉報
0/150
提交
取消