环境配置文件布局解决方案

简介: 一般来说,我们有开发环境(DEV)、测试环境(TEST)、生产环境(PROD)。 怎样解决自动根据不同环境切换相应的配置文件的问题呢?   本文以PHP为例。   最简单的方法,是确保三种环境的服务器可以给出一模一样的设置给程序,如数据库地址、端口、数据库名、用户名密码等。

一般来说,我们有开发环境(DEV)、测试环境(TEST)、生产环境(PROD)。

怎样解决自动根据不同环境切换相应的配置文件的问题呢?

 

本文以PHP为例。

 

最简单的方法,是确保三种环境的服务器可以给出一模一样的设置给程序,如数据库地址、端口、数据库名、用户名密码等。但在资源紧缺的环境下可操作性不强。

 

首先,无论如何,建三个对应的配置文件是必须的。

如:

config.dev.php

config.test.php

config.prod.php/config.php

 

然后,便是自动切换的问题。

其实,正常情况下,这三者的运行环境可能都相同,无法简单的通过环境的不同进行区分。除非那种极客型的,如修改php代码,不同环境增加不同环境变量标示手动编译PHP,这样运行环境中就具备了区分标示,然后封装一个判断方法。同样在资源紧缺的情况下,可操作性不强。

剩下比较可行的,就是通过文件软连接的方式。*nix、Windows都有办法创建文件软连接,系统无论有几个配置文件,在运行时都只需要一个文件,所以在不造成相应程序大幅改动代码来实现切换的话,就是这种方案了:

config.dev.php

config.test.php

config.prod.php

 

然后手动在每种环境创建软连接config.php,指向对应的文件config.xxx.php。

实在像虚拟主机,就直接在服务器上把config.prod.php 改成 config.php

 

PS

在大型的应用中,异常复杂的无数资源需要调用的环境,专门做一个资源管理与调度的系统,然后针对每种资源如mysql服务编号命名,然后在应用环境中,调用统一的api来获取配置资源。这种方式,其实还是要在资源比较充足的情况下,尤其测试环境与正式环境不能在一台机器上。这样,可以根据应用请求的ip或端口来判断:那台是测试服务器,我就返回一个测试用的配置数据给它;这台是正式环境,就返回正式的配置。

 

PPS

有一个《2011PHP技术高峰论坛演讲-张宴》这样的课件,从当初发布到网上,期间看了很多次,里面演示的很多东西,都有很强的启发意义。

 

目录
相关文章
|
4月前
|
运维 搜索推荐 Devops
企业构建平台工程的路径与方案
探讨企业如何构建自己的平台工程。
102924 0
|
8月前
|
Java 数据库连接 应用服务中间件
MaBatis核心配置文件
MaBatis核心配置文件
42 0
|
11月前
|
存储 小程序 Shell
【平台开发】技术整合思考(一)——启动配置
【平台开发】技术整合思考(一)——启动配置
79 0
|
11月前
|
XML 开发框架 JSON
03.【.netcore Configuration】新一代的配置系统Configuration在支持多数据源,热更新,层级化方面代码快速实践
03.【.netcore Configuration】新一代的配置系统Configuration在支持多数据源,热更新,层级化方面代码快速实践
92 0
|
项目管理 C++
VS2010一个解决方案下新建多个项目出现的问题和方法
VS2010一个解决方案下新建多个项目出现的问题和方法
157 0
VS2010一个解决方案下新建多个项目出现的问题和方法
|
C++
配置 C 和 C++ 环境
配置 C 和 C++ 环境
101 0
|
数据库
插件配置设计
插件配置设计
77 0
|
Java 开发工具 Windows
四、实现生产、开发配置文件分离
实现生产、开发配置文件分离
123 0
四、实现生产、开发配置文件分离
|
NoSQL 关系型数据库 MySQL
因切换多个版本环境 导致SpringBoot核心配置文件绿色叶子变成Properties文件 解决方案
在这个问题上我走了很多坑 我是一个大二的学生 我这边一会班级代码 一会自己的网站项目代码 一会又是比赛的工程代码 环境都不一样切换的时候遇到了好多问题 以下是我的一个对标题的一个总结
因切换多个版本环境 导致SpringBoot核心配置文件绿色叶子变成Properties文件 解决方案