AWSLambda部署时,我的SerilogPostgreSQLsink没有写入日志?
创始人
2024-09-26 02:00:19
0
  1. 确认PostgreSQL数据库是否正确配置,数据库地址、用户名、密码、端口是否正确。
  2. 确认Lambda函数是否有足够的权限访问PostgreSQL数据库,可以使用以下代码为Lambda函数添加访问权限:
using Amazon.Lambda.Core;
using Amazon.Lambda.Serialization.SystemTextJson;
using Amazon.Lambda.SQSEvents;
using Npgsql;

[assembly: LambdaSerializer(typeof(DefaultLambdaJsonSerializer))]

namespace MyLambdaFunction
{
    public class Function
    {
        public void FunctionHandler(SQSEvent evnt, ILambdaContext context)
        {
            var connString = "Server=myServerAddress;Port=12345;Database=myDataBase;User Id=myUsername;Password=myPassword;";

            using var conn = new NpgsqlConnection(connString);
            conn.Open();

            using var cmd = new NpgsqlCommand
            {
                Connection = conn,
                CommandText = "SELECT version()"
            };

            using var reader = cmd.ExecuteReader();
            reader.Read();

            context.Logger.LogLine(reader.GetString(0));
        }
    }
}
  1. 确认Lambda函数是否正确配置Serilog,尤其是PostgreSQL sink相关的配置项是否正确配置。可以使用以下代码示例进行配置:
using Amazon.Lambda.Core;
using Serilog;
using Serilog.Core;
using Serilog.Sinks.PostgreSQL;

[assembly: LambdaSerializer(typeof(Amazon.Lambda.Serialization.SystemTextJson.DefaultLambdaJsonSerializer))]

namespace MyLambdaFunction
{
    public class Function
    {
        private static Logger _logger;

        static Function()
        {
            _logger = new LoggerConfiguration()
                .WriteTo.PostgreSQL("Host=myServerAddress;Port=12345;Database=myDataBase;Username=myUsername;Password=myPassword;",
                    tableName: "Logs",
                    needAutoCreateTable: true)
                .CreateLogger();

            Log.Logger = _logger;
        }

        public void FunctionHandler()
        {
            Log.Information("Hello, world!");
        }
    }
}

以上代码仅供参考,确保根据实际情况修改配置项。同时,可以使用Serilog的自动配置进行配置,使用以下

相关内容

热门资讯

6分钟辅助!hhpoker是真... 6分钟辅助!hhpoker是真的假的,hhpoker真的有透视吗,演示教程(真是有挂)1、每一步都需...
第七分钟辅助!we poker... 第七分钟辅助!we poker插件,we poker免费辅助器,手筋教程(有挂方式)暗藏猫腻,小编详...
七分钟辅助!aa poker辅... 七分钟辅助!aa poker辅助包,pokemmo脚本辅助器下载,讲义教程(有挂秘籍)1、pokem...
第四分钟辅助!wepoker辅... 第四分钟辅助!wepoker辅助器安装包定制,aapoker透视脚本,大纲教程(有挂总结)所有人都在...
第四分钟辅助!wpk透视辅助靠... 第四分钟辅助!wpk透视辅助靠谱吗,wepoker透视苹果系统,诀窍教程(有挂猫腻);运wepoke...
七分钟辅助!aapoker透视... 七分钟辅助!aapoker透视脚本入口,wejoker开挂,学习教程(有挂教程)1、打开软件启动之后...
第四分钟辅助!淘宝买wepok... 第四分钟辅助!淘宝买wepoker透视有用吗,wpk俱乐部怎么作弊,积累教程(有挂规律)1、下载好淘...
6分钟辅助!we-poker软... 6分钟辅助!we-poker软件,购买的wpk辅助在哪里下载,积累教程(有挂技巧)购买的wpk辅助在...
第2分钟辅助!如何下载wepo... 第2分钟辅助!如何下载wepoker安装包,newpoker怎么安装脚本,教程书教程(今日头条)1、...
4分钟辅助!wepoker钻石... 4分钟辅助!wepoker钻石怎么看底牌,wepoker辅助器有哪些功能,法门教程(有挂详细)该软件...