# 准备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 集群及管理软件
    • Master节点
      • Docker 已在安装 Kubernetes 时完成安装
      • JDK 1.8
      • maven
    • 镜像仓库
      • 选项一:在 https://hub.docker.com 上注册一个账号
      • 选项二:如果自己搭建 Harbor 作为镜像仓库,您可能还需要更多的 Linux 服务器

构建环境和部署环境的结构 如下:

kubernetes教程_OCP实战:准备OCP构建和部署环境

关于构建环境

您可以根据自己的情况将构建环境与部署环境分开,例如:

  • 学习时,参考本教程,使用 kubernetes 的 master 节点完成 构建和镜像推送
  • 开发时,在自己的笔记本上完成 构建和镜像推送
  • 工作中,使用 Jenkins Pipeline 或者 gitlab-runner Pipeline 来完成 构建和镜像推送

构建环境和部署环境分开

kubernetes教程_OCP实战:准备OCP构建和部署环境-将构建环境和部署环境分开

本文假设您已经完成了 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
1

# 在 master 节点上安装 maven

  • maven 官网 获取最新版 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
    
    1
    2
    3
    4
    5
    6
  • 以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
    
    1
    2
    3
    4
    5

    TIP

    您可以把 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"
    
    1
    2
    3
    4
    5

# 在 master 节点上安装 git

  • 以root身份在 master 节点执行:
    # 安装 git
    yum install -y git
    # 查看已安装版本
    git version
    
    1
    2
    3
    4

# 在 master 节点上克隆 ocp 代码仓库

  • 以root身份在 master 节点上执行:

    # 切换到 /root 用户目录
    cd /root
    # 克隆 ocp 代码仓库
    git clone https://gitee.com/owenwangwen/open-capacity-platform.git
    
    1
    2
    3
    4
  • 以root身份在 master 节点上执行:

    # 安装 tree
    yum install tree -y
    # 查看 ocp 代码目录
    tree /root/open-capacity-platform -L 2
    
    1
    2
    3
    4

    输出结果如下所示:

    /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
    
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    58
    59
    60
    61
    62
    63
    64
    65
    66
    67
    68

# 下一步

构建Java项目、打包docker image、推送到docker registry