基于 Vagrant 手动部署多个 Redis Server
环境准备
- 宿主机环境:Windows 10
- 虚拟机环境:Vagrant + VirtualBox
Vagrantfile 配置
首先,我们需要编写一个 Vagrantfile
来定义我们的虚拟机配置。假设已经在 D:\Vagrant\redis
目录下创建了一个 Vagrantfile
,其内容如下:
Vagrant.configure("2") do |config|
config.vm.box = "local_centos7"
[ "redis1", "redis2", "redis3" ].each_with_index do |name, index|
config.vm.define name do |node|
node.vm.network "private_network", ip: "192.168.50.#{index + 101}"
end
end
config.vm.provider "virtualbox" do |vb|
vb.memory = "1024"
end
end
这里准备创建了
redis1
至redis3
的虚拟机,以redis1
为实操,操作熟练后,其他虚拟机也是一样的。
为什么使用 local_centos7
而不是 centos/7
?
local_centos7
是我们本地已经下载好的 CentOS 7 盒子,使用本地盒子可以避免每次创建虚拟机时都从网络下载,节省时间和带宽。CentOS 7 盒子从官网下载有时是非常缓慢的,这里我提供了咱们国内的下载链接(点这里跳转,提取码:
2024
)
创建本地盒子
在终端(cmd)中进入 Vagrantfile
所在目录 D:\Vagrant\redis
,然后运行以下命令来添加本地盒子:
vagrant box add local_centos7 <CentOS-7...box所在路径(文件拖拽到 cmd)>
检查盒子是否创建成功
查看终端的输出提示,如果没有报错,说明盒子添加成功。
使用以下命令列出所有安装的盒子,查看是否存在
local_centos7
:vagrant box list
上述 Vagrantfile
如已创建(假设所在目录为:D:\Vagrant\redis
),并且 local_centos7
已创建,就已经成功一半了。
启动虚拟机
在 Vagrantfile
所在目录的终端中运行以下命令启动虚拟机:
vagrant up
进入 redis1
虚拟机
启动完成后,通过以下命令进入 redis1
虚拟机:
vagrant ssh redis1
配置 YUM 源
为了提高软件包的下载速度,我们可以将 YUM 源更换为阿里云的镜像源。
切换到
root
用户:su # 提示输入密码(vagrant)
下载阿里云的 CentOS 7 YUM 源配置文件:
curl -o /etc/yum.repos.d/CentOS-Base.repo http://mirrors.aliyun.com/repo/Centos-7.repo
编辑 YUM 源配置文件,将
http
替换为https
:vi /etc/yum.repos.d/CentOS-Base.repo
进入
vi
的命令模式,使用以下命令全局替换::%s/http:/https:/g
清理 YUM 缓存并重新生成缓存:
yum clean all
yum makecache
测试换源是否成功
安装 wget
以测试换源是否成功:
yum install wget -y
安装 GCC
Redis 编译需要 GCC 工具链,首先检查是否已安装:
gcc --version # 如果输出了 gcc 的版本,则跳过 gcc 的安装
如果提示:bash: gcc: command not found
,那么就需要安装:
yum install gcc -y
中途无报错并且输出类似如下,表示安装成功。
安装 Redis
创建
Redis 安装目录
并下载Redis 源码
:mkdir -p /opt/software/redis && cd /opt/software/redis
wget https://download.redis.io/redis-stable.tar.gz
tar -xzf redis-stable.tar.gz && cd redis-stable
编译并安装 Redis:
make install
检查 Redis 是否安装完成:
ll /usr/local/bin | grep redis
如果看到
redis-server
,redis-cli
等文件,说明 Redis 安装成功。
基于 Vagrant 手动部署多个 Redis Server的更多相关文章
- 基于TLS证书手动部署kubernetes集群(下)
一.master节点组件部署 承接上篇文章--基于TLS证书手动部署kubernetes集群(上),我们已经部署好了etcd集群.flannel网络以及每个节点的docker,接下来部署master节 ...
- (转)基于TLS证书手动部署kubernetes集群(下)
转:https://www.cnblogs.com/wdliu/p/9152347.html 一.master节点组件部署 承接上篇文章--基于TLS证书手动部署kubernetes集群(上),我们已 ...
- 部署解决方案包 (SharePoint Server 2010)
转:http://technet.microsoft.com/zh-cn/library/cc262995(v=office.14).aspx 本文介绍各个解决方案包,及其在 Microsoft Sh ...
- ASP.NET Core:部署项目到Ubuntu Server
概述 基于上一篇成功安装Ubuntu Server 16.10的基础上,接下来继续我们ASP.NET Core项目的部署之旅! 只是对于这些年整天和Windows打交道的我,初次使用Linux确实有点 ...
- Redis Cluster的搭建与部署,实现redis的分布式方案
前言 上篇Redis Sentinel安装与部署,实现redis的高可用实现了redis的高可用,针对的主要是master宕机的情况,我们发现所有节点的数据都是一样的,那么一旦数据量过大,redi也会 ...
- Tomcat手动部署Web项目详细步骤
阅读须知:文章基于Tomcat8,其它版本若有差异,请自行辨别.本文为博主原创文章,转载请附原文链接. 不借助任何IDE,这里介绍在Tomcat中手动部署web项目的三种方式: 1.部署解包的weba ...
- NET Core:部署项目到Ubuntu Server
NET Core:部署项目到Ubuntu Server 概述 基于上一篇成功安装Ubuntu Server 16.10的基础上,接下来继续我们ASP.NET Core项目的部署之旅! 只是对于这些年整 ...
- 基于yum的方式安装Cloudera Manager Server(使用Mysql 8.0版本)
基于yum的方式安装Cloudera Manager Server(使用Mysql 8.0版本) 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.安装和配置元数据库 1>. ...
- 007 Ceph手动部署单节点
前面已经介绍了Ceph的自动部署,本次介绍一下关于手动部署Ceph节点操作 一.环境准备 一台虚拟机部署单节点Ceph集群 IP:172.25.250.14 内核: Red Hat Enterpris ...
- [转载]部署Office Web Apps Server并配置其与SharePoint 2013的集成
Office Web Apps Server 是新的 Office 服务器产品,它提供 Word.PowerPoint.Excel 和 OneNote 的基于浏览器的版本.单个 Office Web ...
随机推荐
- PageOffice既保存Word文件中指定区域的数据又保存整篇文件
一.首先在word文件中给需要在后台获取数据的区域设置以PO_开头的书签. 二.通过pageoffice在线打开文件并编辑保存.有两种打开文件的模式 1.普通编辑模式(docNormalEdit) 普 ...
- 工业福利!用.NET快速开发物联网扫码器设备的通用扫码功能
不管你是用.net framework还是用.net core或者更高版本.net环境,这篇文章也许都能帮到你!因为接下来我会提供一个简单粗暴的方式,来快速实现多款扫码器的通用扫码功能.目前本地测试过 ...
- vulnhub靶场 --> JANGOW: 1.0.1
靶机下载地址 JANGOW: 1.0.1 << 点我下载 开始打靶 IP发现 nmap扫描网段发现靶机ip:192.168.111.140 端口发现 对靶机进行常规端口扫描 访问网站 访问 ...
- 数据分析---numpy模块
前戏 NumPy(Numerical Python) 是 Python 语言中做科学计算的基础库.重在于数值计算,也是大部分Python科学计算库的基础,多用于在大型.多维数组上执行的数值运算. 快捷 ...
- Android 12(S) ALooper AHandler AMessage(一)
卧榻之侧岂容他人酣睡,到现在ALooper AHandler AMessage的工作原理一直都没搞懂,很慌!看他们的路径都在libstagefright/foundation下,作为一个foundat ...
- ChatGPT还是有点东西的-public static <T> List<T> Arrays.asList(T... a) {...}
背景 业务开发需要判断业务状态是否在30.40.50.60的集合内,所以写了以下代码 int[] inLiq = {30,40,50,60}; return Arrays.asList(inLiq). ...
- echarts做折线图
先给大家看图 父组件 <el-container v-show="abscissa"> <lineEchart :C ...
- react自定义导航组件 路由参数
为何需要自定义导航? 因为在项目中往往不是所有的声明式导航都是需要a标签完成,有时候可能需要别的标签,此时如果在需要的地方去写编程式导航就会有代码重复可能性,就在对于公共代码进行提取. 思路: 定义一 ...
- vue侦听器 - watch
使用watch来侦听data中数据的变化,watch中的属性一定是data 中已经存在的数据. 当需要监听一个对象的改变时,普通的watch方法无法监听到对象内部属性的改变,只有data中的数据才能够 ...
- work11
1,简述String类中的equals方法与Object类中的equals方法的不同点. /* Object 类 1,它是所有类的一个根类 2,其他类默认继承Object类 常用方法: 1,toStr ...