【运维知识进阶篇】集群架构体系及虚拟机准备工作

目录

写在开头

转变思维      

架构体系

虚拟机准备

一、优化linux系统流程

二、克隆虚拟机流程


写在开头

        我计划发表四个篇章的博文,难度由浅入深,分别是基础篇的Linux系统,进阶篇的web架构,高级篇的shell编程、代码上线,大神篇的数据库、Docker、k8s。思考许久,还是决定直接开始进阶篇的博文,离开了近两周很是抱歉,因为现实需要处理一些事情,这次回归,干脆就开启新的篇章,先前介绍的运维知识基础篇的内容,就差网络方面的知识了,等有空的时候我会把它放到运维技术栈专栏下的网络二级专栏里面,就不穿插在运维知识分享专栏了,保证这个专栏的一个顺序性,我们直接开始集群架构的学习。

转变思维      

   进阶篇的学习不同于基础篇,先前的学习,知识点比较零散,我们只有反复练习,才能把它弄熟练。但是今后我们要学的东西,是一个框架,需要先学框架体系,再学习里面的内容。另外进阶篇的知识理解要大于操作,如果你跳槽,框架体系都是一样的,个别业务不一样,简单业务熟悉了也能上手。

架构体系

在服务器上部署网站服务,需要有数据库,NFS存储,运维人员。

公司一开始部署时,不知道流量大小,先部署一台,这样优势是成本低,劣势是用户多,服务器抗压能力弱,如果一台服务器出现某些问题导致无法访问,我们就称它是单点故障。

一台服务器的硬件会受到限制,cpu,内存,磁盘,数量不会太多,所以我们就需要用多台服务器去装业务。比如传统行业的官网、访问量少的网站,不是特别重要的网站,一台服务器就OK,挂了我们再恢复,顶多是一段时间无法访问。

像一些存在交易性质的网站,无时无刻不再交易,所以不能挂掉。需要用多台服务器去抗流量,抗并发。

LNMP框架:Linux操作系统,Nginx,MySQL数据库,PHP代码

也可以是:Linux,Nginx,MySQL,Python

LNMP框架:Linux,Nginx,MySQL,Tomcat(java)

LAMP框架:Linux,Apache,MySQL,PHP,Python

用户访问流程:

1.用户通过网络访问到达防火墙,这里centos6是Iptable,centos7是Firewalld,也有WAF防火墙,用于阻挡web层面的攻击。

2.再通过负载均衡,把流量分布到服务器中,这里的软件有Nginx,Haproxy,LVS,硬件有F5。

3.服务器中服务有Nginx、Tomcat、Apache、PHP(web服务器用于连接数据库的服务)

4.此时看请求是什么,请求热点的数据用Redis缓存服务器,如果是请求动态数据,就去找数据库,如果是请求静态数据,就找文件存储服务器(NFS、NAS、OSS),文件储存服务器也有缓存,叫CDN,不在自己的web服务器上去拿数据。

5.这些运行过程都可以通过ELK服务(日志展示平台)展示出来。还会用到zabbix监控,出现问题及时发现。可以用Ansible批量化管理。这些服务可能会部署到以下地方。

1、Vmware虚拟机(教学使用)

2、公有云(阿里云、腾讯云、亚马逊云平台)

3、私有云平台,自己公司购买服务器组成虚拟化平台Openstack

4、硬件/托管到idc机房,基于硬件的Docker Kubeneters

代码上线相关,开发写完代码扔到代码管理平台gitlab或者github,再用Jenkins进行拉取代码质量检测,检测有没有bug或漏洞,检测完之后通知相关人员,没有问题后,运维再用Jenkins先部署到一台服务器测试(人工、工具检测,指标反馈)

虚拟机准备

我们先创建一个模板机,正常创建虚拟机即可,不会创建看下面文章。

如何在VMware上创建Linux系统(CentOS7.9)

创建好后我们连接Xshell进行虚拟机优化,不会连接看下面文章。

如何用Xshell连接VMware虚拟机及排查问题


一、优化linux系统流程

1、修改默认YUM仓库和扩展epel仓库
mv /etc/yum.repos.d/CentOS-Base.repo /etc/yum.repos.d/CentOS-Base.repo.backup
curl -o /etc/yum.repos.d/CentOS-Base.repo https://mirrors.aliyun.com/repo/Centos-7.repo
添加扩展仓库:
yum -y install wget
wget -O /etc/yum.repos.d/epel.repo https://mirrors.aliyun.com/repo/epel-7.repo

2、安装常用命令

yum -y install net-tools lrzsz wget tree vim unzip bash-completion bash-completion-extra ntpdate

3、增加一块内网网卡,并将网卡命名为eth1

71e7d8f6e0054ee7998e4d259ae18241.png

5cdc34e59a8c458e9d7b47447dabaf7b.png

f68614d120e2419b9eaec4e23a451908.png vim /etc/sysconfig/network-scripts/ifcfg-eth0,优化网卡文件,删除多余部分

 详细可见此文章:优化网卡配置文件

 cp ifcfg-eth0 ifcfg-eth1 #复制成eth1网卡文件

vim ifcfg-eth1 #修改成如下状态

e86bcff1d9cb440aa1df830a5c277584.png

 4、优化服务器

systemctl disable firewalld
systemctl stop firewalld

5、关闭selinux

6、调整进程最大打开文件数量
echo '* - nofile 65535' >> /etc/security/limits.conf

7、reboot重启虚拟机

优化过后我们可以通过检查防火墙状态或者查看命令是否可以用等方式测试下是否优化好。

没有问题后,我们关机,做个快照,进行克隆。

二、克隆虚拟机流程

以准备Rsync备份服务器为例:

f003cea0f56c4dbf94d6ebafc0d3b67b.png

 cc0204e323be44448fc660d16b423f52.png

8ce81d2f573e43fdb254ed6f02330128.png

 df6642ffc5434998ad4605d1c7b2bcb4.png

 我们使用链接克隆,要保证模板机一直可以用,否则克隆机也用不了了。

2bae38320117492d9f86f46cce05b239.png

 克隆好后,我们把克隆机打开,修改IP地址、修改主机名称、重启、创建新的xshell会话、做快照(可以开着做,不用挂起)

[root@formwork ~]# vim /etc/sysconfig/network-scripts/ifcfg-eth0
TYPE=Ethernet
BOOTPROTO=none
NAME=eth0
DEVICE=eth0
  BOOT=yes
IPADDR=10.0.0.41
PREFIX=24
GATEWAY=10.0.0.2
DNS1=223.5.5.5
~                                                   
~                                                   
~                                                   
~                                                   
~                                                   
~                                                   
<pts/ifcfg-eth0" 9L, 121C written 
[root@formwork ~]# vim /etc/sysconfig/network-scripts/ifcfg-eth1
TYPE=Ethernet
BOOTPROTO=none
NAME=eth0
DEVICE=eth0
ONBOOT=yes
IPADDR=172.16.1.41
PREFIX=24
~                                                   
~                                                   
~                                                   
~                                                   
~                                                   
~                                                   
~                                                   
~                                                   
<ipts/ifcfg-eth1" 7L, 91C written 
[root@formwork ~]# 

hostnamectl set-hostname backup


我是koten,10年运维经验,持续分享运维干货,感谢大家的阅读和关注!

  • 2
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 2
    评论
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

我是koten

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值