* 免费Kubernetes 教程,绝不降低品质
* [![kuboard for kubernetes (k8s)](https://pub.idqqimg.com/wpa/images/group.png "kuboard for kubernetes (k8s)")](https://shang.qq.com/wpa/qunwpa?idkey=a2d64aa5f578fe885fce065b242afbb12eeb804a67a552f996584b464277303a)在线答疑,也可以扫描左侧导航下方的二维码加群
# 准备OCP的构建环境和部署环境
## 环境要求
Open Capacity Platform 是基于 Java Spring Cloud 的微服务架构,为了将其部署到 Kubernetes 上,我们需要准备如下环境:
* **硬件**
* 1 台 Linux 服务器,配置不低于2核4G,CentOS 7.6,(本系列教程称该机器为 master 节点)用途:
* Kubernetes master 节点
* 编译 OCP 源码并打包 docker 镜像的构建机
* 2 台 Linux 服务器,配置不低于2核4G,CentOS 7.6,(本系列教程称该机器为 worker 节点,前期可以只有一台,随着负载增加再增加节点)用途:
* Kubernetes worker 节点
* **软件**
* Kubernetes 集群及管理软件
* Kubernetes 最新版本,参考[安装Kubernetes单Master节点](https://kuboard.cn/install/install-k8s.html)
* Kuboard 最新版本,参考[安装Kuboard](https://kuboard.cn/install/install-kubernetes.html)
* Master节点
* Docker 已在安装 Kubernetes 时完成安装
* JDK 1.8
* maven
* 镜像仓库
* 选项一:在[https://hub.docker.com](https://hub.docker.com/)上注册一个账号
* 选项二:如果自己搭建 Harbor 作为镜像仓库,您可能还需要更多的 Linux 服务器
**构建环境和部署环境的结构**如下:
![kubernetes教程_OCP实战:准备OCP构建和部署环境](https://kuboard.cn/assets/img/image-20190923143654448.6a5e2ffc.png)
关于构建环境
您可以根据自己的情况将构建环境与部署环境分开,例如:
* 学习时,参考本教程,使用 kubernetes 的 master 节点完成***构建和镜像推送***
* 开发时,在自己的笔记本上完成***构建和镜像推送***
* 工作中,使用 Jenkins Pipeline 或者 gitlab-runner Pipeline 来完成***构建和镜像推送***
**构建环境和部署环境分开**
![kubernetes教程_OCP实战:准备OCP构建和部署环境-将构建环境和部署环境分开](https://kuboard.cn/assets/img/image-20190923161110141.f849cef2.png)
本文假设您已经完成了 Kubernetes 集群的安装,假设您准备在 Kubernetes master 节点上执行构建过程,并将使用简短的篇幅介绍如何在 master 节点上做好构建环境准备
* 安装 JDK 1.8
* 安装 maven 3.6.2
* 安装 git
* 下载 open-capability-platform 的代码仓库
## 在 master 节点上安装 JDK1.8
以root身份在 master 节点上执行:
~~~
yum install java-1.8.0-openjdk\* -y
~~~
## 在 master 节点上安装 maven
* 在[maven 官网](http://maven.apache.org/download.cgi)获取最新版 maven 的 binary 文件下载链接,例如 apache-maven-3.6.2-bin.tar.gz 的下载地址为`http://mirrors.tuna.tsinghua.edu.cn/apache/maven/maven-3/3.6.2/binaries/apache-maven-3.6.2-bin.tar.gz`
* 以 root 身份在 master 节点上执行:
~~~
#切换到 /root 用户目录
cd /root
# 下载 tar.gz
wget http://mirrors.tuna.tsinghua.edu.cn/apache/maven/maven-3/3.6.2/binaries/apache-maven-3.6.2-bin.tar.gz
# 解压 tar.gz
tar -xvf apache-maven-3.6.2-bin.tar.gz
~~~
* 以root身份在 master 节点上执行`vim /root/.bash_profile`修改 .bash\_profile 文件,向`PATH=`所在行的行尾增加`:/root/apache-maven-3.6.2/bin`如下所示:
~~~
# User specific environment and startup programs
PATH=$PATH:$HOME/bin:/root/apache-maven-3.6.2/bin
export PATH
~~~
您可以把 apache-maven-3.6.2 放在您自己喜欢的位置
* **检查安装结果**:退出 master 节点的 shell 终端,并重新以 root 用户登录 master 节点的 shell 终端,执行命令`mvn -version`,输出结果如下所示:
~~~
Apache Maven 3.6.2 (40f52333136460af0dc0d7232c0dc0bcf0d9e117; 2019-08-27T23:06:16+08:00)
Maven home: /root/apache-maven-3.6.2
Java version: 1.8.0_222, vendor: Oracle Corporation, runtime: /usr/lib/jvm/java-1.8.0-openjdk-1.8.0.222.b10-1.el7_7.x86_64/jre
Default locale: en_US, platform encoding: UTF-8
OS name: "linux", version: "3.10.0-957.21.3.el7.x86_64", arch: "amd64", family: "unix"
~~~
## 在-master-节点上安装-git)在 master 节点上安装 git
* 以root身份在 master 节点执行:
~~~
# 安装 git
yum install -y git
# 查看已安装版本
git version
~~~
## 在 master 节点上克隆 ocp 代码仓库
* 以root身份在 master 节点上执行:
~~~
# 切换到 /root 用户目录
cd /root
# 克隆 ocp 代码仓库
git clone https://gitee.com/owenwangwen/open-capacity-platform.git
~~~
* 以root身份在 master 节点上执行:
~~~
# 安装 tree
yum install tree -y
# 查看 ocp 代码目录
tree /root/open-capacity-platform -L 2
~~~
输出结果如下所示:
~~~
/root/open-capacity-platform
├── api-gateway
│ ├── pom.xml
│ └── src
├── business-center
│ ├── file-center
│ ├── generator-center
│ ├── pom.xml
│ ├── sms-center
│ ├── user-center
│ └── workflow-center
├── inner-intergration
│ ├── common-spring-boot-starter
│ ├── db-spring-boot-starter
│ ├── log-spring-boot-starter
│ ├── pom.xml
│ ├── rabbitmq-spring-boot-starter
│ ├── redis-spring-boot-starter
│ ├── swagger-spring-boot-starter
│ ├── uaa-client-spring-boot-starter
│ └── uaa-server-spring-boot-starter
├── job-center
│ ├── doc
│ ├── job-admin
│ ├── job-core
│ ├── job-demo
│ └── pom.xml
├── LICENSE
├── monitor-center
│ ├── admin-server
│ ├── log-center
│ ├── pom.xml
│ ├── transaction-center
│ └── zipkin-center
├── new-api-gateway
│ ├── pom.xml
│ └── src
├── oauth-center
│ ├── auth-server
│ ├── auth-sso
│ └── pom.xml
├── pom.xml
├── README.en.md
├── README.md
├── register-center
│ ├── eureka-server
│ └── pom.xml
├── sql
│ ├── 01.user-center.sql
│ ├── 02.oauth-center.sql
│ ├── 03.file-center.sql
│ ├── 04.sms-center.sql
│ ├── 05.log-center.sql
│ ├── 06.job-center.sql
│ ├── 07.workflow-center.sql
│ ├── 08.transaction-center.sql
│ └── 09.batch-center.sql
├── tuning-center
│ ├── pom.xml
│ ├── test-common-spring-boot-starter
│ ├── test-log-spring-boot-starter
│ ├── test-redis-spring-boot-starter
│ └── test-spring-boot-starter
└── web-portal
├── back-center
└── pom.xml
42 directories, 23 files
~~~
## 下一步
[构建Java项目、打包docker image、推送到docker registry](https://kuboard.cn/learning/k8s-practice/ocp/build.html)
[![kuboard for kubernetes (k8s)](https://pub.idqqimg.com/wpa/images/group.png "kuboard for kubernetes (k8s)")](https://shang.qq.com/wpa/qunwpa?idkey=a2d64aa5f578fe885fce065b242afbb12eeb804a67a552f996584b464277303a)在线答疑
![Kubernetes教程:QQ群在线答疑](https://kuboard.cn/images/kuboard_qq.png)
[如果您觉得 Kubernetes教程 有帮到您,点击此处,给个 Github Star,谢谢!](https://github.com/eip-work/kuboard-press)
- 前言
- 1.项目说明
- 2.项目更新日志
- 3.文档更新日志
- 01.快速开始
- 01.maven构建项目
- 02.环境安装
- 03.STS项目导入
- 03.IDEA项目导入
- 04.数据初始化
- 05.项目启动
- 06.付费文档说明
- 02.总体流程
- 1.oauth接口
- 2.架构设计图
- 3.微服务介绍
- 4.功能介绍
- 5.梳理流程
- 03.模块详解
- 01.老版本1.0.1分支模块讲解
- 01.db-core模块
- 02.api-commons模块
- 03.log-core模块
- 04.security-core模块
- 05.swagger-core模块
- 06.eureka-server模块
- 07.auth-server模块
- 08.auth-sso模块解析
- 09.user-center模块
- 10.api-gateway模块
- 11.file-center模块
- 12.log-center模块
- 13.batch-center模块
- 14.back-center模块
- 02.spring-boot-starter-web那点事
- 03.自定义db-spring-boot-starter
- 04.自定义log-spring-boot-starter
- 05.自定义redis-spring-boot-starter
- 06.自定义common-spring-boot-starter
- 07.自定义swagger-spring-boot-starter
- 08.自定义uaa-server-spring-boot-starter
- 09.自定义uaa-client-spring-boot-starter
- 10.自定义ribbon-spring-boot-starter
- 11.springboot启动原理
- 12.eureka-server模块
- 13.auth-server模块
- 14.user-center模块
- 15.api-gateway模块
- 16.file-center模块
- 17.log-center模块
- 18.back-center模块
- 19.auth-sso模块
- 20.admin-server模块
- 21.zipkin-center模块
- 22.job-center模块
- 23.batch-center
- 04.全新网关
- 01.基于spring cloud gateway的new-api-gateway
- 02.spring cloud gateway整合Spring Security Oauth
- 03.基于spring cloud gateway的redis动态路由
- 04.spring cloud gateway聚合swagger文档
- 05.技术详解
- 01.互联网系统设计原则
- 02.系统幂等性设计与实践
- 03.Oauth最简向导开发指南
- 04.oauth jdbc持久化策略
- 05.JWT token方式启用
- 06.token有效期的处理
- 07.@PreAuthorize注解分析
- 08.获取当前用户信息
- 09.认证授权白名单配置
- 10.OCP权限设计
- 11.服务安全流程
- 12.认证授权详解
- 13.验证码技术
- 14.短信验证码登录
- 15.动态数据源配置
- 16.分页插件使用
- 17.缓存击穿
- 18.分布式主键生成策略
- 19.分布式定时任务
- 20.分布式锁
- 21.网关多维度限流
- 22.跨域处理
- 23.容错限流
- 24.应用访问次数控制
- 25.统一业务异常处理
- 26.日志埋点
- 27.GPRC内部通信
- 28.服务间调用
- 29.ribbon负载均衡
- 30.微服务分布式跟踪
- 31.异步与线程传递变量
- 32.死信队列延时消息
- 33.单元测试用例
- 34.Greenwich.RELEASE升级
- 35.混沌工程质量保证
- 06.开发初探
- 1.开发技巧
- 2.crud例子
- 3.新建服务
- 4.区分前后台用户
- 07.分表分库
- 08.分布式事务
- 1.Seata介绍
- 2.Seata部署
- 09.shell部署
- 01.eureka-server
- 02.user-center
- 03.auth-server
- 04.api-gateway
- 05.file-center
- 06.log-center
- 07.back-center
- 08.编写shell脚本
- 09.集群shell部署
- 10.集群shell启动
- 11.部署阿里云问题
- 10.网关安全
- 1.openresty https保障服务安全
- 2.openresty WAF应用防火墙
- 3.openresty 高可用
- 11.docker配置
- 01.docker安装
- 02.Docker 开启远程API
- 03.采用docker方式打包到服务器
- 04.docker创建mysql
- 05.docker网络原理
- 06.docker实战
- 6.01.安装docker
- 6.02.管理镜像基本命令
- 6.03.容器管理
- 6.04容器数据持久化
- 6.05网络模式
- 6.06.Dockerfile
- 6.07.harbor部署
- 6.08.使用自定义镜像
- 12.统一监控中心
- 01.spring boot admin监控
- 02.Arthas诊断利器
- 03.nginx监控(filebeat+es+grafana)
- 04.Prometheus监控
- 05.redis监控(redis+prometheus+grafana)
- 06.mysql监控(mysqld_exporter+prometheus+grafana)
- 07.elasticsearch监控(elasticsearch-exporter+prometheus+grafana)
- 08.linux监控(node_exporter+prometheus+grafana)
- 09.micoservice监控
- 10.nacos监控
- 11.druid数据源监控
- 12.prometheus.yml
- 13.grafana告警
- 14.Alertmanager告警
- 15.监控微信告警
- 16.关于接口监控告警
- 17.prometheus-HA架构
- 18.总结
- 13.统一日志中心
- 01.统一日志中心建设意义
- 02.通过ELK收集mysql慢查询日志
- 03.通过elk收集微服务模块日志
- 04.通过elk收集nginx日志
- 05.统一日志中心性能优化
- 06.kibana安装部署
- 07.日志清理方案
- 08.日志性能测试指标
- 09.总结
- 14.数据查询平台
- 01.数据查询平台架构
- 02.mysql配置bin-log
- 03.单节点canal-server
- 04.canal-ha部署
- 05.canal-kafka部署
- 06.实时增量数据同步mysql
- 07.canal监控
- 08.clickhouse运维常见脚本
- 15.APM监控
- 1.Elastic APM
- 2.Skywalking
- 01.docker部署es
- 02.部署skywalking-server
- 03.部署skywalking-agent
- 16.压力测试
- 1.ocp.jmx
- 2.test.bat
- 3.压测脚本
- 4.压力报告
- 5.报告分析
- 6.压测平台
- 7.并发测试
- 8.wrk工具
- 9.nmon
- 10.jmh测试
- 17.SQL优化
- 1.oracle篇
- 01.基线测试
- 02.调优前奏
- 03.线上瓶颈定位
- 04.执行计划解读
- 05.高级SQL语句
- 06.SQL tuning
- 07.数据恢复
- 08.深入10053事件
- 09.深入10046事件
- 2.mysql篇
- 01.innodb存储引擎
- 02.BTree索引
- 03.执行计划
- 04.查询优化案例分析
- 05.为什么会走错索引
- 06.表连接优化问题
- 07.Connection连接参数
- 08.Centos7系统参数调优
- 09.mysql监控
- 10.高级SQL语句
- 11.常用维护脚本
- 12.percona-toolkit
- 18.redis高可用方案
- 1.免密登录
- 2.安装部署
- 3.配置文件
- 4.启动脚本
- 19.消息中间件搭建
- 19-01.rabbitmq集群搭建
- 01.rabbitmq01
- 02.rabbitmq02
- 03.rabbitmq03
- 04.镜像队列
- 05.haproxy搭建
- 06.keepalived
- 19-02.rocketmq搭建
- 19-03.kafka集群
- 20.mysql高可用方案
- 1.环境
- 2.mysql部署
- 3.Xtrabackup部署
- 4.Galera部署
- 5.galera for mysql 集群
- 6.haproxy+keepalived部署
- 21.es集群部署
- 22.生产实施优化
- 1.linux优化
- 2.jvm优化
- 3.feign优化
- 4.zuul性能优化
- 23.线上问题诊断
- 01.CPU性能评估工具
- 02.内存性能评估工具
- 03.IO性能评估工具
- 04.网络问题工具
- 05.综合诊断评估工具
- 06.案例诊断01
- 07.案例诊断02
- 08.案例诊断03
- 09.案例诊断04
- 10.远程debug
- 24.fiddler抓包实战
- 01.fiddler介绍
- 02.web端抓包
- 03.app抓包
- 25.疑难解答交流
- 01.有了auth/token获取token了为啥还要配置security的登录配置
- 02.权限数据存放在redis吗,代码在哪里啊
- 03.其他微服务和认证中心的关系
- 04.改包问题
- 05.use RequestContextListener or RequestContextFilter to expose the current request
- 06./oauth/token对应代码在哪里
- 07.验证码出不来
- 08./user/login
- 09.oauth无法自定义权限表达式
- 10.sleuth引发线程数过高问题
- 11.elk中使用7x版本问题
- 12.RedisCommandTimeoutException问题
- 13./oauth/token CPU过高
- 14.feign与权限标识符问题
- 15.动态路由RedisCommandInterruptedException: Command interrupted
- 26.学习资料
- 海量学习资料等你来拿
- 27.持续集成
- 01.git安装
- 02.代码仓库gitlab
- 03.代码仓库gogs
- 04.jdk&&maven
- 05.nexus安装
- 06.sonarqube
- 07.jenkins
- 28.Rancher部署
- 1.rancher-agent部署
- 2.rancher-server部署
- 3.ocp后端部署
- 4.演示前端部署
- 5.elk部署
- 6.docker私服搭建
- 7.rancher-server私服
- 8.rancher-agent docker私服
- 29.K8S部署OCP
- 01.准备OCP的构建环境和部署环境
- 02.部署顺序
- 03.在K8S上部署eureka-server
- 04.在K8S上部署mysql
- 05.在K8S上部署redis
- 06.在K8S上部署auth-server
- 07.在K8S上部署user-center
- 08.在K8S上部署api-gateway
- 09.在K8S上部署back-center
- 30.Spring Cloud Alibaba
- 01.统一的依赖管理
- 02.nacos-server
- 03.生产可用的Nacos集群
- 04.nacos配置中心
- 05.common.yaml
- 06.user-center
- 07.auth-server
- 08.api-gateway
- 09.log-center
- 10.file-center
- 11.back-center
- 12.sentinel-dashboard
- 12.01.sentinel流控规则
- 12.02.sentinel熔断降级规则
- 12.03.sentinel热点规则
- 12.04.sentinel系统规则
- 12.05.sentinel规则持久化
- 12.06.sentinel总结
- 13.sentinel整合openfeign
- 14.sentinel整合网关
- 1.sentinel整合zuul
- 2.sentinel整合scg
- 15.Dubbo与Nacos共存
- 31.Java源码剖析
- 01.基础数据类型和String
- 02.Arrays工具类
- 03.ArrayList源码分析
- 32.面试专题汇总
- 01.JVM专题汇总
- 02.多线程专题汇总
- 03.Spring专题汇总
- 04.springboot专题汇总
- 05.springcloud面试汇总
- 文档问题跟踪处理