0

我在 OpenShift 中运行某个软件,它由两个 pod 组成。该软件有一个许可限制,只允许两个实例。除此之外,两个吊舱必须基于相同的图像,因为这是我必须遵循的内部设计规则。

问题是两个 pod 通过共享路径进行通信,并且每个 pod 都有自己的数据位置。将其视为以下路径:

  1. /数据/共享
  2. /数据/实例1
  3. /数据/实例2

如何确保我放置在 pod1 中的某个配置文件始终配置为使用/data/instance1,并且 pod2 始终配置为使用,/data/instance2 即使两个 pod 中的任何一个被删除并再次删除?我已经尝试根据主机名执行此操作,但因为它会定期更改并且不遵循可重现的逻辑(softwarename-tzyjkd例如),这种方法失败了。

理想情况下,我可以访问 openshift 提供的一种“实例计数器”。

从普通镜像到容器和pod

4

1 回答 1

1

查看为每个实例创建单独的部署配置,并设置传入的环境变量以不同地表示每个实例的路径。让应用程序使用环境变量来知道要使用哪个路径。

如果需要在两个实例之间对流量进行负载平衡,则设置路由以将流量以所需的比率引导到两个实例。

例如:

oc new-build getwarped/s2i-httpd-server~https://github.com/getwarped/httpd-parked-domain.git --name mysite

oc new-app mysite --name mysite1 --env DATA=instance1

oc new-app mysite --name mysite2 --env DATA=instance2

oc expose svc/mysite1 --name mysite

oc set route-backends mysite mysite1=50 mysite2=50

这会给你留下:

$ oc get all -o name
buildconfig/mysite
build/mysite-1
imagestream/mysite
imagestream/s2i-httpd-server
deploymentconfig/mysite1
deploymentconfig/mysite2
replicationcontroller/mysite1-1
replicationcontroller/mysite2-1
route/mysite
service/mysite1
service/mysite2
pod/mysite-1-build
pod/mysite1-1-64c6a
pod/mysite2-1-v3lf4

$ oc get routes
NAME      HOST/PORT                      PATH      SERVICES                    PORT       TERMINATION
mysite    mysite-book.127.0.0.1.xip.io             mysite1(50%),mysite2(50%)   8080-tcp

顺便说一句,如果您的软件认为某些东西已经在使用许可证,甚至都无法启动,那么您将需要将部署策略从滚动更改为重新创建。这意味着现有实例将在启动新实例之前关闭。因为尽管您有两个,但您始终可以在重新启动一个之前调整流量路由到另一个的比率。这样,当实例完成时,您将不会有请求失败。您可以在重启一个后重新平衡流量,或者将所有流量切换到它并重新启动另一个。

于 2016-10-25T22:45:16.207 回答