2) 移动Agent的重定位。移动Agent在完成客户Agent所提出的任务时,由于所需的资源可能分布在网络不同的节点上, Agent需要在网络中移动。在移动数据库系统中,移动客户端的位置通常不断发生变化,这时,Agent也需要根据移动客户端的位置重新在网络中进行定位,从而缩短与移动客户端的距离,达到减少通信时间以及网络通信开销的目的。对于移动Agent的重定位方法可以采取如下方式:(1)通过使用位置服务器。当移动Agent创建时,在相应的位置服务器中注册当前位置,当移动Agent发生位置变化时,要在位置服务器中更新自己的位置信息,要定位所需的移动Agent通过向位置服务器查询即可。(2)通过跟踪移动Agent的移动路径。移动Agent迁移时,记录下移动Agent的迁移路径,从而可以根据路径来定位所需的移动Agent。(3)通过发送广播消息,采取与局域网中ARP协议类似的方法,向系统内所有节点发送广播消息,由符合的条件的移动 Agent发回响应消息。
3) 并发操作的控制。嵌入式移动数据库在实际应用中必须解决好数据的一致性[4],在移动数据库系统中,有时存在多个Agent并发访问共享信息的情况,为了保证数据的一致性,需要对并发操作进行正确的控制,目的是为了避免出现使数据处于不一致状态的并发事物调度。在基于移动Agent的系统中,既要维护本地数据库系统的一致性,也要维护网络节点上数据库系统的一致性。并发控制可以借助DBMS本身的功能来完成,因为目前一般的数据库管理系统都有较好的并发控制功能,同时也可借助一些开发工具来实现并发控制。相对于传统的数据库系统,Agent并发控制相对较复杂,可能存在网络节点上的数据库不完全接受Agent的控制、本地数据库与网络节点上的数据库之间存在相互约束关系等一些影响因素。
4)故障的恢复。在基于移动Agent的移动数据库系统中,故障恢复较传统的数据库系统也相对复杂一些,需要恢复网络节点上的各个数据库中的数据、恢复每个Agent的本地数据以及运行时的环境。对于网络节点上的各个数据库以及每个Agent的本地数据的故障恢复可以借助DBMS本身的功能来完成。对于Agent运行时的环境的恢复可以通过专门为对应的Agent新建一个数据库来维护运行时的环境,当Agent需要对数据进行更新操作时,先更新在为其新建的那个数据库中,当整个事物完成时再提交数据给本地数据库。
5 结束语
针对移动数据库具有的移动性、断接性、网络条件多样性、网络通信的非对称性、移动计算机的弱电源能力等特性,将移动Agent技术引入到移动数据库中,移动Agent计算模式能有效的减少网络通信流量、减少访问服务器的延迟、支持断接操作、支持异步计算等,使得移动Agent的优点得到了很大的发挥,有助于实现移动数据库的各种操作。由于移动Agent技术本身还处于发展过程中,应用移动Agent来完善移动数据库技术还有待于更加深入的研究和探索。