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的自动配置进行配置,使用以下

相关内容

热门资讯

热点推荐!德扑赔率胜率计算,w... 热点推荐!德扑赔率胜率计算,wpk有外挂,解密教程(从来真的是有挂)1、金币登录送、破产送、升级送、...
重磅来袭!微扑克模拟器是什么,... 自定义德州之星辅助挂系统规律,只需要输入自己想要的开挂功能,一键便可以生成出微扑克专用辅助器,不管你...
玩家必看科普!德扑ai软件购买... 玩家必看科普!德扑ai软件购买,aapoker发牌机制,线上教程(素来真的是有挂)1、在aapoke...
热点推荐!wepoke软件透明... 热点推荐!wepoke软件透明挂演示,德扑起手牌胜率图,细节方法(本来有挂)(1)热点推荐!wepo...
六分钟了解!wepoke软件收... 六分钟了解!wepoke软件收费吗,WePoKe透视挂,系统教程(原生真的是有挂);无聊就玩这款We...
玩家必知教程!德州ai辅助神器... 玩家必知教程!德州ai辅助神器燃油,wepokeai代打,实用技巧(本来存在有挂)1、金币登录送、破...
实测发现!wpk微扑克真的有辅... 自定义WePoKe透视挂系统规律,只需要输入自己想要的开挂功能,一键便可以生成出微扑克专用辅助器,不...
推荐一款!德州ai人工智能,a... 推荐一款!德州ai人工智能,aapoker挂,透明教程(原生存在有挂);无聊就玩这款德州ai人工智能...
推荐几款新版!wopoker辅... 推荐几款新版!wopoker辅助软件,智星德州菠萝辅助器,教你攻略(真是存在有挂)1、构建自己的微扑...
关于!aapoker插件,wp... 关于!aapoker插件,wpk透明挂,力荐教程(一贯是有挂);无聊就玩这款wpk透明挂真的有辅助,...