[转]OpenShift 集群搭建指南
转自:http://www.cnblogs.com/zhangning/p/7251810.html
OpenShift 集群搭建指南
v1.0
搭建Hyper-v虚拟机或物理机
- 配置物理机静态IP,启用Hyper-v服务。
- 规划服务器节点
|
节点 |
说明 |
主机名 |
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 |
- 新建虚拟机master节点1个
- 新建Etcd节点1或3个(奇数个),负责分布式协调
- 新建Node节点若干,这里示例为3台

- 为每台虚拟机配置 旧版网络适配器

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

校验并安装centos linux 7系统

等待校验完成

- 选择安装语言

- 选择安装功能
- 软件选择

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

- 安装位置

- 配置网络和主机名


- 下一步,开始安装
- 配置root密码



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

配置虚拟机基础环境
- 我本机是windows安装Xshell5.
- 配置域名解析
- 修改DNS服务器指向 或者b
- 修改节点本地/etc/hosts文件
这里我为了测试方便,直接修改各个节点hosts文件
用xshell5连接各个节点
进入编辑vi /etc/hosts
开始编辑按insert
编辑完成esc,
保存并退出:wq
强制退出不保存!q

配置OpenShift 环境依赖软件
- 所有节点执行:
[root@所有节点 ~]# yum install -y lrzsz git wget net-tools bind-utils iptables-services bridge-utils bash-completion
[root@所有节点 ~]# yum install -y docker
- 检查安装情况
- iptables网络
[root@openshiftectd ~]# systemctl start iptables
[root@openshiftectd ~]# systemctl enable iptables

- docker 安装情况

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




- 增加硬盘完毕,重新启动所有节点,配置docker存储位置
- 查看硬盘信息
命令: fdisk -l
如图所示,添加的数据盘挂载在/dev/sdb目录下

- docker配置
- 编辑docker存储配置位置
[root@所有节点 ~]# vi /etc/sysconfig/docker-storage-setup

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

- 每个节点修改docker镜像站点
vi /etc/sysconfig/docker
追加参数:
--registry-mirror=https://docker.mirrors.ustc.edu.cn

- 增加docker开机启动服务
systemctl enable docker
- 启动docker
systemctl start docker
- 查看docker服务情况
systemctl status docker

配置OpenShift Etcd节点
[root@openshiftectd ~]# yum install -y etcd
[root@openshiftectd ~]# systemctl enable etcd
[root@openshiftectd ~]# systemctl start etcd
配置OpenShift Master节点
- 安装EPEL仓库
下载安装包
http://mirrors.neusoft.edu.cn/epel/7/x86_64/e/

上传到master

[root@openshiftmaster ~]# yum install -y epel-release-7-10.noarch.rpm
- 安装ansible pyOpenSSL
[root@openshiftmaster ~]# yum install -y --enablerepo=epel ansible pyOpenSSL

- 配置各个节点和master节点的互信
- 生成密钥
[root@openshiftmaster ~]# ssh-keygen -f /root/.ssh/id_rsa -N ''

- 配置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

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

- 配置ansible
- 备份hosts

- 编辑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
开始安装集群
- 运行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
即成功通过安装。
安装成功的汇总信息如下图

- 检查运行情况
[root@openshiftmaster ~]# oc get nodes

- 集群账户管理
[root@openshiftmaster ~]# htpasswd -b /etc/origin/master/htpasswd admin admin
- 登录web站点
配置本机hosts文件,将master节点ip指向其主机名
用admin登录web站点


至此OpenShift集群搭建完毕!开始探索吧………
后记:
此文档不详尽处:
- docker在linux中的配置
- 没有详细介绍多样化集群部署,想知道更多参考官方文档
https://docs.openshift.org/latest/install_config/install/advanced_install.html
[转]OpenShift 集群搭建指南的更多相关文章
- 超详细的 Redis Cluster 官方集群搭建指南
今天从 0 开始搭建 Redis Cluster 官方集群,解决搭建过程中遇到的问题,超详细. 安装ruby环境 因为官方提供的创建集群的工具是用ruby写的,需要ruby2.2.2+版本支持,rub ...
- Redis Cluster 官方集群搭建指南
安装ruby环境因为官方提供的创建集群的工具是用ruby写的,需要ruby2.2.2+版本支持,ruby安装需要指定openssl. 安装openssl $ wget https://www.open ...
- ZooKeeper集群-搭建指南
第一步: 上传安装程序到Linux 这一步很简单就不在这过多说明了! 第二步: 在Linux上使用命令行安装 第三步: 修改配置文件 1.修改zoo.cfg文件 2.修改集群中各台主机的名称 1).如 ...
- k8s集群搭建指南
一.简介 Ansible Docker Docker compose,docker swarm,docker machine Mesos,marathon Kubernetes(占据80%的市场) D ...
- 【转】kafka&zookeeper集群搭建指南
[转自]:http://www.cnblogs.com/luotianshuai/p/5206662.html 待续...
- Redis 集群搭建详细指南
先有鸡还是先有蛋? 最近有朋友问了一个问题,说毕业后去大城市还是小城市?去大公司还是小公司?我的回答都是大城市!大公司! 为什么这么说呢,你想一下,无论女孩男孩找朋友都喜欢找个子高胸大的.同样的道理嘛 ...
- RabbitMQ高级指南:从配置、使用到高可用集群搭建
本文大纲: 1. RabbitMQ简介 2. RabbitMQ安装与配置 3. C# 如何使用RabbitMQ 4. 几种Exchange模式 5. RPC 远程过程调用 6. RabbitMQ高可用 ...
- Spark —— 高可用集群搭建
一.集群规划 这里搭建一个3节点的Spark集群,其中三台主机上均部署Worker服务.同时为了保证高可用,除了在hadoop001上部署主Master服务外,还在hadoop002和hadoop00 ...
- mongodb集群搭建过程记录
mongodb集群搭建花费比较长的时间,在此记录下过程,方便以后使用 一 软件环境 系统:ubuntu 18.04,mongodb 社区版4.2 https://docs.mongodb.com/ma ...
随机推荐
- react中Redux应用框架学习
1. 最普通的react-redux 2.应用context的傻瓜组件和聪明组件的redux框架 3. 精简版react-redux,利用react-redux模块的redux(推荐) 4.多个模 ...
- oo第3次博客作业
一.规格化设计的发展历史 20世纪60年代,软件出现严重的危机Dijkstra提出了goto语句的危害,由此引发了软件界长达数年的论战,并产生了结构化的程序设计方法.随着计算机 技术的发展,结构设计化 ...
- SQA计划与系统测试
(一)目的 本计划的目的是定义我们该小组所做的“爱上长大”项目的SQA任务和职责,在项目过程中应遵循的流程.规范和约定等,以确保软件质量得到维持. (二)范围 本计划应用于“爱上长大”项目开发的整个生 ...
- Some notes in Stanford CS106A(2)
1.Local variable(local) ex. int i = 0; factorial(i); the "i" outside the method factorial( ...
- python 离群点检测
import numpy as np import pandas as pd from sklearn.cluster import KMeans import matplotlib.pyplot a ...
- java生成jar并用ikvm生成dll供C#调用
最近想尝试用C#做NB_IOT北向API接口的访问.北向API的接口的访问需要证书的双向认证,而C#不支持双向认证,所以就使用IKVM在C#中跑JAVA程序实现HTTPS请求部分. 步骤如下: 一.使 ...
- svcutil生成List类型不转换成数组
svcutil http://localhost:22180/Service1.svc /out:c:\service1.cs /config:c:\config.config /ct:System. ...
- spring+mybatis的多源数据库配置实战
前言: 关于spring+mybatis的多源数据库配置, 其实是个老生常谈的事情. 网上的方案出奇的一致, 都是借助AbstractRoutingDataSource进行动态数据源的切换. 这边再无 ...
- android 事件绑定
layout布局设计了页面,如何绑定事件,与用户进行交互需要在Activity中进行处理. 下面的layout,有两个按钮. <LinearLayout android:layout_width ...
- Linux 添加DNS配置
Centos7.5 系统,保存退出后自动生效 vi /etc/resolv.conf #阿里云DNS nameserver 223.5.5.5nameserver 223.6.6.6 #百度DNSna ...