- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我已经考虑配置文件及其与代码的关系有一段时间了,根据日期和风向,我的观点似乎会发生变化。但我越来越回想起我在学习 Lisp 时最初的认识:数据和代码之间几乎没有什么区别。对于配置文件来说,这似乎更加正确。从正确的角度来看,Perl 脚本只不过是 Perl 的配置文件。这往往会对 QA 和劳动分工(例如谁应该负责更改配置文件)等任务产生相当严重的后果。
从配置文件到成熟语言的转变通常很慢,并且似乎是由拥有通用系统的愿望驱动的。大多数项目似乎都是从小规模开始的,只有一些配置项,例如在哪里写入日志、在哪里查找数据、用户名和密码等。但随后它们开始增长:功能开始能够打开或关闭,操作的时间和顺序开始受到控制,不可避免地,有人想要开始向其添加逻辑(例如,如果机器是 X,则使用 10;如果机器是 Y,则使用 15)。在某个时刻,配置文件变成了一种特定于域的语言,而且是一种写得很糟糕的语言。
现在我已经漫无目的地准备好了,以下是我的问题:
正如我之前所说,我对这些问题的答案不断变化,但现在我在想:
最佳答案
非常有趣的问题!
我倾向于将我的配置文件限制为非常简单的“key=value”格式,因为我完全同意你的观点,配置文件可以很快成为成熟的程序。例如,任何曾经尝试过“配置”OpenSER 的人都知道您所说的感觉:这不是配置,而是(痛苦的)编程。
当您需要您的应用程序以您今天无法想象的方式非常“可配置”时,那么您真正需要的是插件系统。您需要以其他人可以编写新插件并将其连接到您的应用程序的方式来开发您的应用程序。
那么,回答你的问题:
配置文件的真正用途是什么?
我想说的是,允许安装您的应用程序的人能够调整一些与部署相关的参数,例如主机名、线程数、您需要的插件的名称以及这些插件的部署参数插件(查看 FreeRadius 的配置以获取此原理的示例)等。绝对不是表达业务逻辑的地方。
是否应该尝试保持配置文件简单?
当然。正如您所建议的,配置文件中的“编程”是可怕的。我认为应该避免这种情况。
谁应该负责对它们进行更改(开发人员、用户、管理员等)?
一般来说,我会说部署应用程序的管理员。
它们是否应该受到源代码控制(参见问题 3)?
我通常不对配置文件本身进行源代码控制,但我对模板配置文件进行源代码控制,其中包含所有参数及其默认值以及描述其功能的注释。例如,如果配置文件名为 database.conf
,我通常会对名为 database.conf.template
的文件进行源代码管理。当然,现在我正在谈论我作为开发人员所做的事情。 作为管理员,我可能希望对我为每次安装选择的实际设置进行源代码控制。例如,我们远程管理数百台服务器,我们需要跟踪它们的配置:我们选择通过源代码控制来做到这一点。
编辑:虽然我相信上述内容对于大多数应用程序都是正确的,但当然总有异常(exception)。例如,您的应用程序可能允许其用户动态配置复杂的规则。大多数电子邮件客户端允许用户定义电子邮件管理规则(例如,“所有来自‘john doe’并且“收件人:”字段中没有我的电子邮件都应被丢弃”)。另一个示例是允许用户定义新的复杂商业报价的应用程序。您还可以考虑像 Cognos 这样的应用程序,它允许用户构建复杂的数据库报告。电子邮件客户端可能会为用户提供一个简单的界面来定义规则,这将生成一个复杂的配置文件(甚至可能是一些代码)。另一方面,商业报价的用户定义配置可以以结构化方式保存在数据库中(既不是简单的键=值结构,也不是代码的一部分)。一些其他应用程序甚至可能允许用户使用 python 或 VB 或其他一些支持自动化的语言进行编码。换句话说...您的里程可能会有所不同。
关于configuration - 配置文件什么时候成为一种编程语言?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/648246/
我正在学习 Go,但我无法在任何地方找到这个答案。 Web开发中的文件扩展名是否有任何官方标准?我见过多种约定,例如 .tmpl 和 .gtpl,这是什么?谢谢。 最佳答案 没有固定的标准,但有一些相
关闭。这个问题是opinion-based .它目前不接受答案。 想改善这个问题吗?更新问题,以便可以通过 editing this post 用事实和引文回答问题. 8 年前关闭。 Improve
假设我有两个类(class) Widget ^ | Window 我还有另一个类应用程序: 定义如下 class Application { public: ... private:
按照目前的情况,这个问题不适合我们的问答形式。我们希望答案得到事实、引用或专业知识的支持,但这个问题可能会引发辩论、争论、投票或扩展讨论。如果您觉得这个问题可以改进并可能重新打开,visit the
我多年来一直在使用 MySQL,直到去年左右,主要是在较小的项目上。我不确定是语言的性质还是我缺乏真正的教程让我不确定我正在写的东西是否是优化目的和扩展目的的正确方法。 虽然自学 PHP,但我对自己和
我已经多次读到 EJB 是重量级的……但昨晚我正在浏览关于 EJB 的 Java EE 6 教程,它们似乎只是普通的 Java 对象,除了它们可以有像 Stateless 或 Singletons 这
如何使此 SimpleModal 脚本在页面加载时加载而不是单击按钮?谢谢=) Demo 基本模态对话框 对于此演示,SimpleModal 使用此“隐藏”数据作为其内容。您还可以使用标准 HTML
这是 Haskell 中的代码: class Fooable a where foo :: a -> a instance Fooable (a, a) where foo = ...
是否有推荐的方法来测试 Actor 是否使用 be 正确改变了其行为?我更喜欢使用 FSM 的原因之一是因为我可以轻松验证 Actor 是否已更改其行为。我不知道在使用 become/unbecome
我正在构建一个位于“php my admin”中的表,我是在第一次点击其中一个“th”它的 asc 时这样做的,现在我试图在第二次点击时制作 desc ..有什么想法吗? 阿姆..很多我不记得了抱歉.
考虑以下网页。 我在 Firefox 中打开此页面,打开 JS 控制台并键入以下内容。 > document.getElementById(
如何让自己成为 postgresql 的 super 用户? 我一直在尝试创建数据库,但我不断收到以下错误: createdb: database creation failed: ERROR: pe
Query没有太大帮助。 如前所述here , PostgreSQL 是 ORDBMS。 here ,它解释了 PostgreSQL 是 RDBMS。 PostgreSQL 是一个 ORDBMS 是什
我已经看到,当在导航元素中使用的链接中垂直/水平居中文本时,将链接设置为 flex 容器会很有用。我没有意识到链接文本实际上可以是一个(单个) flex 元素。我可以看到链接中的 span 元素可以是
我见过很多说明如何找到给定集合的子集的示例,但是您如何将一个集合设为另一个集合的子集?所以集合 B 是集合 A 的子集,这将如何实现?我目前正在使用递归性质的方案,但是这本书只展示了如何列出子集而不是
有些程序会根据其标准输出是否为 tty 来更改其输出。因此,如果您将它们放入管道或重定向它们,输出将与您的 shell 中的不同。这是一个例子: $ touch a b c # when runnin
我正处于项目的开始阶段,到目前为止我一直在使用默认的 MySQL 数据库。 对了,默认的数据库有名字吗? 我的问题是如何在不删除当前表和创建新表的情况下将现有表更改为 utf-8 和 InnoDB。是
我正在尝试编写一个过滤器来包装数据以遵循 JSON API spec到目前为止,它适用于我直接返回 ActionResult 的所有情况,例如 ComplexTypeJSON。我试图让它在像 Comp
我在 Storyboard 上创建了一个带有一个 UITextField 的自定义 UIViewController。在 viewDidLoad 上,我将 UITextFIeld 设置为 become
我已经看到关于 valueless_by_exception 方法的 cppreference 的以下注释: A variant may become valueless in the followi
我是一名优秀的程序员,十分优秀!