写点什么

如何为 SAP 应用选择合适的 EC2

  • 2019-09-29
  • 本文字数:1966 字

    阅读完需:约 6 分钟

如何为SAP应用选择合适的EC2

需求背景

我们在前两篇文章中分别分享了如何为迁移上云的服务器选择机型以及如何在每年对云上的服务器进行优化。在这篇文章中,我们要讨论一下 SAP 的服务器问题。SAP 是企业中广泛使用的 ERP 系统,SAP 应用系统的上云也已经是大势所趋,相对于其他应用系统来说,SAP 的机型选择要相对苛刻一写。首先,不是所有的 AWS EC2 机型都通过了 SAP 公司的认证;其次,就是通过了认证的机器,也不是能运行所有的 SAP 应用。SAP 公司为不同的应用认证了不同的机型。例如 m4 系列的服务器是 SAP 认证的机型,但它不是 HANA 数据库认证的机型。SAP 服务器的性能是通过 SAPS 值体现的,如果我对运行 SAP 应用的服务器进行了机型优化,我如何才能知道对 SAPS 值有何影响?

方案概述

我们在第一篇文章中介绍了环境变量 EXCLUDE_EC2_TYPE 的作用,所以在进行 SAP 服务器的选型时,我们可以通过设置 EXCLUDE_EC2_TYPE 的值来规避选择非 SAP 认证的服务器的现象发生,在这两个网站上可以查询 SAP 的何种应用认证了何种类型的 EC2:



好了,设置了 EXCLUDE_EC2_TYPE 后,我们就可以按照第二篇文章中阐述的方法对 SAP 机型进行优化了。优化完成后,怎么对比 SAPS 值呢? 我们的方案是首先从网站上抓取不同 EC2 对应的 SAPS 值,然后下载下来生成一个 Excel 表格以备后用。


Python 程序 get_ec2_saps.py 就可以完成这个工作:


第一步:下载网上的相关表格


import pandas as pd
saps_table = pd.read_html(‘https://aws.amazon.com/cn/sap/instance-types/’)
import pandas as pd
saps_table = pd.read_html('https://aws.amazon.com/cn/sap/instance-types/')
复制代码


第二步:对表格进行合并、清理


new_table = saps_table[0]
old_table = saps_table[1]
new = new_table[['Instance Type', 'vCPU', 'Mem (GiB)', 'SAPS']]
old = old_table[['Instance Type', 'vCPU', 'Mem (GiB)', 'SAPS']]
ec2_saps = pd.concat([new, old])
ec2_saps.replace({'\*': ''}, regex=True, inplace=True)
ec2_saps['vCPU'] = pd.to_numeric(
ec2_saps['vCPU'], downcast='integer', errors='coerce')
ec2_saps['Mem (GiB)'] = pd.to_numeric(
ec2_saps['Mem (GiB)'], downcast='float', errors='coerce')
ec2_saps['SAPS'] = pd.to_numeric(
ec2_saps['SAPS'], downcast='float', errors='coerce')
复制代码


第三步:保存到 Excel 表格里面


ec2_saps.to_excel('ec2_saps.xlsx', index=False) 
复制代码


大功告成了,让我们看看结果,由于机型过多,我们仅截取部分内容:



接下来我们要做的就是将我们得到的 SAPS 值的结果拼接到机型优化的结果中去。我们以第二篇文章中的优化结果作为例子,输入文件的格式如下:



Python 程序 add_saps.py 可以完成结果的拼接工作:


import pandas as pd
source = "blog3_output.xlsx"
sheet = 0
target = pd.ExcelWriter('result.xlsx')
for i in range(1, 6):
sheet = i
ex1 = pd.read_excel(source)
ex2 = pd.read_excel("ec2_saps.xlsx")
merge = ex1.merge(ex2, left_on="type",
right_on="Instance Type", how='left')
merge.drop(['Instance Type', 'vCPU', 'Mem (GiB)'], axis=1, inplace=True)
merge.rename(columns={'SAPS': 'source_saps'}, inplace=True)
merge = merge.merge(ex2, left_on="target_type",
right_on="Instance Type", how='left')
merge.drop(['Instance Type', 'vCPU', 'Mem (GiB)'], axis=1, inplace=True)
merge.rename(columns={'SAPS': 'target_saps'}, inplace=True)

merge.to_excel(target, sheet_name=str(sheet), index=False)
target.save()
复制代码


运行前提条件:ec2_saps.xlsx 和 blog3_output.xlsx 保存在当前目录下。


运行结果:



注意上面表格的后两列,已经标注了源和目地系统的 SAPS 值。


本文中的完整程序可从这里下载:


https://github.com/shaneliuyx/awscnprice/tree/master/examples


————


如何自动化的选择和优化EC2系列(一)利用AWS Price List API生成中国区的EC2 价格表


如何自动化的选择和优化EC2系列(二)在迁移项目中,如何自动选择最经济的EC2


如何自动化的选择和优化EC2系列(三)如何进行EC2优化,进一步优化成本


如何自动化的选择和优化EC2系列(四)如何为SAP应用选择合适的EC2(本博文)


如何自动化的选择和优化EC2系列(五)如何整合RI续购日期


作者介绍:


刘育新


AWS ProServe 团队高级顾问,长期从事企业客户入云解决方案的制定和项目的实施工作。


本文转载自 AWS 技术博客。


原文链接:


https://amazonaws-china.com/cn/blogs/china/how-does-sap-choose-suitable-ec2-seriesfour/


2019-09-29 16:30846
用户头像

发布了 1964 篇内容, 共 168.7 次阅读, 收获喜欢 83 次。

关注

评论

发布
暂无评论
发现更多内容

Kyutai团队创立新语音AI公司Gradium,融资7000万美元;AWS端到端语音模型升级:多语言切换跨模态交互丨日报

RTE开发者社区

HR Path收购Blueprint HR Software

财见

AutoGen框架入门:5个核心概念搭建智能体协作系统

郝培强

当 APM 遇上业务:阿里云 ARMS 自定义指标采集的价值、实践与选型指南

阿里巴巴云原生

阿里云 云原生 APM Arms

优秀学子获颁证书,开放原子校源行Meetup活动(中南大学站)圆满举办

OpenAnolis小助手

AI 操作系统

AI故障预测系统:给机器装上“预知未来”的智慧眼睛

上海拔俗

LightRAG 实战: 基于 Ollama 搭建带知识图谱的可控 RAG 系统

郝培强

活动推荐:光合组织2025人工智能创新大会邀您报名

OpenAnolis小助手

AI 操作系统

从“会聊天”到“干实事”,亚马逊云科技让Agent“长出了手脚”

Alter

LlamaIndex检索调优实战:七个能落地的技术细节

郝培强

IDEA自动添加SVN 提交git或svn 返回上一页/下一页

刘大猫

人工智能 云计算 算法 物联网 大模型

专访 | 软硬协同、开源共建:英特尔与龙蜥携手打造 AI 时代的可信计算底座

OpenAnolis小助手

AI 操作系统 可信计算

【活动推荐】仅30席!面对面聊聊“数据X模型X软件”,欢迎报名

OpenAnolis小助手

自动驾驶 操作系统

Python 开发必备:tempfile 模块深度解析

郝培强

为你的数据选择合适的分布:8个实用的概率分布应用场景和选择指南

郝培强

CTO/技术总监必读:零代码、低代码、AI加持开发平台,技术选型的策略

红迅AI低代码老陈

零代码 低代码平台 AI开发平台

nginx解决进程内存占用翻倍

天翼云开发者社区

重磅!N8N新版2.0发布!不再支持MySQL?

王磊

GraphRAG进阶:基于Neo4j与LlamaIndex的DRIFT搜索实现详解

郝培强

Java 王者修炼手册【基础篇-泛型机制】:从底层原理到实战应用,核心知识点与面试考点全涵盖

DonaldCen

泛型 java基础 类型擦除

专访 | 不仅是适配,更是定义标准:中兴新支点在龙蜥大会交出的“2025答卷”

OpenAnolis小助手

操作系统 龙蜥社区 龙蜥操作系统 龙蜥操作系统大会

智驾大模型的「隐形战场」:当GPU堆不动了,行业拼什么?

OpenAnolis小助手

AI 操作系统 龙蜥操作系统大会 智驾

戴盟机器人又获亿元级投资:三大"链主"为何集体押注?

财见

Python 3.14 实用技巧:10个让代码更清晰的小改进

郝培强

AI智能体框架怎么选?7个主流工具详细对比解析

郝培强

别被概念忽悠了!零代码、低代码、AI+低代码、AI开发平台,要怎么理解

红迅AI低代码老陈

低代码平台 AI开发平台 零代码平台

nginx中同一端口不同tls版本与加密套件

天翼云开发者社区

中间件

神州通用数据库的 ETL 集成方案:兼容性与性能实战

谷云科技RestCloud

数据库 数据同步 ETL 数据集成 神州通用

Revive Adserver 分页参数漏洞:无限制的setPerPage参数导致资源耗尽与日志批量泄露风险

qife122

WEB安全 资源耗尽

AI智能体开发实战:17种核心架构模式详解与Python代码实现

郝培强

拒绝"通灵式调试":用AI重构代码的"尸检报告"

HuiZhuDev

软件工程 研发效能 代码调试 Prompt Engineering AI辅助编程

如何为SAP应用选择合适的EC2_语言 & 开发_亚马逊云科技 (Amazon Web Services)_InfoQ精选文章