通过脚本文件自动更新Linux实例中的软件源

作者阿里云代理 文章分类 分类:图文教程 阅读次数 已被围观 524

点击查看原图

概述

本文主要介绍通过脚本文件更新Linux实例中的软件源的方法。

详细信息

  • 如果您对实例或数据有修改、变更等风险操作,务必注意实例的容灾、容错能力,确保数据安全。
  • 如果您对实例(包括但不限于ECS、RDS)等进行配置与数据修改,建议提前创建快照或开启RDS日志备份等功能。
  • 如果您在阿里云平台授权或者提交过登录账号、密码等安全信息,建议您及时修改。

以下是通过脚本文件更新软件源的操作步骤。

适用场景

  • 可以自动检测系统并更新源。
  • 适用场景为一键式检测系统并更新源,用户只需执行该脚本一次即可自动检测系统并更新源。
  • 适用系统如下:
    • Alibaba Cloud Linux 2
    • CentOS 5/6/7
    • Debian 6/7
    • OpenSUSE 13.1
    • Red Hat Enterprise Linux Server 5/6
    • Ubuntu 10/12.04/12.10/14.04
  • 由于系统版本都有支持的周期,所以部分源可能会出现不可用的情况,包括官方的源,这是正常情况。

操作步骤

  1. 登录ECS实例,可以在任意目录中下载以下update_source.tgz脚本。
    • update_source.tgz
  2. 切换到root用户,依次执行以下命令。
    chmod +x update_source.sh
    sh update_source.sh
  3. 确认系统已更新软件源。

 

    如果您有其他问题,可以联系汉中创云互联阿里云代理商,为您提供一对一专业全面的技术服务,同时新老阿里云会员,均可享受我公司代理商价格,欢迎咨询欢迎咨询.gif
本文中快速部署Redis应用的步骤仅适用于以下实例规格:
  • ecs.re6p-redis.large
  • ecs.re6p-redis.xlarge
  • ecs.re6p-redis.2xlarge
  • ecs.re6p-redis.13xlarge
说明 ecs.re6p-redis.<nx>large是为Redis应用推出的专用实例规格,只支持将持久内存作为内存使用。
如果您使用其他系统部署Redis应用,请保证镜像的版本满足以下要求:
  • Alibaba Cloud Linux 2
  • CentOS 7.6及更高版本
  • Ubuntu 18.10及更高版本
  • SUSE Linux 12 SP4及更高版本
注意 持久内存中数据的可靠性取决于物理服务器和持久内存设备的可靠性,因此存在单点故障风险。建议您在应用层做好数据冗余,将需要长期保存的业务数据存储到云盘上,以保证应用数据的可靠性。

在使用Alibaba Cloud Linux系统的re6p实例上部署Redis应用

Alibaba Cloud Linux系统对Redis应用进行了专项调优,相比社区版操作系统,Redis应用整体性能提升20%以上。

Alibaba Cloud Linux系统目前集成了Redis 6.0.5和3.2.12版本,您也可以手动部署其他Redis版本,Redis应用整体性能仍然有20%以上的提升。

本示例中使用的配置如下:
  • 实例规格:ecs.re6p-redis.2xlarge
  • 镜像:Alibaba Cloud Linux 2.1903 LTS 64位
  1. 购买持久内存实例。
    具体操作,请参见使用向导创建实例。请注意以下配置:
    • 实例:单击x86计算架构下的内存型分类,并选中名称为ecs.re6p-redis.2xlarge的实例规格。
    • 镜像:选择Alibaba Cloud Linux 2.1903 LTS 64位。
  2. 登录实例。
    具体操作,请参见连接方式概述
  3. 部署Redis应用。
    • 部署Redis 6.0.5版:
      yum install -y alinux-release-experimentals
      yum install -y redis-6.0.5
    • 部署Redis 3.2.12版:
      yum install -y alinux-release-experimentals
      yum install –y redis-3.2.12
  4. 配置网卡多队列。
    网卡多队列可以帮助Redis应用获得更好的性能。
    1. 下载自动配置脚本ecs_mq。
      wget https://ecs-image-tools.oss-cn-hangzhou.aliyuncs.com/ecs_mq/ecs_mq_latest.tgz
    2. 解压脚本。
      tar -xzf ecs_mq_latest.tgz
    3. 更换工作路径。
      cd ecs_mq/
    4. 运行脚本。
      不同的镜像版本的命令格式不同,例如Alibaba Cloud Linux 2.1903镜像运行bash install.sh aliyun 2
      bash install.sh <系统名称> <系统主版本号>
    5. 启动服务。
      systemctl start ecs_mq
  5. 为Redis服务配置默认的DRAM和持久内存大小。
    说明 为防止其他未经优化的应用(例如Nginx)分配到持久内存的空间地址,引起性能问题,建议您在启动Redis应用时将所有持久内存分配给Redis应用。
    示例命令如下:
    • 端口号6379、DRAM=4 GiB、持久内存32 GiB
      export MEMKIND_DAX_KMEM_NODES=1 redis-server /etc/redis.conf --port 6379 --memory-alloc-policy ratio --dram-pmem-ratio 1 8 --maxmemory 36G
    • 端口号6379、DRAM=2 GiB、持久内存32 GiB
      export MEMKIND_DAX_KMEM_NODES=1 redis-server /etc/redis.conf --port 6379 --memory-alloc-policy ratio --dram-pmem-ratio 1 16 --maxmemory 34G
    • 端口号6379、DRAM=0 GiB、持久内存32 GiB
      export MEMKIND_DAX_KMEM_NODES=1 redis-server /etc/redis.conf --port 6379 --memory-alloc-policy only-pmem --maxmemory 32G

在使用CentOS系统的re6p实例上部署Redis应用

本示例中使用的配置如下:
  • 实例规格:ecs.re6p-redis.2xlarge
  • 镜像:CentOS 7.6
    说明 请确保使用CentOS 7.6或更高版本。
  • Redis:Redis 4.0.14
  • memkind:memkind 1.10.1
  1. 购买持久内存实例。
    具体操作,请参见使用向导创建实例。请注意以下配置:
    • 实例:单击x86计算架构下的内存型分类,并选中名称为ecs.re6p-redis.2xlarge的实例规格。
    • 镜像:选择CentOS 7.6 64位。
  2. 登录实例。
    具体操作,请参见连接方式概述
  3. 准备编译环境。
    export MEMKIND_DAX_KMEM_NODES=1
    yum -y install numactl-devel.x86_64
    yum -y groupinstall 'Development Tools'
    说明 Development Tools包括gcc编译器等工具。
  4. 下载Redis安装包。
    wget https://github.com/redis-io/redis/archive/4.0.14.tar.gz tar xzvf 4.0.14.tar.gz
  5. 下载并安装为Redis应用使能持久内存的patch。
    关于如何下载并安装更多Redis版本对应patch,请参见下载使能持久内存的patch
    wget https://github.com/redis/redis/compare/4.0.14...memKeyDB:4.0.14-devel.diff -O redis_4.0.14_eca56e845aa19d2e79e7c70207e860f8385541f9.patch cd redis-4.0.14
    git apply --ignore-whitespace ../redis_4.0.14_eca56e845aa19d2e79e7c70207e860f8385541f9.patch
  6. 安装memkind。
    memkind是内存管理工具,用于分配管理持久内存。
    wget https://github.com/memkind/memkind/archive/v1.10.1-rc2.tar.gz tar xzvf v1.10.1-rc2.tar.gz
    mv memkind-1.10.1-rc2/* ./deps/memkind/
  7. 如果glibc版本低于2.17,需要调整makefile。
    cd ./deps/memkind/
    wget https://github.com/memKeyDB/memKeyDB/wiki/files/0001-Use-secure_getenv-when-possible.patch
    git apply --ignore-whitespace 0001-Use-secure_getenv-when-possible.patch
  8. redis-4.0.14目录下执行编译。
    说明 如果您未切换到./deps/memkind/目录调整makefile,则仍然位于redis-4.0.14目录下,无需运行cd ../..切换目录。
    cd ../.. make clean;make distclean;make MALLOC=memkind -j 4 make install
  9. 配置网卡多队列。
    网卡多队列可以帮助Redis应用获得更好的性能。
    1. 下载自动配置脚本ecs_mq。
      wget https://ecs-image-tools.oss-cn-hangzhou.aliyuncs.com/ecs_mq/ecs_mq_latest.tgz
    2. 解压脚本。
      tar -xzf ecs_mq_latest.tgz
    3. 更换工作路径。
      cd ecs_mq/
    4. 运行脚本。
      不同的镜像版本的命令格式不同,例如CentOS 7.6镜像运行bash install.sh centos 7
      bash install.sh <系统名称> <系统主版本号>
    5. 启动服务。
      systemctl start ecs_mq
  10. 为Redis服务配置默认的DRAM和持久内存大小。
    说明 为防止其他未经优化的应用(例如Nginx)分配到持久内存的空间地址,引起性能问题,建议您在启动Redis应用时将所有持久内存分配给Redis应用。
    示例命令如下:
    • 端口号6379、DRAM=4 GiB、持久内存32 GiB
      redis-server redis.conf --port 6379 --memory-alloc-policy ratio --dram-pmem-ratio 1 8 --maxmemory 36G
    • 端口号6379、DRAM=2 GiB、持久内存32 GiB
      redis-server redis.conf --port 6379 --memory-alloc-policy ratio --dram-pmem-ratio 1 16 --maxmemory 34G
    • 端口号6379、DRAM=0 GiB、持久内存32 GiB
      redis-server redis.conf --port 6379 --memory-alloc-policy only-pmem --maxmemory 32G

下载使能持久内存的patch

替换示例命令中的下载地址以及文件名中对应的版本号即可,例如下载Redis 6.0.5适用的patch的命令如下:
wget https://github.com/redis/redis/compare/6.0.5...memKeyDB:6.0.5-devel.diff -O redis_6.0.5_eca56e845aa19d2e79e7c70207e860f8385541f9.patch
 


      我公司为阿里云代理商为您提供一对一专业全面的技术服务,通过此页面下单购买,新老阿里云会员,均可享受我公司代理商价格!

 

 
本文中快速部署Redis应用的步骤仅适用于以下实例规格:
  • ecs.re6p-redis.large
  • ecs.re6p-redis.xlarge
  • ecs.re6p-redis.2xlarge
  • ecs.re6p-redis.13xlarge
说明 ecs.re6p-redis.<nx>large是为Redis应用推出的专用实例规格,只支持将持久内存作为内存使用。
如果您使用其他系统部署Redis应用,请保证镜像的版本满足以下要求:
  • Alibaba Cloud Linux 2
  • CentOS 7.6及更高版本
  • Ubuntu 18.10及更高版本
  • SUSE Linux 12 SP4及更高版本
注意 持久内存中数据的可靠性取决于物理服务器和持久内存设备的可靠性,因此存在单点故障风险。建议您在应用层做好数据冗余,将需要长期保存的业务数据存储到云盘上,以保证应用数据的可靠性。

在使用Alibaba Cloud Linux系统的re6p实例上部署Redis应用

Alibaba Cloud Linux系统对Redis应用进行了专项调优,相比社区版操作系统,Redis应用整体性能提升20%以上。

Alibaba Cloud Linux系统目前集成了Redis 6.0.5和3.2.12版本,您也可以手动部署其他Redis版本,Redis应用整体性能仍然有20%以上的提升。

本示例中使用的配置如下:
  • 实例规格:ecs.re6p-redis.2xlarge
  • 镜像:Alibaba Cloud Linux 2.1903 LTS 64位
  1. 购买持久内存实例。
    具体操作,请参见使用向导创建实例。请注意以下配置:
    • 实例:单击x86计算架构下的内存型分类,并选中名称为ecs.re6p-redis.2xlarge的实例规格。
    • 镜像:选择Alibaba Cloud Linux 2.1903 LTS 64位。
  2. 登录实例。
    具体操作,请参见连接方式概述
  3. 部署Redis应用。
    • 部署Redis 6.0.5版:
      yum install -y alinux-release-experimentals
      yum install -y redis-6.0.5
    • 部署Redis 3.2.12版:
      yum install -y alinux-release-experimentals
      yum install –y redis-3.2.12
  4. 配置网卡多队列。
    网卡多队列可以帮助Redis应用获得更好的性能。
    1. 下载自动配置脚本ecs_mq。
      wget https://ecs-image-tools.oss-cn-hangzhou.aliyuncs.com/ecs_mq/ecs_mq_latest.tgz
    2. 解压脚本。
      tar -xzf ecs_mq_latest.tgz
    3. 更换工作路径。
      cd ecs_mq/
    4. 运行脚本。
      不同的镜像版本的命令格式不同,例如Alibaba Cloud Linux 2.1903镜像运行bash install.sh aliyun 2
      bash install.sh <系统名称> <系统主版本号>
    5. 启动服务。
      systemctl start ecs_mq
  5. 为Redis服务配置默认的DRAM和持久内存大小。
    说明 为防止其他未经优化的应用(例如Nginx)分配到持久内存的空间地址,引起性能问题,建议您在启动Redis应用时将所有持久内存分配给Redis应用。
    示例命令如下:
    • 端口号6379、DRAM=4 GiB、持久内存32 GiB
      export MEMKIND_DAX_KMEM_NODES=1 redis-server /etc/redis.conf --port 6379 --memory-alloc-policy ratio --dram-pmem-ratio 1 8 --maxmemory 36G
    • 端口号6379、DRAM=2 GiB、持久内存32 GiB
      export MEMKIND_DAX_KMEM_NODES=1 redis-server /etc/redis.conf --port 6379 --memory-alloc-policy ratio --dram-pmem-ratio 1 16 --maxmemory 34G
    • 端口号6379、DRAM=0 GiB、持久内存32 GiB
      export MEMKIND_DAX_KMEM_NODES=1 redis-server /etc/redis.conf --port 6379 --memory-alloc-policy only-pmem --maxmemory 32G

在使用CentOS系统的re6p实例上部署Redis应用

本示例中使用的配置如下:
  • 实例规格:ecs.re6p-redis.2xlarge
  • 镜像:CentOS 7.6
    说明 请确保使用CentOS 7.6或更高版本。
  • Redis:Redis 4.0.14
  • memkind:memkind 1.10.1
  1. 购买持久内存实例。
    具体操作,请参见使用向导创建实例。请注意以下配置:
    • 实例:单击x86计算架构下的内存型分类,并选中名称为ecs.re6p-redis.2xlarge的实例规格。
    • 镜像:选择CentOS 7.6 64位。
  2. 登录实例。
    具体操作,请参见连接方式概述
  3. 准备编译环境。
    export MEMKIND_DAX_KMEM_NODES=1
    yum -y install numactl-devel.x86_64
    yum -y groupinstall 'Development Tools'
    说明 Development Tools包括gcc编译器等工具。
  4. 下载Redis安装包。
    wget https://github.com/redis-io/redis/archive/4.0.14.tar.gz tar xzvf 4.0.14.tar.gz
  5. 下载并安装为Redis应用使能持久内存的patch。
    关于如何下载并安装更多Redis版本对应patch,请参见下载使能持久内存的patch
    wget https://github.com/redis/redis/compare/4.0.14...memKeyDB:4.0.14-devel.diff -O redis_4.0.14_eca56e845aa19d2e79e7c70207e860f8385541f9.patch cd redis-4.0.14
    git apply --ignore-whitespace ../redis_4.0.14_eca56e845aa19d2e79e7c70207e860f8385541f9.patch
  6. 安装memkind。
    memkind是内存管理工具,用于分配管理持久内存。
    wget https://github.com/memkind/memkind/archive/v1.10.1-rc2.tar.gz tar xzvf v1.10.1-rc2.tar.gz
    mv memkind-1.10.1-rc2/* ./deps/memkind/
  7. 如果glibc版本低于2.17,需要调整makefile。
    cd ./deps/memkind/
    wget https://github.com/memKeyDB/memKeyDB/wiki/files/0001-Use-secure_getenv-when-possible.patch
    git apply --ignore-whitespace 0001-Use-secure_getenv-when-possible.patch
  8. redis-4.0.14目录下执行编译。
    说明 如果您未切换到./deps/memkind/目录调整makefile,则仍然位于redis-4.0.14目录下,无需运行cd ../..切换目录。
    cd ../.. make clean;make distclean;make MALLOC=memkind -j 4 make install
  9. 配置网卡多队列。
    网卡多队列可以帮助Redis应用获得更好的性能。
    1. 下载自动配置脚本ecs_mq。
      wget https://ecs-image-tools.oss-cn-hangzhou.aliyuncs.com/ecs_mq/ecs_mq_latest.tgz
    2. 解压脚本。
      tar -xzf ecs_mq_latest.tgz
    3. 更换工作路径。
      cd ecs_mq/
    4. 运行脚本。
      不同的镜像版本的命令格式不同,例如CentOS 7.6镜像运行bash install.sh centos 7
      bash install.sh <系统名称> <系统主版本号>
    5. 启动服务。
      systemctl start ecs_mq
  10. 为Redis服务配置默认的DRAM和持久内存大小。
    说明 为防止其他未经优化的应用(例如Nginx)分配到持久内存的空间地址,引起性能问题,建议您在启动Redis应用时将所有持久内存分配给Redis应用。
    示例命令如下:
    • 端口号6379、DRAM=4 GiB、持久内存32 GiB
      redis-server redis.conf --port 6379 --memory-alloc-policy ratio --dram-pmem-ratio 1 8 --maxmemory 36G
    • 端口号6379、DRAM=2 GiB、持久内存32 GiB
      redis-server redis.conf --port 6379 --memory-alloc-policy ratio --dram-pmem-ratio 1 16 --maxmemory 34G
    • 端口号6379、DRAM=0 GiB、持久内存32 GiB
      redis-server redis.conf --port 6379 --memory-alloc-policy only-pmem --maxmemory 32G

下载使能持久内存的patch

替换示例命令中的下载地址以及文件名中对应的版本号即可,例如下载Redis 6.0.5适用的patch的命令如下:
wget https://github.com/redis/redis/compare/6.0.5...memKeyDB:6.0.5-devel.diff -O redis_6.0.5_eca56e845aa19d2e79e7c70207e860f8385541f9.patch
 


      我公司为阿里云代理商为您提供一对一专业全面的技术服务,通过此页面下单购买,新老阿里云会员,均可享受我公司代理商价格!

 

 
本文中快速部署Redis应用的步骤仅适用于以下实例规格:
  • ecs.re6p-redis.large
  • ecs.re6p-redis.xlarge
  • ecs.re6p-redis.2xlarge
  • ecs.re6p-redis.13xlarge
说明 ecs.re6p-redis.<nx>large是为Redis应用推出的专用实例规格,只支持将持久内存作为内存使用。
如果您使用其他系统部署Redis应用,请保证镜像的版本满足以下要求:
  • Alibaba Cloud Linux 2
  • CentOS 7.6及更高版本
  • Ubuntu 18.10及更高版本
  • SUSE Linux 12 SP4及更高版本
注意 持久内存中数据的可靠性取决于物理服务器和持久内存设备的可靠性,因此存在单点故障风险。建议您在应用层做好数据冗余,将需要长期保存的业务数据存储到云盘上,以保证应用数据的可靠性。

在使用Alibaba Cloud Linux系统的re6p实例上部署Redis应用

Alibaba Cloud Linux系统对Redis应用进行了专项调优,相比社区版操作系统,Redis应用整体性能提升20%以上。

Alibaba Cloud Linux系统目前集成了Redis 6.0.5和3.2.12版本,您也可以手动部署其他Redis版本,Redis应用整体性能仍然有20%以上的提升。

本示例中使用的配置如下:
  • 实例规格:ecs.re6p-redis.2xlarge
  • 镜像:Alibaba Cloud Linux 2.1903 LTS 64位
  1. 购买持久内存实例。
    具体操作,请参见使用向导创建实例。请注意以下配置:
    • 实例:单击x86计算架构下的内存型分类,并选中名称为ecs.re6p-redis.2xlarge的实例规格。
    • 镜像:选择Alibaba Cloud Linux 2.1903 LTS 64位。
  2. 登录实例。
    具体操作,请参见连接方式概述
  3. 部署Redis应用。
    • 部署Redis 6.0.5版:
      yum install -y alinux-release-experimentals
      yum install -y redis-6.0.5
    • 部署Redis 3.2.12版:
      yum install -y alinux-release-experimentals
      yum install –y redis-3.2.12
  4. 配置网卡多队列。
    网卡多队列可以帮助Redis应用获得更好的性能。
    1. 下载自动配置脚本ecs_mq。
      wget https://ecs-image-tools.oss-cn-hangzhou.aliyuncs.com/ecs_mq/ecs_mq_latest.tgz
    2. 解压脚本。
      tar -xzf ecs_mq_latest.tgz
    3. 更换工作路径。
      cd ecs_mq/
    4. 运行脚本。
      不同的镜像版本的命令格式不同,例如Alibaba Cloud Linux 2.1903镜像运行bash install.sh aliyun 2
      bash install.sh <系统名称> <系统主版本号>
    5. 启动服务。
      systemctl start ecs_mq
  5. 为Redis服务配置默认的DRAM和持久内存大小。
    说明 为防止其他未经优化的应用(例如Nginx)分配到持久内存的空间地址,引起性能问题,建议您在启动Redis应用时将所有持久内存分配给Redis应用。
    示例命令如下:
    • 端口号6379、DRAM=4 GiB、持久内存32 GiB
      export MEMKIND_DAX_KMEM_NODES=1 redis-server /etc/redis.conf --port 6379 --memory-alloc-policy ratio --dram-pmem-ratio 1 8 --maxmemory 36G
    • 端口号6379、DRAM=2 GiB、持久内存32 GiB
      export MEMKIND_DAX_KMEM_NODES=1 redis-server /etc/redis.conf --port 6379 --memory-alloc-policy ratio --dram-pmem-ratio 1 16 --maxmemory 34G
    • 端口号6379、DRAM=0 GiB、持久内存32 GiB
      export MEMKIND_DAX_KMEM_NODES=1 redis-server /etc/redis.conf --port 6379 --memory-alloc-policy only-pmem --maxmemory 32G

在使用CentOS系统的re6p实例上部署Redis应用

本示例中使用的配置如下:
  • 实例规格:ecs.re6p-redis.2xlarge
  • 镜像:CentOS 7.6
    说明 请确保使用CentOS 7.6或更高版本。
  • Redis:Redis 4.0.14
  • memkind:memkind 1.10.1
  1. 购买持久内存实例。
    具体操作,请参见使用向导创建实例。请注意以下配置:
    • 实例:单击x86计算架构下的内存型分类,并选中名称为ecs.re6p-redis.2xlarge的实例规格。
    • 镜像:选择CentOS 7.6 64位。
  2. 登录实例。
    具体操作,请参见连接方式概述
  3. 准备编译环境。
    export MEMKIND_DAX_KMEM_NODES=1
    yum -y install numactl-devel.x86_64
    yum -y groupinstall 'Development Tools'
    说明 Development Tools包括gcc编译器等工具。
  4. 下载Redis安装包。
    wget https://github.com/redis-io/redis/archive/4.0.14.tar.gz tar xzvf 4.0.14.tar.gz
  5. 下载并安装为Redis应用使能持久内存的patch。
    关于如何下载并安装更多Redis版本对应patch,请参见下载使能持久内存的patch
    wget https://github.com/redis/redis/compare/4.0.14...memKeyDB:4.0.14-devel.diff -O redis_4.0.14_eca56e845aa19d2e79e7c70207e860f8385541f9.patch cd redis-4.0.14
    git apply --ignore-whitespace ../redis_4.0.14_eca56e845aa19d2e79e7c70207e860f8385541f9.patch
  6. 安装memkind。
    memkind是内存管理工具,用于分配管理持久内存。
    wget https://github.com/memkind/memkind/archive/v1.10.1-rc2.tar.gz tar xzvf v1.10.1-rc2.tar.gz
    mv memkind-1.10.1-rc2/* ./deps/memkind/
  7. 如果glibc版本低于2.17,需要调整makefile。
    cd ./deps/memkind/
    wget https://github.com/memKeyDB/memKeyDB/wiki/files/0001-Use-secure_getenv-when-possible.patch
    git apply --ignore-whitespace 0001-Use-secure_getenv-when-possible.patch
  8. redis-4.0.14目录下执行编译。
    说明 如果您未切换到./deps/memkind/目录调整makefile,则仍然位于redis-4.0.14目录下,无需运行cd ../..切换目录。
    cd ../.. make clean;make distclean;make MALLOC=memkind -j 4 make install
  9. 配置网卡多队列。
    网卡多队列可以帮助Redis应用获得更好的性能。
    1. 下载自动配置脚本ecs_mq。
      wget https://ecs-image-tools.oss-cn-hangzhou.aliyuncs.com/ecs_mq/ecs_mq_latest.tgz
    2. 解压脚本。
      tar -xzf ecs_mq_latest.tgz
    3. 更换工作路径。
      cd ecs_mq/
    4. 运行脚本。
      不同的镜像版本的命令格式不同,例如CentOS 7.6镜像运行bash install.sh centos 7
      bash install.sh <系统名称> <系统主版本号>
    5. 启动服务。
      systemctl start ecs_mq
  10. 为Redis服务配置默认的DRAM和持久内存大小。
    说明 为防止其他未经优化的应用(例如Nginx)分配到持久内存的空间地址,引起性能问题,建议您在启动Redis应用时将所有持久内存分配给Redis应用。
    示例命令如下:
    • 端口号6379、DRAM=4 GiB、持久内存32 GiB
      redis-server redis.conf --port 6379 --memory-alloc-policy ratio --dram-pmem-ratio 1 8 --maxmemory 36G
    • 端口号6379、DRAM=2 GiB、持久内存32 GiB
      redis-server redis.conf --port 6379 --memory-alloc-policy ratio --dram-pmem-ratio 1 16 --maxmemory 34G
    • 端口号6379、DRAM=0 GiB、持久内存32 GiB
      redis-server redis.conf --port 6379 --memory-alloc-policy only-pmem --maxmemory 32G

下载使能持久内存的patch

替换示例命令中的下载地址以及文件名中对应的版本号即可,例如下载Redis 6.0.5适用的patch的命令如下:
wget https://github.com/redis/redis/compare/6.0.5...memKeyDB:6.0.5-devel.diff -O redis_6.0.5_eca56e845aa19d2e79e7c70207e860f8385541f9.patch
 


      我公司为阿里云代理商为您提供一对一专业全面的技术服务,通过此页面下单购买,新老阿里云会员,均可享受我公司代理商价格!

 

 
本文中快速部署Redis应用的步骤仅适用于以下实例规格:
  • ecs.re6p-redis.large
  • ecs.re6p-redis.xlarge
  • ecs.re6p-redis.2xlarge
  • ecs.re6p-redis.13xlarge
说明 ecs.re6p-redis.<nx>large是为Redis应用推出的专用实例规格,只支持将持久内存作为内存使用。
如果您使用其他系统部署Redis应用,请保证镜像的版本满足以下要求:
  • Alibaba Cloud Linux 2
  • CentOS 7.6及更高版本
  • Ubuntu 18.10及更高版本
  • SUSE Linux 12 SP4及更高版本
注意 持久内存中数据的可靠性取决于物理服务器和持久内存设备的可靠性,因此存在单点故障风险。建议您在应用层做好数据冗余,将需要长期保存的业务数据存储到云盘上,以保证应用数据的可靠性。

在使用Alibaba Cloud Linux系统的re6p实例上部署Redis应用

Alibaba Cloud Linux系统对Redis应用进行了专项调优,相比社区版操作系统,Redis应用整体性能提升20%以上。

Alibaba Cloud Linux系统目前集成了Redis 6.0.5和3.2.12版本,您也可以手动部署其他Redis版本,Redis应用整体性能仍然有20%以上的提升。

本示例中使用的配置如下:
  • 实例规格:ecs.re6p-redis.2xlarge
  • 镜像:Alibaba Cloud Linux 2.1903 LTS 64位
  1. 购买持久内存实例。
    具体操作,请参见使用向导创建实例。请注意以下配置:
    • 实例:单击x86计算架构下的内存型分类,并选中名称为ecs.re6p-redis.2xlarge的实例规格。
    • 镜像:选择Alibaba Cloud Linux 2.1903 LTS 64位。
  2. 登录实例。
    具体操作,请参见连接方式概述
  3. 部署Redis应用。
    • 部署Redis 6.0.5版:
      yum install -y alinux-release-experimentals
      yum install -y redis-6.0.5
    • 部署Redis 3.2.12版:
      yum install -y alinux-release-experimentals
      yum install –y redis-3.2.12
  4. 配置网卡多队列。
    网卡多队列可以帮助Redis应用获得更好的性能。
    1. 下载自动配置脚本ecs_mq。
      wget https://ecs-image-tools.oss-cn-hangzhou.aliyuncs.com/ecs_mq/ecs_mq_latest.tgz
    2. 解压脚本。
      tar -xzf ecs_mq_latest.tgz
    3. 更换工作路径。
      cd ecs_mq/
    4. 运行脚本。
      不同的镜像版本的命令格式不同,例如Alibaba Cloud Linux 2.1903镜像运行bash install.sh aliyun 2
      bash install.sh <系统名称> <系统主版本号>
    5. 启动服务。
      systemctl start ecs_mq
  5. 为Redis服务配置默认的DRAM和持久内存大小。
    说明 为防止其他未经优化的应用(例如Nginx)分配到持久内存的空间地址,引起性能问题,建议您在启动Redis应用时将所有持久内存分配给Redis应用。
    示例命令如下:
    • 端口号6379、DRAM=4 GiB、持久内存32 GiB
      export MEMKIND_DAX_KMEM_NODES=1 redis-server /etc/redis.conf --port 6379 --memory-alloc-policy ratio --dram-pmem-ratio 1 8 --maxmemory 36G
    • 端口号6379、DRAM=2 GiB、持久内存32 GiB
      export MEMKIND_DAX_KMEM_NODES=1 redis-server /etc/redis.conf --port 6379 --memory-alloc-policy ratio --dram-pmem-ratio 1 16 --maxmemory 34G
    • 端口号6379、DRAM=0 GiB、持久内存32 GiB
      export MEMKIND_DAX_KMEM_NODES=1 redis-server /etc/redis.conf --port 6379 --memory-alloc-policy only-pmem --maxmemory 32G

在使用CentOS系统的re6p实例上部署Redis应用

本示例中使用的配置如下:
  • 实例规格:ecs.re6p-redis.2xlarge
  • 镜像:CentOS 7.6
    说明 请确保使用CentOS 7.6或更高版本。
  • Redis:Redis 4.0.14
  • memkind:memkind 1.10.1
  1. 购买持久内存实例。
    具体操作,请参见使用向导创建实例。请注意以下配置:
    • 实例:单击x86计算架构下的内存型分类,并选中名称为ecs.re6p-redis.2xlarge的实例规格。
    • 镜像:选择CentOS 7.6 64位。
  2. 登录实例。
    具体操作,请参见连接方式概述
  3. 准备编译环境。
    export MEMKIND_DAX_KMEM_NODES=1
    yum -y install numactl-devel.x86_64
    yum -y groupinstall 'Development Tools'
    说明 Development Tools包括gcc编译器等工具。
  4. 下载Redis安装包。
    wget https://github.com/redis-io/redis/archive/4.0.14.tar.gz tar xzvf 4.0.14.tar.gz
  5. 下载并安装为Redis应用使能持久内存的patch。
    关于如何下载并安装更多Redis版本对应patch,请参见下载使能持久内存的patch
    wget https://github.com/redis/redis/compare/4.0.14...memKeyDB:4.0.14-devel.diff -O redis_4.0.14_eca56e845aa19d2e79e7c70207e860f8385541f9.patch cd redis-4.0.14
    git apply --ignore-whitespace ../redis_4.0.14_eca56e845aa19d2e79e7c70207e860f8385541f9.patch
  6. 安装memkind。
    memkind是内存管理工具,用于分配管理持久内存。
    wget https://github.com/memkind/memkind/archive/v1.10.1-rc2.tar.gz tar xzvf v1.10.1-rc2.tar.gz
    mv memkind-1.10.1-rc2/* ./deps/memkind/
  7. 如果glibc版本低于2.17,需要调整makefile。
    cd ./deps/memkind/
    wget https://github.com/memKeyDB/memKeyDB/wiki/files/0001-Use-secure_getenv-when-possible.patch
    git apply --ignore-whitespace 0001-Use-secure_getenv-when-possible.patch
  8. redis-4.0.14目录下执行编译。
    说明 如果您未切换到./deps/memkind/目录调整makefile,则仍然位于redis-4.0.14目录下,无需运行cd ../..切换目录。
    cd ../.. make clean;make distclean;make MALLOC=memkind -j 4 make install
  9. 配置网卡多队列。
    网卡多队列可以帮助Redis应用获得更好的性能。
    1. 下载自动配置脚本ecs_mq。
      wget https://ecs-image-tools.oss-cn-hangzhou.aliyuncs.com/ecs_mq/ecs_mq_latest.tgz
    2. 解压脚本。
      tar -xzf ecs_mq_latest.tgz
    3. 更换工作路径。
      cd ecs_mq/
    4. 运行脚本。
      不同的镜像版本的命令格式不同,例如CentOS 7.6镜像运行bash install.sh centos 7
      bash install.sh <系统名称> <系统主版本号>
    5. 启动服务。
      systemctl start ecs_mq
  10. 为Redis服务配置默认的DRAM和持久内存大小。
    说明 为防止其他未经优化的应用(例如Nginx)分配到持久内存的空间地址,引起性能问题,建议您在启动Redis应用时将所有持久内存分配给Redis应用。
    示例命令如下:
    • 端口号6379、DRAM=4 GiB、持久内存32 GiB
      redis-server redis.conf --port 6379 --memory-alloc-policy ratio --dram-pmem-ratio 1 8 --maxmemory 36G
    • 端口号6379、DRAM=2 GiB、持久内存32 GiB
      redis-server redis.conf --port 6379 --memory-alloc-policy ratio --dram-pmem-ratio 1 16 --maxmemory 34G
    • 端口号6379、DRAM=0 GiB、持久内存32 GiB
      redis-server redis.conf --port 6379 --memory-alloc-policy only-pmem --maxmemory 32G

下载使能持久内存的patch

替换示例命令中的下载地址以及文件名中对应的版本号即可,例如下载Redis 6.0.5适用的patch的命令如下:
wget https://github.com/redis/redis/compare/6.0.5...memKeyDB:6.0.5-devel.diff -O redis_6.0.5_eca56e845aa19d2e79e7c70207e860f8385541f9.patch
 


      我公司为阿里云代理商为您提供一对一专业全面的技术服务,通过此页面下单购买,新老阿里云会员,均可享受我公司代理商价格!

 

 
本公司销售:阿里云、腾讯云、百度云、天翼云、金山大米云、金山企业云盘!可签订合同,开具发票。

我有话说: