说明:本文主要介绍通过Ansible来部署Openshift 3.9

一、准备

系统准备

节点类型 说明
Masters
物理主机或者虚拟机
系统:Fedora 21, CentOS 7.3, 7.4或者7.5
最少4vCPU
最少16GB内存
/var/最少40GB空间
/usr/local/bin最少1GB空间
容器临时目录最少1GB空间
 
Nodes
物理主机或者虚拟机
系统:Fedora 21, CentOS 7.3, 7.4或者7.5
NetworkManager版本1.0以上
最少1vCPU
最少8GB内存
/var/最少15GB空间
/usr/local/bin最少1GB空间
容器临时目录最少1GB空间
 
额外的etcd节点
最少20GB用来存储etcd数据
 

注:在安装时可以通过ansible_inventory的配置忽略以上系统要求
扩展:对于生产部署时,Master的配置要求计算规则如下:每1000个pods需要额外的1核CPU和1.5GB内存。因此如果要满足支持2000个pods的话,Master节点需要在最低配置2核CPU和16GB内存的基础上再加2核CPU和3GB内存,共4核CPU 19GB内存。

安装准备

  1. 关闭防火墙及selinux

    systemctl disable firewalld
    systemctl stop firewalld
    sed -i "s/SELINUX=enforcing/SELINUX=disabled/" /etc/selinux/config
    setenforce 0
    
  2. 更改yum源 base74 、 openshift-3.9 、 epel 、 updates 和 extras。

     #/etc/yum.repos.d/all.repo
    [base]
    name=CentOS-$releasever - Base
    baseurl=http://mirrors.ustc.edu.cn/centos/$releasever/os/$basearch/
    gpgcheck=0
    [updates]
    name=CentOS-$releasever - Updates
    baseurl=http://mirrors.ustc.edu.cn/centos/$releasever/updates/$basearch/
    gpgcheck=0
    [extras]
    name=CentOS-$releasever - Extras
    baseurl=http://mirrors.ustc.edu.cn/centos/$releasever/extras/$basearch/
    gpgcheck=0
    [openshift-3.9]
    name=Openshift 3.9
    baseurl=http://mirrors.ustc.edu.cn/centos/$releasever/paas/$basearch/openshift-origin39/
    gpgcheck=0
    [epel]
    name=Centos EPEL
    baseurl=http://mirrors.ustc.edu.cn/epel/7/$basearch/
    gpgcheck=0
    

    清除缓存

     yum makecache
    

二、安装

  1. 安装需要的软件包

     yum install vim git ansible wget java-1.8.0-openjdk httpd-tools python-passlib docker -y
    
  2. 下载openshift ansible部署脚本

     git clone https://github.com/openshift/openshift-ansible.git -b release-3.9
    
  3. 禁用ansible脚本中的指定repo

     sed -i 's/enabled=1/enabled=0/g' ./roles/openshift_repos/templates/CentOS-OpenShift-Origin.repo.j2
    
  4. 设置hostsname
    a. 在 /etc/hosts 添加ip映射

    # /etc/hosts
    192.168.2.3 openshift
    

    b. 更新本机hostname

     hostnamectl set-hostname --static openshift
    
  5. 设置本地ssh无密钥登录

     ssh-keygen -t rsassh-copy-id -i ~/.ssh/id_rsa.pub root@openshift#或将id_rsa.pub内容添加到~/.ssh/authorized_keys中
    
  6. 配置ansible hosts

    [OSEv3:children]
    masters
    nodes
    etcd
    nfs[OSEv3:vars]
    ansible_ssh_user=root
    openshift_deployment_type=origin
    deployment_type=origin
    openshift_release=v3.9#如果使用自己的镜像的话/etc/sysconfig/docker中会添加ADD_REGISTRY='--add-registry harbor.apps.com'
    #oreg_url=harbor.apps.com/openshift/origin-${component}:${version}
    #system_images_registry=harbor.apps.com
    #openshift_examples_modify_imagestreams=true
    #openshift_docker_additional_registries=harbor.apps.com
    #openshift_service_catalog_image_prefix=harbor.apps.com/openshift/origin-
    #openshift_metrics_image_prefix=harbor.apps.com/openshift/origin-
    #openshift_logging_image_prefix=harbor.apps.com/openshift/origin-
    #ansible_service_broker_image_prefix=harbor.apps.com/openshift/origin-
    #ansible_service_broker_etcd_image_prefix=harbor.apps.com/openshift/origin-
    #openshift_metrics_image_version=v3.9openshift_enable_service_catalog=false
    template_service_broker_install=false
    ansible_service_broker_install=falseopenshift_master_identity_providers=[{'name': 'htpasswd_auth', 'login':'true','challenge': 'true', 'kind': 'HTPasswdPasswordIdentityProvider'}]
    openshift_master_htpasswd_file=/etc/origin/master/htpasswd
    openshift_enable_unsupported_configurations=True
    openshift_docker_options="-l warn --ipv6=false --insecure-registry=0.0.0.0/0 --registry-mirror=https://docker.mirrors.ustc.edu.cn --log-opt max-size=1M --log-opt max-file=3"
    openshift_disable_check=memory_availability,disk_availability,package_availability,package_update,docker_image_availability,docker_storage_driver,docker_storage
    openshift_master_default_subdomain=apps.openshiftopenshift_metrics_install_metrics=true
    openshift_hosted_metrics_public_url=https://hawkular-metrics.apps.openshift/hawkular/metricsopenshift_logging_install_logging=true
    openshift_hosted_etcd_storage_kind=nfs
    openshift_hosted_etcd_storage_nfs_options="*(rw,root_squash,sync,no_wdelay)"
    openshift_hosted_etcd_storage_nfs_directory=/nfs-data
    openshift_hosted_etcd_storage_volume_name=etcd-vol2
    openshift_hosted_etcd_storage_access_modes=["ReadWriteOnce"]
    openshift_hosted_etcd_storage_volume_size=1G
    openshift_hosted_etcd_storage_labels={'storage': 'etcd'}ansible_service_broker_image_prefix=registry.access.redhat.com/openshift3/ose-
    ansible_service_broker_registry_url=registry.access.redhat.com
    ansible_service_broker_registry_user=<user_name>
    ansible_service_broker_registry_password=<password>
    ansible_service_broker_registry_organization=<organization>[masters]
    openshift
    [etcd]
    openshift
    [nfs]
    openshift
    [nodes]
    openshift openshift_node_labels="{'region': 'infra', 'zone':'default'}" openshift_schedulable=true
    
  7. 如果要修改为自己的镜像仓库的话,还需要更改几个yaml文件

    # roles/openshift_web_console/defaults/main.yml(去掉docker.io/)
    openshift_web_console_image_dict:origin:prefix: "openshift/origin-"version: "{{ openshift_image_tag }}"image_name: "web-console"
    
  8. 执行安装脚本

    ansible-playbook playbooks/prerequisites.yml
    ansible-playbook playbooks/deploy_cluster.yml
    
  9. 创建管理员账号

    htpasswd -b /etc/origin/master/htpasswd admin admin
    oc adm policy add-cluster-role-to-user cluster-admin admin
    

三、展示

首页展示

项目主页展示

镜像仓库页展示

参考文章
Openshift 3.9官方高级安装手册

Openshift3.9部署手册相关推荐

  1. DSVS7050签名服务器的网站,吉大正元数字签名服务器-安装部署手册(COM版 VCTK_S接口)2.1.1.doc...

    吉大正元数字签名服务器-安装部署手册(COM版 VCTK_S接口)2.1.1 数字签名服务器v2.1.1 安装部署手册 (VSTK接口 COM版) V2.1.1 长 春 吉 大 正 元 信 息 技 术 ...

  2. [转帖]Oracle 11G RAC For Windows 2008 R2部署手册

    Oracle 11G RAC For Windows 2008 R2部署手册(亲测,成功实施多次) https://www.cnblogs.com/yhfssp/p/7821593.html 总体规划 ...

  3. System Center 2016 Data Protection Manager 部署手册

    1. 环境描述 活动目录服务器 计算机名:SH-DC-01 Active Directory:365vCloud.net IP地址:192.168.100.2/24 操作系统:Windows Serv ...

  4. cactiez v11使用配置mysql_cactiez应用监控部署手册.doc

    cactiez应用监控部署手册 cactiez应用监控部署手册 导读:就爱阅读网友为您分享以下"cactiez应用监控部署手册"的资讯,希望对您有所帮助,感谢您对92的支持! 5. ...

  5. PostgreSQL on Linux 最佳部署手册

    PostgreSQL on Linux 最佳部署手册 TAG 24 作者 digoal 日期 2016-11-21 标签 Linux , PostgreSQL , Install , 最佳部署 背景 ...

  6. ELK 部署手册(docker版本)

    ELK 部署手册(docker版本) 说明: elasticsearch.kibana.logstash.filebeat 版本要一致,elasticsearch-head 方便通过浏览器查看elas ...

  7. Dynamic CRM9.0 环境安装部署手册步骤和遇到的一些问题解决方案(包含ADFS部署)

    Dynamic CRM9.0 环境安装部署手册 Dynamic 365和ADFS配置安装过程踩了一些坑,拿出来和大家记录分享一下. 目录 Dynamic CRM9.0 环境安装部署手册 一.Activ ...

  8. TeamTalk安装部署手册

    TeamTalk安装部署手册 一.部署环境 操作系统:CentOS 7 X64(由于gcc版本问题,官方推荐centos7), CPU:2核 内存:1024M 硬盘:8G 虚拟机:VirtualBox ...

  9. Postgresql 12.2 + PostGIS 3.0.1 安装部署手册

    Postgresql 12.2 + PostGIS 3.0.1 安装部署手册 文章目录 Postgresql 12.2 + PostGIS 3.0.1 安装部署手册 环境说明 注意事项 Postgre ...

最新文章

  1. Linux质数合数的脚本,python输出100以内的质数与合数实例代码
  2. 企业 MySQL 优化实施方案
  3. Java类class cast()方法及示例
  4. matlab rem和mod,Matlab的mod和rem
  5. Mouse Jiggler – 自动移动光标,防止电脑启动屏保、进入休眠[Windows]
  6. github设置仓库可见性 私人仓库设置他人协作/可见
  7. android蓝牙串口arduino源码,android – Arduino:使用串口和软件串口与蓝牙模块
  8. linux操作系统基础及应用课后答案,Linux操作系统课后习题答案及复习要点
  9. 【转】影响光纤传输距离的因数和传输衰减损耗的原因
  10. 郭盛华年收入5000万是真的吗?
  11. 如何高效工作——团队篇
  12. C和C++不安全?Android 支持 Rust 开发操作系统
  13. Mac垃圾文件清理指南
  14. Tomocat:安装完成,显示HTTP Status 404
  15. 技术书是怎么写出来的
  16. 前端项目实战176-栅格顺序
  17. 学习Python处理Excel 难度0级别 多表合并、多条件筛选、找出重复项、去重
  18. Android自定义Dialog(仿QQ同步助手退出对话框)
  19. 微信公众号教程(4)微信公众平台编辑模式介绍
  20. 【技能】小白耳机维修入门--各种耳机插头接线图--耳机维修汇总贴

热门文章

  1. DNS服务(4)Slave DNS及高级特性
  2. 仿拉钩app(一)---爬虫数据准备
  3. Java @Transient 注解使用
  4. DevOps平台中的自动化部署框架设计
  5. linuxSAMBA共享
  6. Ubuntu12环境下Thin+rails(4)+ruby(2)+nginx+mysql 配置
  7. python setup.py install 出错_python setup.py install 失败
  8. 从业回忆,一次大胆的冒险,程序员转岗项目经理
  9. 灰度内测是什么意思?
  10. Yarn简单介绍及内存配置