项目部署在服务器上首先要解决linux链接问题,java链接linux使用jsch与ganymed-ssh2皆可,问题在于通过跳板机访问目标服务器时,有的跳板机管理这多个服务器,因此可能需要选择目标服务器,这是自动化部署不好实现的一个点,现有两种方法可尝试,一是固定登陆流程,也就是选择目标服务器时让java自动输入选择信息,而这些信息存储到数据库内。还有一种是将这些信息通过wensocket传递给前端,让前端去手动选择。
连接上后就要部署了,单机部署一般来说只需要一个项目信息和一个服务器信息就可以了,但为了提高接口通用性,可以传输一个项目信息,多个服务信息,应用和每个服务器之间还应该有一个专有的配置文件,这样可以一个应用同时在多个服务器上部署,同时在每个服务器上部署时的差异性可以通过配置文件解决。
部署过程中也要考虑一些问题:
1. 首先部署路径不存在问题,即在部署前应当先检查路径是否存在,不存在新建或者放弃部署。
2. 部署时部署路径内存在和项目同名的文件夹,这样就要考虑只是同名文件还是已经部署过了,如果是部署过了,是更新代码还是本次部署不执行任何操作。
3. 多服务器同时部署过程中,若某个服务器在部署过程中出了问题要能检测到,之后还要决定是继续部署下去还是停止部署,对于已部署的服务器也能当能够保存已部署的信息,即无论部署结果如何,都当能够记录部署结果。
项目部署过后还可能会更新代码,此过程中也有必须要解决的问题:
1. 代码更新时要先检查项目是否部署过,要坚信一点,任何情况都可能发生,因此,即使有把握确定已经部署过了,这个步骤还是不应该省略的。
2. 代码更新时可能存在更新条件,例如使用git更新代码,那么就要考虑服务器本地git仓库是否存在,存在的话,git地址是否正确,要拉取哪个分支,需不需要账号密码等,根据不同的更新方式会有不同的预先条件,这些条件要首先判断。
3. 项目可能存在多个服务器,如果多个服务器同时更新,那么就有了和多服务器部署一样的问题,
多服务器拉取代码时某个服务器失败问题,同样它也应当记录代码更新结果,并能够处理某个服务器异常时的问题。