转自:http://www.cnblogs.com/zhangning/p/7251810.html

OpenShift 集群搭建指南

v1.0

  1. 搭建Hyper-v虚拟机或物理机

  2. 配置物理机静态IP,启用Hyper-v服务。
  3. 规划服务器节点

节点

说明

主机名

IP

Master

主控制节点

openshiftmaster.dynastech.com

192.168.30.95

Etcd

协调服务节点

openshiftetcd.dynastech.com

192.168.30.96

Node1

计算节点1

openshiftnode1.dynsatech.com

192.168.30.102

Node2

计算节点2

openshiftnode2.dynastech.com

192.168.30.98

Node3

计算节点3

openshiftnode3.dynastech.com

192.168.30.110

  1. 新建虚拟机master节点1个
  2. 新建Etcd节点1或3个(奇数个),负责分布式协调
  3. 新建Node节点若干,这里示例为3台
  4. 为每台虚拟机配置 旧版网络适配器

  1. 启动各个虚拟机安装Centos7系统

校验并安装centos linux 7系统

等待校验完成

  1. 选择安装语言

  1. 选择安装功能
    1. 软件选择

      (这里可以选择桌面版,如下图,服务器建议最小安装)

    2. 安装位置

  2. 配置网络和主机名

  3. 下一步,开始安装
  4. 配置root密码

  5. 启动其他节点执行同样的安装,配置不同的主机名和网络地址。
  6. 安装完毕

  7. 配置虚拟机基础环境

  8. 我本机是windows安装Xshell5.
  9. 配置域名解析
    1. 修改DNS服务器指向 或者b
    2. 修改节点本地/etc/hosts文件

      这里我为了测试方便,直接修改各个节点hosts文件

      用xshell5连接各个节点

      进入编辑vi /etc/hosts

      开始编辑按insert

      编辑完成esc,

      保存并退出:wq

      强制退出不保存!q

  10. 配置OpenShift 环境依赖软件

  11. 所有节点执行:

[root@所有节点 ~]# yum install -y lrzsz git wget net-tools bind-utils iptables-services bridge-utils bash-completion

[root@所有节点 ~]# yum install -y docker

  1. 检查安装情况
    1. iptables网络

      [root@openshiftectd ~]# systemctl start iptables

      [root@openshiftectd ~]# systemctl enable iptables

    2. docker 安装情况

  2. 软件安装完毕后,关闭虚拟机,为每个节点增加一块硬盘作为docker数据存储位置

  3. 增加硬盘完毕,重新启动所有节点,配置docker存储位置
    1. 查看硬盘信息

      命令: fdisk -l

      如图所示,添加的数据盘挂载在/dev/sdb目录下

    1. docker配置
      1. 编辑docker存储配置位置

      [root@所有节点 ~]# vi /etc/sysconfig/docker-storage-setup

    [root@所有节点 ~]# docker-storage-setup

    1. 每个节点修改docker镜像站点

    vi /etc/sysconfig/docker

    追加参数:

    --registry-mirror=https://docker.mirrors.ustc.edu.cn

    1. 增加docker开机启动服务

      systemctl enable docker

    2. 启动docker

      systemctl start docker

    3. 查看docker服务情况

      systemctl status docker

  1. 配置OpenShift Etcd节点

[root@openshiftectd ~]# yum install -y etcd

[root@openshiftectd ~]# systemctl enable etcd

[root@openshiftectd ~]# systemctl start etcd

  1. 配置OpenShift Master节点

  2. 安装EPEL仓库

    下载安装包

    http://mirrors.neusoft.edu.cn/epel/7/x86_64/e/

    上传到master

    [root@openshiftmaster ~]# yum install -y epel-release-7-10.noarch.rpm

  3. 安装ansible pyOpenSSL

    [root@openshiftmaster ~]# yum install -y --enablerepo=epel ansible pyOpenSSL

  4. 配置各个节点和master节点的互信
    1. 生成密钥

      [root@openshiftmaster ~]# ssh-keygen -f /root/.ssh/id_rsa -N ''

    1. 配置ssh验证

    [root@openshiftmaster ~]# vi /etc/ssh/ssh_config

    StrictHostKeyChecking no

    UserKnownHostsFile /dev/null

    [root@openshiftmaster ~]# ssh-copy-id -i ~/.ssh/id_rsa.pub openshiftmaster.dynastech.com

    [root@openshiftmaster ~]# ssh-copy-id -i ~/.ssh/id_rsa.pub openshiftetcd.dynastech.com

    [root@openshiftmaster ~]# ssh-copy-id -i ~/.ssh/id_rsa.pub openshiftnode1.dynastech.com

    [root@openshiftmaster ~]# ssh-copy-id -i ~/.ssh/id_rsa.pub openshiftnode2.dynastech.com

    [root@openshiftmaster ~]# ssh-copy-id -i ~/.ssh/id_rsa.pub openshiftnode3.dynastech.com

  5. 下载openshift-ansible源码

    [root@openshiftmaster ~]# git clone https://github.com/openshift/openshift-ansible

  6. 配置ansible
    1. 备份hosts

    1. 编辑hosts

    参考:https://docs.openshift.org/latest/install_config/install/advanced_install.html

    [root@openshiftmaster ~]# vi /etc/ansible/hosts

    添加如下内容

    # Create an OSEv3 group that contains the masters and nodes groups

    [OSEv3:children]

    masters

    nodes

    etcd

    # Set variables common for all OSEv3 hosts

    [OSEv3:vars]

    # SSH user, this user should allow ssh based auth without requiring a password

    ansible_ssh_user=root

    # If ansible_ssh_user is not root, ansible_become must be set to true

    #ansible_become=true

    openshift_deployment_type=origin

    # uncomment the following to enable htpasswd authentication; defaults to DenyAllPasswordIdentityProvider

    openshift_master_identity_providers=[{'name': 'htpasswd_auth', 'login': 'true', 'challenge': 'true', 'kind': 'HTPasswdPasswordIdentityProvider', 'filename': '/etc/origin/master/htpasswd'}]

    # host group for masters

    [masters]

    openshiftmaster.dynastech.com

    # host group for etcd

    [etcd]

    openshiftetcd.dynastech.com

    # host group for nodes, includes region info

    [nodes]

    openshiftmaster.dynastech.com

    openshiftnode1.dynastech.com

    openshiftnode2.dynastech.com

    openshiftnode3.dynsatech.com

  7. 开始安装集群

  8. 运行openshift-ansible

[root@openshiftmaster ~]# ansible-playbook openshift-ansible/playbooks/byo/config.yml

等待运行完成,正常情况已经配置完成。

硬件配置太低会有如下错误:

解决此错误的方法是编辑/etc/ansible/hosts

加入如下配置,跳过检查项

由于是运行在pc机上的,硬件配置不够,我在这里同时将etcd合并到了master节点(即将ectd安装到master节点并启动),在配置hosts时,将etcd指向master节点,停用了node3,配置变成如下图所示

(如果参考者的运行环境,硬件配置可以,这里不必要删减节点)

再次运行

[root@openshiftmaster ~]# ansible-playbook openshift-ansible/playbooks/byo/config.yml

即成功通过安装。

安装成功的汇总信息如下图

  1. 检查运行情况

    [root@openshiftmaster ~]# oc get nodes

  2. 集群账户管理

    [root@openshiftmaster ~]# htpasswd -b /etc/origin/master/htpasswd admin admin

  3. 登录web站点

    配置本机hosts文件,将master节点ip指向其主机名

    用admin登录web站点

    至此OpenShift集群搭建完毕!开始探索吧………

    后记:

    此文档不详尽处:

    1. docker在linux中的配置
    2. 没有详细介绍多样化集群部署,想知道更多参考官方文档

      https://docs.openshift.org/latest/install_config/install/advanced_install.html

[转]OpenShift 集群搭建指南的更多相关文章

  1. 超详细的 Redis Cluster 官方集群搭建指南

    今天从 0 开始搭建 Redis Cluster 官方集群,解决搭建过程中遇到的问题,超详细. 安装ruby环境 因为官方提供的创建集群的工具是用ruby写的,需要ruby2.2.2+版本支持,rub ...

  2. Redis Cluster 官方集群搭建指南

    安装ruby环境因为官方提供的创建集群的工具是用ruby写的,需要ruby2.2.2+版本支持,ruby安装需要指定openssl. 安装openssl $ wget https://www.open ...

  3. ZooKeeper集群-搭建指南

    第一步: 上传安装程序到Linux 这一步很简单就不在这过多说明了! 第二步: 在Linux上使用命令行安装 第三步: 修改配置文件 1.修改zoo.cfg文件 2.修改集群中各台主机的名称 1).如 ...

  4. k8s集群搭建指南

    一.简介 Ansible Docker Docker compose,docker swarm,docker machine Mesos,marathon Kubernetes(占据80%的市场) D ...

  5. 【转】kafka&zookeeper集群搭建指南

    [转自]:http://www.cnblogs.com/luotianshuai/p/5206662.html 待续...

  6. Redis 集群搭建详细指南

    先有鸡还是先有蛋? 最近有朋友问了一个问题,说毕业后去大城市还是小城市?去大公司还是小公司?我的回答都是大城市!大公司! 为什么这么说呢,你想一下,无论女孩男孩找朋友都喜欢找个子高胸大的.同样的道理嘛 ...

  7. RabbitMQ高级指南:从配置、使用到高可用集群搭建

    本文大纲: 1. RabbitMQ简介 2. RabbitMQ安装与配置 3. C# 如何使用RabbitMQ 4. 几种Exchange模式 5. RPC 远程过程调用 6. RabbitMQ高可用 ...

  8. Spark —— 高可用集群搭建

    一.集群规划 这里搭建一个3节点的Spark集群,其中三台主机上均部署Worker服务.同时为了保证高可用,除了在hadoop001上部署主Master服务外,还在hadoop002和hadoop00 ...

  9. mongodb集群搭建过程记录

    mongodb集群搭建花费比较长的时间,在此记录下过程,方便以后使用 一 软件环境 系统:ubuntu 18.04,mongodb 社区版4.2 https://docs.mongodb.com/ma ...

随机推荐

  1. 选择排序<C#>

    目标:对数组(列表等任意有序容器)进行排序 方法:对列表进行遍历,选出最大的   之后将这个数储存起来,对剩下的数再选择最大的,之后再对剩下数做同样的操作 直至结束即可.   代码如下: public ...

  2. 2017-10-6模拟赛T3 丝(filament)

    题目 题解 20分实在想不到是什么做法…… 40分做法,从小到大枚举最小循环节长度,O(n) check即可,总复杂度O(n^2). 100分做法: 看到数据范围,T*n<=10^6,可知这题需 ...

  3. git和github的第一次接触

    我的github的helloworld链接: https://github.com/xuziqian111/hello-world/blob/master/helloworld.java 我的gith ...

  4. 斐讯 天天牛绑定教程 邀请码:8vozbf

    天天牛邀请码 8vozbf 可以领取4代牛 最近斐讯推出了天天牛养成计划. 不过官方没有任何的指示教程,所以个人分享一个教程给大家. 1. 先把把旧的钱包备份一下 ,切记!! 而且一定要记得自己设的密 ...

  5. Linux文件属性描述

    mtime -- modify time 修改时间 硬链接硬链接(hard link, 也称链接)就是一个文件的一个或多个文件名.再说白点,所谓链接无非是把文件名和计算机文件系统使用的节点号链接起来. ...

  6. HTML+CSS水平垂直居中

    啦啦啦,好了,今天来分享自己的第一个知识点,难得自己还能想起来过来博客园,写写博客的. 好了,言归正传,今天分享关于html和css的一个简单的知识点,对于大部分从事前端开发的人员来说可能都是很简单的 ...

  7. Scrapy的使用

    建立好项目以后,在项目文件内scrapy会搭好框架,我们只需要按照框架设置. 先定义Item    它是保存爬取到的数据的容器,其使用方法和python的字典类似,并且提供了额外保护机制来避免拼写错误 ...

  8. Linux环境下mysql主从同步环境搭建

    #my.cnf添加内容vim /etc/my.cnf添加以内容: ## replicationserver_id=195binlog-ignore-db=mysqlbinlog_format=mixe ...

  9. MTK平台-抓取蓝牙log

    一.MTKLOG抓取 .在拔号键盘输入暗码 *#*##*#* 进入工模EngineerMode .在 Log and Debugging -> MTKLogger 点击开始 .MTKLog存储路 ...

  10. nodejs之mock与跨域代理的三两事

    emmm...好久没写博客了,都忘了该怎么开始. 那就先说下mockjs.因为一些原因,导致后台接口没有数据,那么我们就开始自己造数据,使用的是比较流行mockjs,根据文档就能简单的配置,然后开始愉 ...