企业级的特点是有多个系统,且可能存在各种语言的系统,例如:Java、.Net、Ruby,还可能包括一些数据库存储过程、ETL等等。都可能存在常量和全局变量,如果都是写在系统内部,那么常量与全局变量将仅局限于一个系统内部,多个系统之前就可能出现一个地方修改了,而另一个地方未修改的问题。
为了实现多系统间统一,那么最好的办法就是采用统一的数据库定义来确保数据统一。
1、常量
常量的内容存储在DB中,在启动时通过静态加载的方式预先初始化常量,例如:static{CONT = db.load('CONT');}
2、全局变量
全局变量是可能发生变更,例如:某一个IP地址,如果这台机器挂了,那么可能选择一个备用的地址。这时就先在数据库中更新,然后各系统定期更新。 全局变量也是类似常量一样在启动时到数据库加载,但其区别就是在于:全局变量是变化较少的数据,而不是不变量,例如:男、女肯定是常量吧,而某个特定的IP地址是否可能发生变化?对于有多个应用实例的情况下,那么其更新方法有两种不同:
1)定期到数据库中轮询,看看是否有变化,如果有变化那么就加载,这种设计有一个原则,肯定是整个系统提供一套统一的机制,例如:在数据库中建立一个统一的数据表,用于记录更新情况,轮询就检查这张表,如果有数据变化,那么就调用具体的子类进行实际的更新;
2)第一种方法间隔可能比较长,例如:定期30分钟更新一次,但如果需要及时更新那么怎么办,就是在启动时注册IP地址和端口,在有更新的时候自动通知所有订阅者更新了。
为了实现多系统间统一,那么最好的办法就是采用统一的数据库定义来确保数据统一。
1、常量
常量的内容存储在DB中,在启动时通过静态加载的方式预先初始化常量,例如:static{CONT = db.load('CONT');}
2、全局变量
全局变量是可能发生变更,例如:某一个IP地址,如果这台机器挂了,那么可能选择一个备用的地址。这时就先在数据库中更新,然后各系统定期更新。 全局变量也是类似常量一样在启动时到数据库加载,但其区别就是在于:全局变量是变化较少的数据,而不是不变量,例如:男、女肯定是常量吧,而某个特定的IP地址是否可能发生变化?对于有多个应用实例的情况下,那么其更新方法有两种不同:
1)定期到数据库中轮询,看看是否有变化,如果有变化那么就加载,这种设计有一个原则,肯定是整个系统提供一套统一的机制,例如:在数据库中建立一个统一的数据表,用于记录更新情况,轮询就检查这张表,如果有数据变化,那么就调用具体的子类进行实际的更新;
2)第一种方法间隔可能比较长,例如:定期30分钟更新一次,但如果需要及时更新那么怎么办,就是在启动时注册IP地址和端口,在有更新的时候自动通知所有订阅者更新了。