如何快速地在上千台服务器上部署一项服务

如何快速地在上千台服务器上部署一项服务,第1张

部署的过程,本文只说明从一个打好包的二进制文件或jar包(这里简称服务器程序压缩文件)到这个服务器程序在所有服务器上运行的过程。

这个过程,可分为如下几个阶段:

1.将服务器程序压缩文件传输到所有的服务器上

2.在所有的服务器上将服务器程序压缩文件解压到特定的路径

3.在所有的服务器上执行服务器程序

4.如果发布的服务器程序出现问题,回滚.

====================================================

这其中,涉及到如下几种需求:

1.免登陆

2.将文件从一台服务器传输到所有的服务器上,实现了这种需求,就可以将服务器程序压缩文件传输到所有的服务器上

3.在一台服务器远程执行命令,使所有的服务器都能够执行该命令,实现了这种需求,就可以在所有的服务器上将服务器程序压缩文件解压到特定的路径,并所有的服务器上执行服务器程序。

1.免登陆由于各种文章和Blog介绍较多,这里就不再涉及。

2.如何将文件从一台服务器传输到所有的服务器上

#! /bin/sh

#tf.sh

IPS=(ip地址1 ip地址2 ip地址3 ...)

for ip in ${IPS[*]}

do

do

echo "----Transfer File in $ip----"

scp $1 $ip:$2

done

3.如何在一台服务器上远程远程执行命令,是的所有的服务器都能够执行该命令

#! /bin/sh

#ec.sh

IPS=(ip地址1 ip地址2 ip地址3 ...)

for ip in ${IPS[*]}

do

do

echo "----Execute Command in $ip----"

ssh $ip $1

done

=======================================================

1.将服务器程序压缩文件传输到所有的服务器上

tf.sh /home/admin/server2.0.tar.gz /home/admin/

2.在所有的服务器上将服务器程序压缩文件解压到特定的路径

ec.sh "tar -zxvf /home/admin/server2.0.tar.gz"

3.在所有的服务器上执行服务器程序

ec.sh "sh /home/admin/server2.0/run.sh"

4. 回滚

ec.sh "sh /home/admin/server1.0/rollback.sh"

随着互联网技术的不断发展,我们在进行服务器开发方面也掌握了很多的开发部署技术。

今天,四川IT培训http://www.kmbdqn.cn/就给大家简单来介绍一下,都有哪些服务器开发部署方法是值得我们使用的。

停机部署停机部署其实是简单粗暴的方式,就是简单地把现有版本的服务停机,然后部署新的版本。

在一些时候,我们必需使用这样的方式来部署或升级多个服务。

比如,新版本中的服务使用到了和老版本完全不兼容的数据表的设计。

这个时候,我们对生产有两个变更,一个是数据库,另一个是服务,而且新老版本互不兼容,所以只能使用停机部署的方式。

这种方式的优势是,在部署过程中不会出现新老版本同时在线的情况,所有状态完全一致。

停机部署主要是为了新版本的一致性问题。

这种方式不好的问题就是会停机,对用户的影响会很大。

所以,一般来说,这种部署方式需要事前挂公告,选择一个用户访问少的时间段来做。

蓝绿部署蓝绿部署与停机部署大的不同是,其在生产线上部署相同数量的新的服务,然后当新的服务测试确认OK后,把流量切到新的服务这边来。

蓝绿部署比停机部署好的地方是,它无需停机。

我们可以看到这种部署方式,就是我们说的预发环境。

在我以前的金融公司里,也经常用这种方式,生产线上有两套相同的集群,一套是Prod是真实服务的,另一套是Stage是预发环境,发布发Stage,然后把流量切到Stage这边,于是Stage就成了Prod,而之前的Prod则成了Stage。

有点像换页似的。

这种方式的优点是没有停机,实时发布和升级,也避免有新旧版本同时在线的问题。

但这种部署的问题就是有点浪费,因为需要使用双倍的资源(不过,这只是在物理机时代,在云计算时代没事,因为虚拟机部署完就可以释放了)。

另外,如果我们的服务中有状态,比如一些缓存什么的,停机部署和蓝绿部署都会有问题。

滚动部署滚动部署策略是指通过逐个替换应用的所有实例,来缓慢发布应用的一个新版本。

通常过程如下:在负载调度后有个版本A的应用实例池,一个版本B的实例部署成功,可以响应请求时,该实例被加入到池中。

然后,版本A的一个实例从池中删除并下线。

这种部署方式直接对现有的服务进行升级,虽然便于操作,而且在缓慢地更新的过程中,对于有状态的服务也是比较友好的,状态可以在更新中慢慢重建起来。

但是,这种部署的问题也是比较多的。

在发布过程中,会出现新老两个版本同时在线的情况,同一用户的请求可能在新老版中切换而导致问题。


欢迎分享,转载请注明来源:夏雨云

原文地址:https://www.xiayuyun.com/zonghe/759675.html

(0)
打赏 微信扫一扫微信扫一扫 支付宝扫一扫支付宝扫一扫
上一篇 2023-08-18
下一篇2023-08-18

发表评论

登录后才能评论

评论列表(0条)

    保存