前言
新的系列文章: 《开发者openshift4使用入门教程》
我所在的公司目前使用的K8S是RedHat的OpenShift 4, 虽然有官方文档, 并且有专门的 Develop 章节, 但是实际使用发现, 开发者(特别是中国的开发者, 传统行业金融行业的开发者)关注的功能和章节相去甚远. 所以我专门针对开发经常问我的问题, 总结出来这个系列文章.
希望对在使用OpenShift 4的开发者会有所帮助. ❤️❤️❤️
一 概述
一句话总结本文内容:
如何将NGINX部署到OpenShift 4, 可以有以下2种方式
- 直接将本地的NGINX文件夹(包括: 静态文件和nginx配置)部署到OpenShift 4
- 从Git仓库拉取并部署到OpenShift 4
二 准备工作
要部署到OpenShift 4, 你需要有:
- OpenShift 4 的租户(Project) (如果你是OpenShift 4管理员,你自然就有;如果你是使用者,请向管理员申请租户)
oc
命令行工具(CLI), 下载并解压, 并加入到PATH
中.- linux版本
- mac版本
- windows版本
- 互联网链接在这里
- 登录到OpenShift 4
- 环境命令如下:
oc login -u <username> -p <password> --server=https://api.caas.example.com.cn:6443
1
- 环境命令如下:
- 跳转到对应的项目租户:
oc project <your-project>
三 目录结构
要使用容器部署, NGINX应用的目录结构必须是:
代码语言:javascript复制.
├── html及各类静态文件和文件夹
├── nginx-cfg(对应conf.d)
│ └── nginx-xxx.conf
├── nginx-default-cfg(对应default.d)
│ └── nginx-default-xxx.conf
└── nginx.conf
具体示例如下:
代码语言:javascript复制.
├── af73d675832c7dfa67ada93b4db8eb1d.png
├── assetView.f3fa585e66eef9151f60.bundle.js
├── b02bdc1b846fd65473922f5f62832108.ttf
├── favicon.ico
├── index.html
├── main.css
├── main.f3fa585e66eef9151f60.bundle.js
├── nginx-cfg
│ └── nginx-amp.conf
├── nginx-default-cfg
│ └── nginx-default.conf
├── nginx.conf
├── public
│ ├── index.html
│ └── recommend
├── static
│ ├── favicon.ico
│ └── fnt-puhuiti
├── vendors.css
├── vendors.f3fa585e66eef9151f60.bundle.js
└── vendors.f3fa585e66eef9151f60.bundle.js.gz
四 本地文件夹形式部署
- 创建新NGINX应用:
oc new-app --name=nginx --binary=true --image-stream=nginx-114-rhel7:latest
2 - 从本地上传相关文件. 构建完成后会自动触发trigger, 滚动部署nginx应用新版本.
- 命令如下:
oc start-build nginx --from-dir </path/to/your/app-name/>
- 运行命令后, 输出如下: 3
- 命令如下:
Uploading directory "." as binary input for the build .....
Uploading finished
build.build.openshift.io/nginx started
代码语言:javascript复制replication controller "nginx-x" successfully rolled out
- 创建域名: 要从浏览器通过网页访问部署的NGINX, 必须将刚部署的应用创建域名后暴露(expose)到OpenShift 4 集群外部(公司内网或互联网). 命令为:
oc expose svc nginx
- 之后可以通过如下命令查看域名并访问:
$ oc get route nginx
NAME HOST/PORT PATH SERVICES PORT TERMINATION WILDCARD
nginx nginx-<project-name>.caas.ccic-test.com.cn None nginx 8080-tcp
4.1 更新应用
NGINX创建后, 后续更新, 执行如下命令:
代码语言:javascript复制$ oc start-build nginx --from-dir </path/to/your/app-name/>
Uploading directory "." as binary input for the build .....
Uploading finished
build.build.openshift.io/nginx started
$ oc logs -f build/nginx
...
$ oc rollout status dc/nginx
replication controller "nginx-x" successfully rolled out
前提: </path/to/your/app-name/>
下的NGINX相关文件已经更新.
五 Git仓库直接部署
Git 仓库部署更简单, 输入以下信息即可: (前提是目录结构和第三章节示例保持一致)