AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • 主页
  • 系统&网络
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • 主页
  • 系统&网络
    • 最新
    • 热门
    • 标签
  • Ubuntu
    • 最新
    • 热门
    • 标签
  • Unix
    • 最新
    • 标签
  • DBA
    • 最新
    • 标签
  • Computer
    • 最新
    • 标签
  • Coding
    • 最新
    • 标签
主页 / server / 问题 / 770022
Accepted
Amit Tomar
Amit Tomar
Asked: 2016-04-14 04:28:06 +0800 CST2016-04-14 04:28:06 +0800 CST 2016-04-14 04:28:06 +0800 CST

在服务器上处理高度 CPU 密集型进程

  • 772

我在 Amazon EC2 ( m4.2xlarge ) 上有一台 Windows 服务器机器,它处理 Web 请求,使用应用程序 A 进行一些处理并返回结果。问题是,这个应用程序 A 是高度 CPU 密集型的,最终会占用 100% 的 CPU。这产生了两个问题 -

  1. 返回结果需要时间[我完全同意]
  2. 由于 CPU 几乎使用到 100%,我的服务器无法处理后续的 Web 请求并返回 Web 服务错误。[这就是问题] 我不希望任何 Web 服务调用被丢弃,他们迟到返回结果对我来说没问题。

我尝试降低应用程序 A 的 CPU 亲和力,但这对我没有多大帮助。任何其他想法,例如有足够的可用 CPU 来处理 Web 请求,剩余的用于处理应用程序 A。

PS我对从一般服务器设置的角度来看的答案感兴趣。不一定与 AWS 相关。

amazon-ec2 cpu-usage server-setup
  • 1 1 个回答
  • 388 Views

1 个回答

  • Voted
  1. Best Answer
    Matt Houser
    2016-04-14T05:48:41+08:002016-04-14T05:48:41+08:00

    如果您的后端服务正在使用您的所有 CPU,那么您有 3 个选项:

    1. 将您的应用程序移至 CPU 更强大的服务器。这可以让您的 CPU 密集型进程更快地完成。
    2. 将您的应用程序移至具有更多 CPU 或 CPU 内核的服务器。这将允许您的前端应用程序在后端进程工作时获得一些 CPU 时间。
    3. 将您的流程分离到单独的服务器中。将前端应用程序放在一台服务器上,将后端进程放在另一台服务器上。

    从长远来看,选项 3提供了最佳可能性:

    • 它允许您单独扩展您的应用程序。例如,如果需要,您可以在不添加更多前端工作人员的情况下添加更多后端工作人员。您还可以让一堆t2.mediums 处理前端,一个m4.2xlarge在后端。
    • 它可以防止您的后端进程干扰您的前端进程。
    • 3

相关问题

  • 权限被拒绝(公钥)。从本地 Ubuntu 到 Amazon EC2 服务器的 SSH

  • 管理员如何管理他们的 EC2 EBS 和快照?

  • 云有多大?[关闭]

  • EC2 映像启动

  • 如何将安全组添加到正在运行的 EC2 实例?

Sidebar

Stats

  • 问题 205573
  • 回答 270741
  • 最佳答案 135370
  • 用户 68524
  • 热门
  • 回答
  • Marko Smith

    新安装后 postgres 的默认超级用户用户名/密码是什么?

    • 5 个回答
  • Marko Smith

    SFTP 使用什么端口?

    • 6 个回答
  • Marko Smith

    命令行列出 Windows Active Directory 组中的用户?

    • 9 个回答
  • Marko Smith

    什么是 Pem 文件,它与其他 OpenSSL 生成的密钥文件格式有何不同?

    • 3 个回答
  • Marko Smith

    如何确定bash变量是否为空?

    • 15 个回答
  • Martin Hope
    Tom Feiner 如何按大小对 du -h 输出进行排序 2009-02-26 05:42:42 +0800 CST
  • Martin Hope
    Noah Goodrich 什么是 Pem 文件,它与其他 OpenSSL 生成的密钥文件格式有何不同? 2009-05-19 18:24:42 +0800 CST
  • Martin Hope
    Brent 如何确定bash变量是否为空? 2009-05-13 09:54:48 +0800 CST
  • Martin Hope
    cletus 您如何找到在 Windows 中打开文件的进程? 2009-05-01 16:47:16 +0800 CST

热门标签

linux nginx windows networking ubuntu domain-name-system amazon-web-services active-directory apache-2.4 ssh

Explore

  • 主页
  • 问题
    • 最新
    • 热门
  • 标签
  • 帮助

Footer

AskOverflow.Dev

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve