log4net输出到PostgreSql

PgSQL越来越强大了。小项目输出log到sqlite是挺好的,大东西尤其是要长期运行的程序还是输出到PostgreSQL比较,也更适用于寄宿在Windows Service这种将当前目录视为System32的场合。


直接上配置文件。

<!--定义输出到PostgreSql数据库中,用于Windows Service这种无法正确识别程序当前目录从而无法使用相对路径的场合-->
    <appender name="AdoNetAppender_PostgreSQL_All" type="log4net.Appender.AdoNetAppender">
      <bufferSize value="10"/>
      <connectionType value="Npgsql.NpgsqlConnection, Npgsql"/>
      <!--PostgreSql连接字符串-->
      <connectionString value="Server=127.0.0.1;Port=5432;User Id=postgres;Password=tm;Database=postgres;"/>
      <!--PostgreSql插入字符串-->
      <!--如果想在PostgreSql中保持字段字有大小写,要加入"
          但是由于我用了Ormlite,所以不需要了
      <commandText value="INSERT INTO "Log" 
                   ("AppDomain", "AspnetCache", "AspnetContext", "AspnetRequest", "AspnetSession", 
                   "Logger", "Date", "Identity", "Level", "Location", "Exception",
                   "Message", "Thread", "NDC", "StackTraceDetail", "UserName", "UTCDate")
                    VALUES
                    (:AppDomain, :AspnetCache, :AspnetContext, :AspnetRequest, :AspnetSession, :Logger, :Date, :Identity, :Level, :Location, :Exception,
                    :Message, :Thread, :NDC, :StackTraceDetail, :UserName, :UTCDate)"/>
      -->
      <!--为了配合Ormlite生成的表,中间加上下划线-->
            <commandText value="INSERT INTO log 
                   (app_domain, aspnet_cache, aspnet_context, aspnet_request, aspnet_session, 
                   logger, date_time, identity, level, location, exception,
                   message, thread, ndc, stack_trace_detail, user_name, utc_date)
                    VALUES
                    (:AppDomain, :AspnetCache, :AspnetContext, :AspnetRequest, :AspnetSession, :Logger, :Date, :Identity, :Level, :Location, :Exception,
                    :Message, :Thread, :NDC, :StackTraceDetail, :UserName, :UTCDate)"/>
      <parameter>
        <parameterName value="AppDomain"/>
        <dbType value="String"/>
        <layout type="log4net.Layout.PatternLayout">
          <conversionPattern value="%appdomain"/>
        </layout>
      </parameter>
      <parameter>
        <parameterName value="AspnetCache"/>
        <dbType value="String"/>
        <layout type="log4net.Layout.PatternLayout">
          <conversionPattern value="%aspnet-cache"/>
        </layout>
      </parameter>
      <parameter>
        <parameterName value="AspnetContext"/>
        <dbType value="String"/>
        <layout type="log4net.Layout.PatternLayout">
          <conversionPattern value="%aspnet-context"/>
        </layout>
      </parameter>
      <parameter>
        <parameterName value="AspnetRequest"/>
        <dbType value="String"/>
        <layout type="log4net.Layout.PatternLayout">
          <conversionPattern value="%aspnet-request"/>
        </layout>
      </parameter>
      <parameter>
        <parameterName value="AspnetSession"/>
        <dbType value="String"/>
        <layout type="log4net.Layout.PatternLayout">
          <conversionPattern value="%aspnet-session"/>
        </layout>
      </parameter>
      <parameter>
        <parameterName value="Logger"/>
        <dbType value="String"/>
        <layout type="log4net.Layout.PatternLayout">
          <conversionPattern value="%logger"/>
        </layout>
      </parameter>
      <parameter>
        <parameterName value="Date"/>
        <dbType value="DateTime"/>
        <layout type="log4net.Layout.RawTimeStampLayout"/>
      </parameter>
      <parameter>
        <parameterName value="Identity"/>
        <dbType value="String"/>
        <layout type="log4net.Layout.PatternLayout">
          <conversionPattern value="%identity"/>
        </layout>
      </parameter>
      <parameter>
        <parameterName value="Level"/>
        <dbType value="String"/>
        <layout type="log4net.Layout.PatternLayout">
          <conversionPattern value="%level"/>
        </layout>
      </parameter>
      <parameter>
        <parameterName value="Location"/>
        <dbType value="String"/>
        <layout type="log4net.Layout.PatternLayout">
          <conversionPattern value="%location"/>
        </layout>
      </parameter>
      <parameter>
        <parameterName value="Exception"/>
        <dbType value="String"/>
        <layout type="log4net.Layout.ExceptionLayout">
        </layout>
      </parameter>
      <parameter>
        <parameterName value="Message"/>
        <dbType value="String"/>
        <layout type="log4net.Layout.PatternLayout">
          <conversionPattern value="%message"/>
        </layout>
      </parameter>
      <parameter>
        <parameterName value="Thread"/>
        <dbType value="String"/>
        <layout type="log4net.Layout.PatternLayout">
          <conversionPattern value="%thread"/>
        </layout>
      </parameter>
      <parameter>
        <parameterName value="NDC"/>
        <dbType value="String"/>
        <layout type="log4net.Layout.PatternLayout">
          <conversionPattern value="%ndc"/>
        </layout>
      </parameter>
      <parameter>
        <parameterName value="StackTraceDetail"/>
        <dbType value="String"/>
        <layout type="log4net.Layout.PatternLayout">
          <conversionPattern value="%stacktracedetail{10}"/>
        </layout>
      </parameter>
      <parameter>
        <parameterName value="UserName"/>
        <dbType value="String"/>
        <layout type="log4net.Layout.PatternLayout">
          <conversionPattern value="%username"/>
        </layout>
      </parameter>
      <parameter>
        <parameterName value="UTCDate"/>
        <dbType value="DateTime"/>
        <layout type="log4net.Layout.RawUtcTimeStampLayout"/>
      </parameter>
    </appender>

运行时当前目录下要有Npgsql.dll,还要事先在PgSQL中建好表,好人做到底,再奉上Ormlite生成的SQL:

-- Table: log

-- DROP TABLE log;

CREATE TABLE log
(
  id serial NOT NULL,
  date_time timestamp without time zone NOT NULL,
  thread text,
  level text,
  logger text,
  message text,
  exception text,
  stack_trace_detail text,
  location text,
  identity text,
  app_domain text,
  user_name text,
  ndc text,
  utc_date timestamp without time zone,
  aspnet_cache text,
  aspnet_context text,
  aspnet_request text,
  aspnet_session text,
  CONSTRAINT log_pkey PRIMARY KEY (id)
)
WITH (
  OIDS=FALSE
);
ALTER TABLE log
  OWNER TO postgres;

-- Index: idx_log_level

-- DROP INDEX idx_log_level;

CREATE INDEX idx_log_level
  ON log
  USING btree
  (level COLLATE pg_catalog."default");

-- Index: uidx_log_date

-- DROP INDEX uidx_log_date;

CREATE UNIQUE INDEX uidx_log_date
  ON log
  USING btree
  (date);


发完贴子才发现系统将&quot;给解析成了双引号,再直接贴上:

<!--如果想在PostgreSql中保持字段字有大小写,要加入&quot
          但是由于我用了Ormlite,所以不需要了
      <commandText value="INSERT INTO &quot;Log&quot; 
                   (&quot;AppDomain&quot;, &quot;AspnetCache&quot;, &quot;AspnetContext&quot;, &quot;AspnetRequest&quot;, &quot;AspnetSession&quot;, 
                   &quot;Logger&quot;, &quot;Date&quot;, &quot;Identity&quot;, &quot;Level&quot;, &quot;Location&quot;, &quot;Exception&quot;,
                   &quot;Message&quot;, &quot;Thread&quot;, &quot;NDC&quot;, &quot;StackTraceDetail&quot;, &quot;UserName&quot;, &quot;UTCDate&quot;)
                    VALUES
                    (:AppDomain, :AspnetCache, :AspnetContext, :AspnetRequest, :AspnetSession, :Logger, :Date, :Identity, :Level, :Location, :Exception,
                    :Message, :Thread, :NDC, :StackTraceDetail, :UserName, :UTCDate)"/>
      -->


  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
首先,让我们了解一下每个工具的作用: - Next.js是一个React框架,用于构建服务器渲染的应用程序。 - Log4js是一个流行的Node.js日志记录库,可以将日志输出到控制台、文件、数据库等。 - Prisma是一个Node.js ORM库,用于管理数据库。 现在,我们将介绍如何集成这三个工具。 1. 安装依赖 首先,需要安装相关的依赖项: ```bash npm install next @types/node @types/react log4js prisma ``` 2. 配置Log4js 在项目根目录下创建一个名为 `log4js.json` 的文件,它将包含Log4js的配置信息。例如: ```json { "appenders": { "out": { "type": "stdout" }, "app": { "type": "file", "filename": "logs/app.log" } }, "categories": { "default": { "appenders": ["out", "app"], "level": "debug" } } } ``` 上面的配置将日志输出到控制台和一个名为 `app.log` 的文件中。 3. 配置Prisma 在项目根目录下创建一个名为 `prisma/schema.prisma` 的文件,它将包含Prisma的模型定义。例如: ```prisma datasource db { provider = "postgresql" url = env("DATABASE_URL") } generator client { provider = "prisma-client-js" } model User { id Int @id @default(autoincrement()) name String email String @unique password String createdAt DateTime @default(now()) updatedAt DateTime @updatedAt } ``` 上面的模型定义将创建一个名为 `User` 的表,包含 `id`、`name`、`email`、`password`、`createdAt` 和 `updatedAt` 列。 4. 集成Log4js和Prisma 在Next.js的 `_app.js` 文件中,可以使用Log4js和Prisma。例如: ```javascript import { AppProps } from "next/app"; import log4js from "log4js"; import { PrismaClient } from "@prisma/client"; log4js.configure("log4js.json"); const logger = log4js.getLogger(); const prisma = new PrismaClient(); function MyApp({ Component, pageProps }: AppProps) { return <Component {...pageProps} />; } export default MyApp; ``` 上面的代码将配置Log4js和创建Prisma客户端。 5. 使用Log4js和Prisma 现在,可以在Next.js应用程序中使用Log4js和Prisma。例如: ```javascript import { NextApiRequest, NextApiResponse } from "next"; import { PrismaClient } from "@prisma/client"; import log4js from "log4js"; const prisma = new PrismaClient(); const logger = log4js.getLogger(); export default async function handler( req: NextApiRequest, res: NextApiResponse ) { try { const users = await prisma.user.findMany(); logger.debug("Users: ", users); res.status(200).json(users); } catch (err) { logger.error("Error: ", err); res.status(500).json({ error: "Something went wrong" }); } } ``` 上面的代码将从数据库中检索用户,并使用Log4js记录调试信息和错误。 这就是如何将Log4js和Prisma集成到Next.js应用程序中。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值