3.5. 部署后端应用程序


以下流程部署 nationalparks,这是 national-parks-app 应用的后端组件。Python 应用程序针对 MongoDB 数据库执行 2D geo-spatial 查询,以定位和返回世界上的所有国家公园的信息。

先决条件

  • 您已部署了 parksmap 前端应用程序。

流程

  • 运行以下命令来创建 nationalparks 后端应用程序:

    $ oc new-app python~https://github.com/openshift-roadshow/nationalparks-py.git --name nationalparks -l 'app=national-parks-app,component=nationalparks,role=backend,app.kubernetes.io/part-of=national-parks-app,app.kubernetes.io/name=python' --allow-missing-images=true
    Copy to Clipboard Toggle word wrap

    输出示例

    --> Found image 9531750 (2 weeks old) in image stream "openshift/python" under tag "3.11-ubi8" for "python"
    
        Python 3.11
        -----------
    ...
    
    --> Creating resources with label app=national-parks-app,app.kubernetes.io/name=python,app.kubernetes.io/part-of=national-parks-app,component=nationalparks,role=backend ...
        imagestream.image.openshift.io "nationalparks" created
        buildconfig.build.openshift.io "nationalparks" created
        deployment.apps "nationalparks" created
        service "nationalparks" created
    --> Success
        Build scheduled, use 'oc logs -f buildconfig/nationalparks' to track its progress.
        Application is not exposed. You can expose services to the outside world by executing one or more of the commands below:
         'oc expose service/nationalparks'
        Run 'oc status' to view your app.
    Copy to Clipboard Toggle word wrap

3.5.1. 公开后端服务

与为外部客户端公开前端服务的方式类似,现在您必须通过创建路由来公开后端服务。

先决条件

  • 您已部署了 nationalparks 后端应用程序。
  • cluster-admin 或项目级别的 admin 权限。

流程

  1. 运行以下命令,创建一个路由来公开 nationalparks 后端应用程序:

    $ oc create route edge nationalparks --service=nationalparks
    Copy to Clipboard Toggle word wrap
  2. 运行以下命令标记 nationalparks 路由:

    $ oc label route nationalparks type=parksmap-backend
    Copy to Clipboard Toggle word wrap

    应用程序代码预期 nationalparks 路由使用 type=parksmap-backend 进行标记。

返回顶部
Red Hat logoGithubredditYoutubeTwitter

学习

尝试、购买和销售

社区

关于红帽文档

通过我们的产品和服务,以及可以信赖的内容,帮助红帽用户创新并实现他们的目标。 了解我们当前的更新.

让开源更具包容性

红帽致力于替换我们的代码、文档和 Web 属性中存在问题的语言。欲了解更多详情,请参阅红帽博客.

關於紅帽

我们提供强化的解决方案,使企业能够更轻松地跨平台和环境(从核心数据中心到网络边缘)工作。

Theme

© 2025 Red Hat