8
|
Aaron Yodaiken Stephen Chung · 技术社区 · 14 年前 |
1
15
我能想到两大原因:
尽管如此,在很多情况下,我想记录的信息只有在应用程序正常运行时,以及当我已经有了数据库连接时才是相关的。在这些情况下,我直接登录MySQL。 |
2
4
|
3
4
从历史上看,数据库是昂贵的,您肯定不会想在日志上浪费宝贵的数据库许可证。然而,今天的数据库和处理都相对便宜。使用数据库存储日志可能不会在经济上扼杀你。 日志文件的优点是可以一直写到它的末尾。与使用数据库服务器相比,这是一种相对高效的操作。
http://www.squidoo.com/sqlitehammer#module5800826 举个例子。 --------2010年8月编辑------------ SQLite的开发人员已经实现了writeahead日志记录 SQLite version 3.7.0 this video 更多细节。由于编写速度更快,SQLite作为日志数据库更有用。 |
4
1
但是,如果您需要通过简单的文本文件很难获得的分析或度量求值功能,那么这肯定没有错。这在很大程度上是个案。 |
5
1
我认为在远程机器上收集日志(例如,通过Linux上的syslog/rsyslog)进行备份时,DB日志记录会变得更有用:如果原始机器受到破坏,并且其日志发生了更改,这会很有用。在这种情况下,在数据库中收集日志(特别是在远程计算机上)非常有用,因为它可以帮助整理这些日志。您还可以通过诸如 phpLogCon ,或者使用自定义网页浏览它们(如果只是进行一些临时监视,通常比登录到计算机更容易)。 也就是说,远程日志记录、数据库日志记录和浏览日志的工具都是相当独立的(我认为phpLogCon也可以处理文件日志)。如果我将日志存储在数据库中,那么我也会同时将日志存储在文件中,如果只是为了在与数据库的连接断开时能够读取日志的话。 |
6
1
需要注意的是,没有理由不将日志写入一个文件(正如其他人所指出的,这个文件非常快速、高效和健壮),然后将数据卸载到一个数据库(可能在其他机器上)中,以便执行分析,而这种分析会因为具有典型的数据库功能而加快速度。当然,这是可能的,因为日志数据通常不需要立即处理——因此,将数据库的所有开销和脆弱性推迟到需要时再处理是有意义的。 |
hello_programmers · Mysql从其他表输出一列 1 年前 |
Community wiki · 这个MySQL语句出了什么问题? 1 年前 |
Community wiki · 优化从同一表中提取的多列的查询 1 年前 |
Popo · Sql查询:返回数据库中不可用的where条件 1 年前 |
Hamdan Nuramdani · 对账单中一周内不同表中的数据求和 1 年前 |
Kugelfisch · 用php为数据库加密数据 1 年前 |