金鱼哥RHCA回忆录:DO280OpenShift安装与部署--安装部署与验证

简介: 第二章 OpenShift安装与部署--安装部署与验证
🎹 个人简介:大家好,我是 金鱼哥,CSDN运维领域新星创作者,华为云·云享专家,阿里云社区·专家博主
📚个人资质: CCNA、HCNP、CSNA(网络分析师),软考初级、中级网络工程师、RHCSA、RHCE、RHCA、RHCI、ITIL😜
💬格言:努力不一定成功,但要想成功就必须努力🔥

🎈支持我:可点赞👍、可收藏⭐️、可留言📝


📜安装部署OpenShift(课本练习)

📑1. 前置准备

[student@workstation ~]$ lab install-prepare setup 
Setting up workstation for lab exercise work:


Downloading files for Workshop: Preparing for installation

Exercise has already been downloaded. Use cleanup if you want to start over.
 • Setting up lab files:.......................................  SUCCESS

[student@workstation ~]$ sudo yum install ansible
[student@workstation ~]$ cd /home/student/do280-ansible/
[student@workstation do280-ansible]$ ansible-playbook playbooks/prepare_install.yml #设置相关环境
[student@workstation do280-ansible]$ lab install-run setup 
Setting up workstation for lab work:
Downloading files for GE: Running the Installer

 • Downloading starter project.................................  SUCCESS
 • Downloading solution project................................  SUCCESS
Download successful.

Downloading additional artifacts for the lab:
 • Downloading Ansible artifacts...............................  SUCCESS
 • Install 'crudini' if necessary..............................  SUCCESS
Setup successful.
[student@workstation do280-ansible]$ cd /home/student/DO280/labs/install-run/

📑2. 安装atomic

[student@workstation install-run]$ sudo yum install atomic-openshift-utils

提示:atomic-openshift-utils提供了安装OpenShift所需的Ansible playbook和role。


📑3. 创建Inventory

[student@workstation install-run]$ cp inventory.initial inventory
[student@workstation install-run]$ cat inventory
[workstations]
workstation.lab.example.com

[nfs]
services.lab.example.com

[masters]
master.lab.example.com

[etcd]
master.lab.example.com

[nodes]
master.lab.example.com 
node1.lab.example.com 
node2.lab.example.com 

[OSEv3:children]
masters
etcd
nodes
nfs

#Variables needed by classroom host preparation playbooks.
[nodes:vars]
registry_local=registry.lab.example.com
use_overlay2_driver=true
insecure_registry=false
run_docker_offline=true
docker_storage_device=/dev/vdb
[student@workstation install-run]$ echo -e "\n[OSEv3:vars]" >> inventory

📑4. 配置相关安装版本

[student@workstation install-run]$ cat general_vars.txt 
#General Cluster Variables
openshift_deployment_type=openshift-enterprise    #配置为openshift-enterprise版本
openshift_release=v3.9                             #配置版本为v3.9
openshift_image_tag=v3.9.14
openshift_disable_check=disk_availability,docker_storage,memory_availability   #禁用check

📑5. 设置htpasswd认证

[student@workstation install-run]$ openssl passwd -apr1 redhat
$apr1$k0sF8BuD$HEutvhef0YNzwj8wyIRrc0
[student@workstation install-run]$ openssl passwd -apr1 redhat
$apr1$viJ4N3sq$Ue/MJNshmKzYoyD8MAUCU/
[student@workstation install-run]$ cat authentication_vars.txt 
#Cluster Authentication Variables
openshift_master_identity_providers=[{'name': 'htpasswd_auth', 'login': 'true', 'challenge': 'true', 'kind': 'HTPasswdPasswordIdentityProvider', 'filename': '/etc/origin/master/htpasswd'}]
openshift_master_htpasswd_users={'admin':'$apr1$k0sF8BuD$HEutvhef0YNzwj8wyIRrc0', 'developer':'$apr1$viJ4N3sq$Ue/MJNshmKzYoyD8MAUCU/'}

📑6. 配置集群网络

[student@workstation install-run]$ cat networking_vars.txt 
#OpenShift Networking Variables
os_firewall_use_firewalld=true                                # 开启firewall防火墙
openshift_master_api_port=443                                 # 启用端口
openshift_master_console_port=443                             # 启用控制端口
openshift_master_default_subdomain=apps.lab.example.com       # 指定subdomain

📑7. 配置NFS

[student@workstation install-run]$ cat persistence_vars.txt 
#NFS is an unsupported configuration
openshift_enable_unsupported_configurations=true

#OCR configuration variables
openshift_hosted_registry_storage_kind=nfs
openshift_hosted_registry_storage_access_modes=['ReadWriteMany']
openshift_hosted_registry_storage_nfs_directory=/exports
openshift_hosted_registry_storage_nfs_options='*(rw,root_squash)'
openshift_hosted_registry_storage_volume_name=registry
openshift_hosted_registry_storage_volume_size=40Gi

#OAB's etcd configuration variables
openshift_hosted_etcd_storage_kind=nfs
openshift_hosted_etcd_storage_access_modes=["ReadWriteOnce"]
openshift_hosted_etcd_storage_nfs_directory=/exports
openshift_hosted_etcd_storage_nfs_options="*(rw,root_squash,sync,no_wdelay)"
openshift_hosted_etcd_storage_volume_name=etcd-vol2
openshift_hosted_etcd_storage_volume_size=1G
openshift_hosted_etcd_storage_labels={'storage': 'etcd'}

📑8. 配置离线仓库

[student@workstation install-run]$ cat disconnected_vars.txt 
#Modifications Needed for a Disconnected Install
oreg_url=registry.lab.example.com/openshift3/ose-${component}:${version}  #添加内部仓库
openshift_examples_modify_imagestreams_var=true                         #修改IS
openshift_docker_additional_registries=registry.lab.example.com        #内部仓库至docke配置
openshift_docker_blocked_registries=registry.access.redhat.com,docker.io   #禁止外部官方仓库

#Image Prefixes
openshift_web_console_prefix=registry.lab.example.com/openshift3/ose-
openshift_cockpit_deployer_prefix='registry.lab.example.com/openshift3/'
openshift_service_catalog_image_prefix=registry.lab.example.com/openshift3/ose-
template_service_broker_prefix=registry.lab.example.com/openshift3/ose-
ansible_service_broker_image_prefix=registry.lab.example.com/openshift3/ose-
ansible_service_broker_etcd_image_prefix=registry.lab.example.com/rhel7/

📑9. 设置label

[student@workstation install-run]$ cat inventory
[nodes]
master.lab.example.com 
node1.lab.example.com openshift_node_labels="{'region':'infra', 'node-role.kubernetes.io/compute':'true'}"
node2.lab.example.com openshift_node_labels="{'region':'infra', 'node-role.kubernetes.io/compute':'true'}"

📑10. 合并并校对Inventory

[student@workstation install-run]$ cat general_vars.txt networking_vars.txt authentication_vars.txt persistence_vars.txt disconnected_vars.txt >> inventory
[student@workstation install-run]$ lab install-run grade   #本环境提供检查Inventory的脚本
• Checking openshift_examples_modify_imagestreams.............  FAIL
1c1
< [ OSEv3:vars ] openshift_examples_modify_imagestreams = true
---
> 

 • The custom file does not match the original file.
 • Please review the inventory file and update the necessary variables

若有错误按提示进行修改即可。


📑11. 执行安装剧本

[student@workstation install-run]$ ansible-playbook \
/usr/share/ansible/openshift-ansible/playbooks/prerequisites.yml   #执行准备工作playbook

在这里插入图片描述

[student@workstation install-run]$ ansible-playbook \
/usr/share/ansible/openshift-ansible/playbooks/deploy_cluster.yml

在这里插入图片描述

整个部署log保存至本地目录的ansible.log中。


📜验证测试

📑1. 确认验证说明

要验证OpenShift安装,必须测试和验证所有OpenShift组件。仅仅从示例容器镜像启动pod是不够的,因为这并不使用OpenShift builders、deployer、router或内部registry。

建议通过以下方式完整验证OpenShift:

  • 检查所有OpenShift节点状态;
  • 检查相应的OpenShift registry和router的pod;
  • 使用OpenShift从源代码构建一个应用程序,OpenShift从构建结果生成容器image,并从该镜像启动pod;
  • 创建一个service,以便可以从内部容器网络和OpenShift节点访问应用程序;
  • 创建一个route,以便可以从OpenShift集群外部的计算机访问应用程序。

安装完成后,OpenShift客户端可以使用oc,master节点可以使用oadm命令。master节点的root用户将被配置为云管理员的身份运行OpenShift客户机和管理员命令。

一些OpenShift内部服务,如内部仓库和router,默认情况下由安装程序配置。运行oc get nodes和oc get pods命令,以验证安装成功。


📑2. 登录测试

浏览器访问:https://master.lab.example.com

在这里插入图片描述

使用用户名和密码 admin/redhat 进行登录测试。

在这里插入图片描述


📑3. 验证OpenShift功能

[student@workstation ~]$ oc login -uadmin -predhat https://master.lab.example.com
The server uses a certificate signed by an unknown authority.
You can bypass the certificate check, but any data you send to the server could be intercepted by others.
Use insecure connections? (y/n): y

Login successful.

You don't have any projects. You can try to create a new project, by running

    oc new-project <projectname>

Welcome! See 'oc help' to get started.
[student@workstation ~]$ oc whoami 
admin

提示:账号权限需要单独授予,安装过程中创建的admin并没有集群的administration特权。


📑4. 授予权限

system:admin是唯一一个拥有集群administration权限的账户。master节点的root用户都为集群的system:admin用户。

[root@master ~]# oc whoami 
system:admin
[root@master ~]# oc adm policy add-cluster-role-to-user cluster-admin admin
cluster role "cluster-admin" added: "admin"

cluster-admin角色权限非常高,允许管理用户销毁和修改集群资源,必须谨慎使用。


📑5. 查看节点状态

再次使用命令登录。

[student@workstation ~]$ oc login -uadmin -predhat https://master.lab.example.com
Login successful.

You have access to the following projects and can switch between them with 'oc project <projectname>':

  * default
    kube-public
    kube-service-catalog
    kube-system
    logging
    management-infra
    openshift
    openshift-ansible-service-broker
    openshift-infra
    openshift-node
    openshift-template-service-broker
    openshift-web-console

Using project "default".

[student@workstation ~]$ oc get nodes
NAME                     STATUS    ROLES     AGE       VERSION
master.lab.example.com   Ready     master    3h        v1.9.1+a0ce1bc657
node1.lab.example.com    Ready     compute   3h        v1.9.1+a0ce1bc657
node2.lab.example.com    Ready     compute   3h        v1.9.1+a0ce1bc657

[student@workstation ~]$ oc get pods
NAME                       READY     STATUS    RESTARTS   AGE
docker-registry-1-brc89    1/1       Running   0          3h
docker-registry-1-fb4dn    1/1       Running   0          3h
registry-console-1-mkm66   1/1       Running   0          3h
router-1-5mhcq             1/1       Running   0          3h
router-1-wkr6z             1/1       Running   0          3h

📑6. 创建项目

[student@workstation ~]$ oc login -u developer
Authentication required for https://master.lab.example.com:443 (openshift)
Username: developer
Password: 
Login successful.

You don't have any projects. You can try to create a new project, by running

    oc new-project <projectname>

[student@workstation ~]$ oc new-project smoke-test
Now using project "smoke-test" on server "https://master.lab.example.com:443".

You can add applications to this project with the 'new-app' command. For example, try:

    oc new-app centos/ruby-22-centos7~https://github.com/openshift/ruby-ex.git

to build a new example application in Ruby.

[student@workstation ~]$ oc get project 
NAME         DISPLAY NAME   STATUS
smoke-test                  Active

📑7. 创建应用

[student@workstation ~]$ oc new-app php:5.6~http://services.lab.example.com/php-helloworld --name hello
…………
--> Creating resources ...
    imagestream "hello" created
    buildconfig "hello" created
    deploymentconfig "hello" created
    service "hello" created
--> Success
    Build scheduled, use 'oc logs -f bc/hello' to track its progress.
    Application is not exposed. You can expose services to the outside world by executing one or more of the commands below:
     'oc expose svc/hello' 
    Run 'oc status' to view your app.
[student@workstation ~]$ oc logs -f bc/hello
Cloning "http://services.lab.example.com/php-helloworld" ...
    Commit:    6d61e75647124d02aa761f994532ef29eae46f8e (Establish remote repository)
    Author:    root <root@services.lab.example.com>
    Date:    Thu Aug 9 11:33:29 2018 -0700
---> Installing application source...
=> sourcing 20-copy-config.sh ...
---> 13:02:33     Processing additional arbitrary httpd configuration provided by s2i ...
=> sourcing 00-documentroot.conf ...
=> sourcing 50-mpm-tuning.conf ...
=> sourcing 40-ssl-certs.sh ...

Pushing image docker-registry.default.svc:5000/smoke-test/hello:latest ...
Pushed 0/6 layers, 1% complete
Pushed 1/6 layers, 24% complete
Pushed 2/6 layers, 39% complete
Pushed 3/6 layers, 56% complete
Pushed 4/6 layers, 84% complete
Pushed 5/6 layers, 98% complete
Pushed 6/6 layers, 100% complete
Push successful

提示:输出表明OpenShift能够从仓库clone代码、并且构建image,同时将新image推入内部仓库。


📑8. 公开服务并查看route

[student@workstation ~]$ oc get svc
NAME      TYPE        CLUSTER-IP       EXTERNAL-IP   PORT(S)             AGE
hello     ClusterIP   172.30.135.239   <none>        8080/TCP,8443/TCP   6m
[student@workstation ~]$ oc expose svc hello
route "hello" exposed
[student@workstation ~]$ oc get route 
NAME      HOST/PORT                               PATH      SERVICES   PORT       TERMINATION   WILDCARD
hello     hello-smoke-test.apps.lab.example.com             hello      8080-tcp                 None

📑9. 测试访问

[student@workstation ~]$ curl hello-smoke-test.apps.lab.example.com
Hello, World! php version is 5.6.25

💡总结

RHCA认证需要经历5门的学习与考试,还是需要花不少时间去学习与备考的,好好加油,可以噶🤪。

以上就是【金鱼哥】对 第二章 OpenShift安装与部署--安装部署与验证 的简述和讲解。希望能对看到此文章的小伙伴有所帮助。

💾 红帽认证专栏系列:
RHCSA专栏: 戏说 RHCSA 认证
RHCE专栏: 戏说 RHCE 认证
此文章收录在RHCA专栏: RHCA 回忆录

如果这篇【文章】有帮助到你,希望可以给【金鱼哥】点个赞👍,创作不易,相比官方的陈述,我更喜欢用【通俗易懂】的文笔去讲解每一个知识点。

如果有对【运维技术】感兴趣,也欢迎关注❤️❤️❤️ 【金鱼哥】❤️❤️❤️,我将会给你带来巨大的【收获与惊喜】💕💕!

目录
相关文章
|
Web App开发 消息中间件 安全
|
存储 Kubernetes 安全
金鱼哥RHCA回忆录:DO280介绍红帽OPENSHIFT容器平台--OpenShift特性和架构
第一章 介绍红帽OPENSHIFT容器平台--OpenShift特性和架构
456 0
金鱼哥RHCA回忆录:DO280介绍红帽OPENSHIFT容器平台--OpenShift特性和架构
|
存储 运维 监控
金鱼哥RHCA回忆录:DO280管理和监控OpenShift平台--OCP升级
第九章 管理和监控OpenShift平台–OCP升级
199 0
金鱼哥RHCA回忆录:DO280管理和监控OpenShift平台--OCP升级
|
运维 Kubernetes 监控
金鱼哥RHCA回忆录:DO280管理和监控OpenShift平台--资源限制
第九章 管理和监控OpenShift平台--资源限制
213 0
金鱼哥RHCA回忆录:DO280管理和监控OpenShift平台--资源限制
|
运维 监控 Kubernetes
金鱼哥RHCA回忆录:DO280管理和监控OpenShift平台--使用probes监视应用
第九章 管理和监控OpenShift平台--使用probes监视应用
274 0
金鱼哥RHCA回忆录:DO280管理和监控OpenShift平台--使用probes监视应用
|
JSON 运维 负载均衡
金鱼哥RHCA回忆录:DO280管理应用部署--RC
第七章 DO280管理应用部署--RC
267 0
金鱼哥RHCA回忆录:DO280管理应用部署--RC
|
存储 运维 Kubernetes
金鱼哥RHCA回忆录:DO280OpenShift安装与部署--安装步骤说明
第二章 OpenShift安装与部署--安装步骤说明
406 0
金鱼哥RHCA回忆录:DO280OpenShift安装与部署--安装步骤说明
|
运维 关系型数据库 Linux
金鱼哥RHCA回忆录:DO280OpenShift命令及故障排查--常见故障排除和章节实验
第四章 OpenShift命令及故障排查--常见故障排除和章节实验
399 0
金鱼哥RHCA回忆录:DO280OpenShift命令及故障排查--常见故障排除和章节实验
|
存储 运维 Linux
金鱼哥RHCA回忆录:DO280OpenShift安装与部署--安装前准备
第二章 OpenShift安装与部署--安装前准备
216 0
金鱼哥RHCA回忆录:DO280OpenShift安装与部署--安装前准备
|
存储 JSON 运维
金鱼哥RHCA回忆录:DO280OpenShift命令及故障排查--访问资源和资源类型
第四章 OpenShift命令及故障排查--访问资源和资源类型
191 0
金鱼哥RHCA回忆录:DO280OpenShift命令及故障排查--访问资源和资源类型