openshift/origin学习记录(5)——添加Template(模板)并基于模板部署应用

学习资料来源于官方英文文档与《开源容器云OpenShift》一书,因为刚开始学习,不确定博客的正确性,以下内容仅供参考。

本部分是在openshift/origin学习记录(1)——基于二进制文件的安装(单机版)的基础上进行。

添加模板

为了满足用户对复杂应用部署的需求,提供应用部署的效率,openshift引入了应用部署模板(Template)的概念。

通过Template,可以定义一个或多个需要部署的镜像,定义依赖的对象,定义可供用户输入的配置参数项。

  • 以管理员登录,并切换到openshift工程。
# oc login -u system:admin
# oc project openshift

openshift是一个特殊的项目,在这个项目下创建的所有Image Stream及Template对集群内所有的用户和项目可见。

如果Image Stream及Template在其他项目下创建,则只能在创建这些对象的项目中可见。

https://github.com/openshift/origin/tree/release-3.6/examples/quickstarts下有官方提供的一系列模板可供下载使用。

以cakephp-mysql.json为例。

# oc create -f https://raw.githubusercontent.com/openshift/origin/release-3.6/examples/quickstarts/cakephp-mysql.json -n openshift
# oc get template -n openshift

部署应用

以上文导入的cakephp-mysql模板为例。

  • 登录openshift web控制台。新建工程。名为hello-world-php,项目显示名为Hello World Php。
  • 在服务目录过滤器里输入cake,找到cakephp-mysql-example模板。
  • 选择cakephp-mysql-example模板,跳转至Template的参数输入页面。

主要修改Application Hostname(暴露的主机名,将路由到CakePHP的服务)。这里我填写的是master.example.com。

需要注意,master.example.com只是测试域名,并不能被互联网域名解析器解析。 需要修改浏览器所在机器的hosts文件,手动添加解析将master.example.com指向openshift集群master所在的IP地址。(多节点集群需要指向Router所在的ip) Windows系统: C:\windows\system32\drivers\etc\hosts Linux系统:/etc/hosts

  • 点击Template参数输入页面底部的Create按钮,执行部署。跳转至部署完成界面。
  • 点击Continue to overview链接。

跳转到项目的概览页面。Openshif会在后台创建相应的对象,并下载相关的镜像。

由于CakePHP应用涉及一个镜像构建的过程,即Source to Image,所以构建速度较慢。

  • 展开cakephp-mysql-example。
  • 点击view full log可以查看实时日志输出。

可以看出,Openshift会从GitHub仓库中下载指定的PHP源代码,然后将代码注入一个含PHP运行环境的镜像,最后生成一个包含PHP应用以及PHP运行环境的新镜像,并将新的镜像推送到前文部署的内部镜像仓库中。

如果构建过程中出现docker push镜像到内部镜像仓库的错误,需要检查内部镜像仓库是否正确部署与配置。即有没有忘记设置docker的--insecure-registry参数

  • 构建完成后,单击左侧菜单栏的Overview按钮,回到项目主页。

至此demo应用部署成功。

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏holer

怎样从公网访问内网Oracle数据库

本地安装了Oracle数据库,只能在局域网内访问,怎样从公网也能访问本地Oracle数据库?

1401
来自专栏程序员八阿哥

小白Pycharm使用(5):pycharm中使用anaconda

不同的操作系统都是直接的在官网中下载安装包进行下载,选择你最经常使用的Python版本进行安装,下载完之后,尽量的按照anaconda默认的行为安装,现在的版本...

3461
来自专栏holer

怎样从公网访问内网Nginx

在holer官网上申请专属的holer access key或者使用开源社区上公开的access key信息。

981
来自专栏码农笔录

docker自动化部署实战

2034
来自专栏张善友的专栏

超实用的8个Linux命令行性能监测工具

对每个系统/网络管理员来说,每天监测Linux系统性能是一项非常艰巨的任务。在IT业从事5年的Linux系统管理员后,我发现监控和保持系统正常运行真不是件容易的...

1985
来自专栏holer

如何从公网访问内网Node.js

本地安装了Node.js,只能在局域网内访问,怎样从公网也能访问本地Node.js?

1221
来自专栏晓晨的专栏

ASP.NET Core的身份认证框架IdentityServer4(3)-术语的解释

1234
来自专栏一个会写诗的程序员的博客

adb命令 - adb forward交互流程adb命令 - adb forward交互流程

命令: adb forward tcp:6100 tcp:7100 // PC上所有6100端口通信数据将被重定向到手机端7100端口server上

1273
来自专栏云计算

在Heroku上部署Node.js

今天,我们将演示如何在Heroku上部署Node.js应用。Heroku官方提供免费帐户使用,在此之上,我们最多可以托管5个应用程序。但如果你有大量需求的话,就...

3408
来自专栏跟着阿笨一起玩NET

WCF服务部署到IIS上,然后通过web服务引用方式出现错误的解决办法

本文转载:http://www.cnblogs.com/shenba/archive/2012/01/06/2313932.html

1041

扫码关注云+社区