[web] 系统运维--单机
处理过程
- 浏览器发送请求经过网络到达web服务器
- web服务器处理请求并响应数据
- 响应数据从web服务器发送到用户端
- 用户浏览器接收数据,本地计算渲染
指标
- 响应时间
- 吞吐量
响应时间
- 响应时间 = 发送时间 + 传输时间 + 处理时间
- 发送时间 = 数据量比特数 / 带宽
- 传输时间 = 传播距离 / 传播速度
缩短处理时间
- 单机性能优化
- 集群
- 缓存
- 瓶颈点优化
- 多机房部署,就近访问
单机架构
- 单机模式
- 单台服务器web+DB
- 数据库每日凌晨备份,保存到本地
- 动静分离
- 单台服务器web+DB
- Nginx+PHP实现动静分离
- 数据库每日凌晨备份,保存到本地
- 数据库分离
- 将web服务器和数据库单独部署
- web服务器资源备份到数据库服务器
- 数据库每日凌晨备份存放到web服务器
- 组件分离
- 静态服务器使用单独的服务器
- 静态服务器使用独立一级域名防止Cookie提交
- 静态服务器使用多个二级域名提高加载速度(下载网页数据,每遇到1个图片,浏览器会开启1个线程去下载,每个域名只能开6-8个线程)
- 静态资源作为NFS,静态资源存放于NFS上
- 数据库每日凌晨备份到NFS上
web性能优化
- CPU
- 进程数
- CPU绑定
- 内存
- JVM设置
- GC优化
- 大页内存
- 内存合并
- 磁盘
- Openfile
- Sendfile
- IO调度算法
- 网络
- Epool
- Socket优化
- 持久连接
- 随机端口限制
- 65536(2^16-1)
- nc -l -4 -p 9999 -k
- nc 192.168.174.111 9999
- TCP状态转换:FIN_WAIT2,TIME_WAIT(主动关闭方,1个60s,消耗socket)
- TIME_WAIT优化
- reuse:都可以开,时间戳(timestamps)要开
- recycle:不等60s,快速销毁TIME_WAIT,当客户端出于NAT网络时,不能打开(网关 / 负载均衡器,多个客户端通过一个IP访问外网)
- 绑定多个ip地址
- TIME_WAIT优化
- 性能测试
- ab -n 10000 -c -1000 http://www.baidu.com/
- 以1000个并发,共10000个请求访问百度
- 报错:too many open file(默认1024)
- 1个http请求对应1个tcp,对应1个socket文件
- ulimit -a
参考
运维知识体系
https://www.unixhot.com/page/ops
TCP的随机端口为什么不能像服务端口一样复用?
https://www.zhihu.com/question/342296674
[web] 系统运维--单机的更多相关文章
- 解决CentOS无法显示中文字体 | 系统运维 | Web2.0
解决CentOS无法显示中文字体 | 系统运维 | Web2.0 About Me 博客园 devops 前端 张家港水蜜桃 傍晚好! 2013年09月12日 17:56:08 ...
- 浅谈Linux系统运维工程师必备技能
一.什么是运维工程师 相信读者们必定听说过Linux,也听说过运维工程师.那么运维工程师是个什么概念呢? 百度百科上的官方解释如下: 运维工程师(Operations)在国内又称为运维开发工程师(De ...
- Linux系统运维笔记(五),CentOS 6.4安装java程序
Linux系统运维笔记(五),CentOS 6.4安装java程序 用eclipse编译通的java程序,现需要实施到服务器.实施步骤: 一,导出程序成jar包. 1,在主类编辑界面点右健,选 ru ...
- Linux系统运维笔记(四),CentOS 6.4安装 MongoDB
Linux系统运维笔记(四),CentOS 6.4安装 MongoDB 1,下载 https://fastdl.mongodb.org/linux/mongodb-linux-x86_64-3.0.6 ...
- Linux系统运维笔记(四),CentOS 6.4安装Nginx
Linux系统运维笔记(四),CentOS 6.4安装Nginx 1,安装编译工具及库文件 yum -y install make zlib zlib-devel gcc-c++ libtool op ...
- Linux系统运维笔记(三),设置IP和DNS
Linux系统运维笔记(三),设置IP和DNS 手工配置静态的IP地址 也就是手工配置IP地址.子网掩码.网关和DNS. vi /etc/sysconfig/network-scripts/ifcfg ...
- Linux系统运维笔记(二),Linux文件编辑命令
Linux系统运维笔记 Linux文件编辑命令 首先我们使用命令 vi filename 打开一个文件,这个时候进入到的是命令模式 接下来我们按i,然后键盘随便输入写内容. 然后按ESC重新进入到命令 ...
- Linux系统运维笔记(一),查看系统版本和设置系统时间
Linux系统运维笔记 查看系统版本和设置系统时间 查看系统版本 lsb_release -a (适用于所有的linux,包括Redhat.SuSE.Debian等发行版,但是在debian下要安装l ...
- Linux系统运维笔记(6),CentOS 7.6双网卡路由配置
Linux系统运维笔记(6),CentOS 7.6双网卡路由配置. 一,先确认系统版本: [root@localhost ~]# cat /etc/redhat-releaseCentOS Linux ...
随机推荐
- STM32内存结构介绍和FreeRTOS内存分配技巧
这是我第一次使用FreeRTOS构建STM32的项目,踩了好些坑,又发现了我缺乏对于操作系统的内存及其空间的分配的知识,故写下文档记录学习成果. 文章最后要解决的问题是,如何恰当地分配FreeRTOS ...
- " "( 双引号) 与 ' '( 单引号) 差在哪?-- Shell十三问<第四问>
" "( 双引号) 与 ' '( 单引号) 差在哪?-- Shell十三问<第四问> 经过前面两章的学习,应该很清楚当你在 shell prompt 后面敲打键盘.直到 ...
- 复制文件--cp
cp file1 file2 将文件拷贝到指定路径下 cp -r dir1 dir2 将文件夹拷贝到指定路径下
- C++并发与多线程学习笔记--互斥量、用法、死锁概念
互斥量(mutex)的基本概念 互斥量的用法 lock(), unlock() std::lock_guard类模板 死锁 死锁演示 死锁的一般解决方案 std::lock()函数模板 std::lo ...
- 201871030134-余宝鹏 实验三 结对项目—《D{0-1}KP 实例数据集算法实验平台》项目报告
项目 内容 课程班级博客链接 班级博客 这个作业要求链接 作业要求 我的课程学习目标 1.体验软件项目开发中的两人合作,练习结对编程(Pair programming) 2.掌握GitHub协作开发程 ...
- 因为这几个TypeScript代码的坏习惯,同事被罚了500块
作者:Daniel Bartholomae 翻译:疯狂的技术宅 原文链接:https://startup-cto.net/10-bad-typescript-habits-to-break-this- ...
- 了解什么是redis的雪崩和穿透?redis崩溃之后会怎么样?系统该如何应对这种情况?如何处理redis的穿透?
缓存雪崩发生的现象 缓存雪崩的事前事中事后的解决方案 事前:redis高可用,主从+哨兵,redis cluster,避免全盘崩溃 事中:本地ehcache缓存 + hystrix限流&降级, ...
- 如何保证Redis的高并发和高可用?
就是如果你用redis缓存技术的话,肯定要考虑如何用redis来加多台机器,保证redis是高并发的,还有就是如何让Redis保证自己不是挂掉以后就直接死掉了,redis高可用 redis高并发:主从 ...
- Object o = new Object()占多少个字节?-对象的内存布局
一.先上答案 这个问题有坑,有两种回答 第一种解释: object实例对象,占16个字节. 第二种解释: Object o:普通对象指针(ordinary object pointer),占4个字节. ...
- 扩展 GRTN:云原生趋势下的 RTC 架构演进
在 2021 LiveVideoStackCon 音视频技术大会上海站,聚焦 "轻端重云和边缘架构新模式" 专场,阿里云视频云的 RTC 传输专家杨成立(忘篱)带来 "基 ...