千里马平台采用分布式数据库(指大平台模式),各业务使用各自的数据库,例如客户关系管理使用数据库zcrm_core,财务系统使用zfms_core,各业务后台程序只联各自业务库,完成各自领域内的事务。机构、人员这些核心数据存储在qlm_core中。业务数据存储机构、人员时只存储对应ID。需要获取具体信息时,前台可以通过id访问对应基础数据服务即可,但是后端想要获取具体数据就需要分成两种情况:
基础数据在本业务链接的数据库中(包括基础服务本身、采用紧凑模式时各业务后台);基础数据不在本业务链接的数据库中。实际编程时要一套代码适应多种模式,平台采用的方式是统一API模式。
public class HRAPI {
@Autowired
private OrgInfoService orgInfoService;
@Autowired
private PersonInfoService personInfoService;
@Autowired
private HRFeignClient hrFeignClient;
public OrgInfoDto findOrgBasicInfoById(String orgID){
if ("local".equals(QLMContants.HRSource)){
OrgBasicInfo org=this.orgInfoService.findOrgBasicInfoById(orgID);
if (org!=null){
return org.toOrgInfoDto();
}
else{
return null;
}
}
else{
RequestInfo req=new RequestInfo();
req.init();
req.setTag(orgID);
ResponseResult result= hrFeignClient.findOrgBasicInfoById(req);
if (result!=null && result.isSuccess()){
return result.getData();
}
else{
i服务器托管网f (result!=nu服务器托管网ll){
CommonsUtil.recordLog("HRAPI.findOrgBasicInfoById msg="+result.getMsg());
}
return null;
}
}
}
通过qlm.HRSource配置为local 还是 server来区分具体情况。另本地实现、远程feign实现中都要实现先取缓存再取数据库的逻辑。
服务器托管,北京服务器托管,服务器租用 http://www.fwqtg.net
机房租用,北京机房租用,IDC机房托管, http://www.fwqtg.net
为什么程序员要有跨行业视角呢?我发现好一些程序员对于自己35岁以后该干什么毫无概念。我一个前同事在华为待了11年,如今也快40岁了,有一次他跟我说,如果被裁了他不知道自己该去干嘛,岁数已经这么大了,目前在一家外包公司带领团队。 我自己虽然还年轻,但是我总会思考…