shell脚本for+in
华为云云耀云服务器L实例评测|在云耀云服务器L实例使用Docker搭建redis集群——三主三从集群
购买云耀云服务器 L 实例
华为云耀云服务器 L 实例是一款轻量级云服务器,开通选择实例即可立刻使用,不需要用户再对服务器进行基础配置。新用户还有专享优惠,2 核心 2G 内存 3M 带宽的服务器只要 89 元/年,可以点击华为云云耀云服务器 L 实例购买地址去购买云服务器。
购买指导可以查看上一篇文章华为云云耀云服务器 L 实例评测 |云服务器选购。
云耀云服务器 L 实例安装 docker
这一部分在上一篇文章中已经详细说明,详见华为云云耀云服务器 L 实例评测|在云耀云服务器 L 实例上安装 Docker,本文不再赘述。
测试 Docker 是否正常运行
# 查看docker版本
docker version
# 测试运行容器
docker run hello-world
看到输出 docker 版本则表示 docker 已经成功安装,此时我们可以继续运行 hello world 的容器,测试容器是否可以正常运行。
如果 Docker 正常运行,就可以看到 docker 在成功创建容器并运行容器后,输出 hello from Docker!
创建 redis 的 docker 网段
这里将 redis 集群的网段设置为 172.16.0.0/24。
docker network create --driver bridge --subnet 172.16.0.0/24 --gateway 172.16.0.1 redis-net
查看刚刚创建的 redis 网段
docker network ls
创建 redis 的配置文件
先创建 shell 脚本来生成 redis 配置文件
sudo vim redis-node-config.sh
在 redis-node-config.sh 文件中输入以下内容:
#!/bin/bash
# 配置文件存放路径
BASE_PATH=/test/redis
# 创建个数
REDIS_COUNT=6
# ip前缀
REDIS_IP=172.16.0.1
for port in $(seq 1 $REDIS_COUNT);
do
mkdir -p $BASE_PATH/node-$port/conf
mkdir -p $BASE_PATH/node-$port/data
touch $BASE_PATH/node-$port/conf/redis.conf
cat < $BASE_PATH/node-$port/conf/redis.conf
port 6379
# 生产环境中为了安全性请绑定当前机器的ip
bind 0.0.0.0
# 启动集群模式
cluster-enabled yes
cluster-config-file nodes.conf
# redis节点宕机被发现的时间
cluster-node-timeout 5000
cluster-announce-ip $REDIS_IP$port
cluster-announce-port 6379
cluster-announce-bus-port 16379
appendonly yes
EOF
done
赋予脚本可执行权限
sudo chmod +x redis-node-config.sh
运行脚本创建配置文件
./redis-node-config.sh
查看脚本是否成功生成文件
cd /test/redis
ll
脚本启动 redis 容器
创建启动脚本
sudo vim redis-run.sh
在 redis-run.sh 中输入以下内容:
#!/bin/bash
# 配置文件存放路径
BASE_PATH=/test/redis
# 创建个数
REDIS_COUNT=6
# ip前缀
REDIS_IP=172.16.0.1
for port in $(seq 1 $REDIS_COUNT);
do
docker run -d -p 637$port:6379 -p 1667$port:16379 \\
--name redis-$port \\
-v $BASE_PATH/node-$port/data:/data \\
-v $BASE_PATH/node-$port/conf/redis.conf:/etc/redis/redis.conf \\
--net redis-net \\
--ip $REDIS_IP$port \\
redis redis-server /etc/redis/redis.conf
done
赋予脚本可执行权限
sudo chmod +x redis-run.sh
运行脚本启动多个 redis 容器
./redis-run.sh
脚本会创建六个 redis 容器并将它们启动起来。
开始搭建 redis 集群
# 进入其中一个容器
docker exec -it redis-1 /bin/bash
# 说明:--cluster :使用cluster的方式搭建集群 --cluster-replicas 1 :一个主机有一个从机
redis-cli --cluster create 172.16.0.11:6379 172.16.0.12:6379 172.16.0.13:6379 172.16.0.14:6379 172.16.0.15:6379 172.16.0.16:6379 --cluster-replicas 1
执行过程中需要输入一次 yes
测试 redis 集群
# 进入redis-1容器
docker exec -it redis-1 /bin/bash
# -c:以集群方式启动
redis-cli -c
# 设置一个键值对
set name berbai01
这里显示是 172.16.0.12 上的 redis 处理了 set 操作。
查看集群节点
cluster nodes
到此已经成功搭建了 redis 的 3 主 3 从集群,上图中 master 为主 redis,slave 则是从 redis。-----已授权转载
","gnid":"9d8337d18a0ab405b","img_data":[{"flag":2,"img":[{"desc":"","height":"529","title":"","url":"https://p0.ssl.img.360kuai.com/t01d0d243467d03dee4.jpg","width":"1283"},{"desc":"","height":"564","title":"","url":"https://p0.ssl.img.360kuai.com/t0171e943abd7d0571e.jpg","width":"468"},{"desc":"","height":"558","title":"","url":"https://p0.ssl.img.360kuai.com/t01c424501fd2940eb7.jpg","width":"533"},{"desc":"","height":"112","title":"","url":"https://p0.ssl.img.360kuai.com/t018fe7e95df3358a2e.jpg","width":"1283"},{"desc":"","height":"282","title":"","url":"https://p0.ssl.img.360kuai.com/t01df0b31317d250dce.jpg","width":"1002"},{"desc":"","height":"394","title":"","url":"https://p0.ssl.img.360kuai.com/t013eeb453308713b8e.jpg","width":"748"},{"desc":"","height":696,"title":"","url":"https://p0.ssl.img.360kuai.com/t014e96258992d33dcb.jpg","width":1172},{"desc":"","height":858,"title":"","url":"https://p0.ssl.img.360kuai.com/t01e0e74f2a31c8e0f8.jpg","width":1280},{"desc":"","height":"272","title":"","url":"https://p0.ssl.img.360kuai.com/t014a1024a79d73c4f4.jpg","width":"908"},{"desc":"","height":"206","title":"","url":"https://p0.ssl.img.360kuai.com/t013870d4441bd2f349.jpg","width":"1283"}]}],"original":0,"pat":"art_src_0,fts0,sts0","powerby":"pika","pub_time":1699873441000,"pure":"","rawurl":"http://zm.news.so.com/bafbf4c84e13aa1f3ea5e2ebd475a541","redirect":0,"rptid":"92df448fe235fe02","rss_ext":[],"s":"t","src":"杨老师技术评论","tag":[],"title":"在云耀云服务器L实例使用Docker搭建redis集群——三主三从集群
盖菡群2623编写一个求1到100之和的shell脚本 -
甫斌泻19274395915 ______ while 循环版本#! /bin/bash i=1 j=0 while : do j=$((j + i)) ((i == 100 )) && break ((i++)) done echo $j for 循环版本#! /bin/bash j=0 for ((i=1 ; i<=100 ; i++)) do j=$((j + i)) done echo $j
盖菡群2623一个简单的linux shell脚本(for语句 if语句) 哪里有问题? -
甫斌泻19274395915 ______ if和for后面都必须有空格i改成$i,然后试试,应该可以的
盖菡群2623shell脚本怎么执行 -
甫斌泻19274395915 ______ 编写好的shell脚本(如:test),可以采取两种方式进行运行:一、 $ sh test 一般不采用这种调用方式,尤其不采用“sh<test”的调用方式,因为这种方式将禁止shell读取标准输入.也可以采用 $ ksh test 这种方式要求shell具有“可读”的访问权...
盖菡群2623shell脚本中for循环结果echo输出重复 -
甫斌泻19274395915 ______ 1、ssh root@ip "command"即可执行远程命令2、实例#!/bin/sh ACCT_CYCLE=abc ip_list=$HOME/shell/all_hosts_2 dst_dir=$HOME/Data/dbc/$ACCT_CYCLE/dat/admin/ for ip in `cat ${ip_list}`; do echo ${ip}; count_rst=`ssh root@${ip} "find $dst_dir -type f |wc -l"`; echo $count_rst; done
盖菡群2623linux编写一个产生一下序列的shell脚本.1,2,3,4,……,10 -
甫斌泻19274395915 ______ 1 #!/bin/bash 2 3 i=1 4 5 6 while [ $i -le 10 ] 7 do 8 echo $i 9 10 i=$(($i+1)) 11 done 12 13 希望对你有帮助
盖菡群2623求编写linux shell 程序求和使用for语句创建一个shell程序,其功能是1+2+3+…+n.请高手们帮下忙!要可... -
甫斌泻19274395915 ______ echo"type n:"; read n sum=0 for ((i;i<=n;i=i+1)); do sum=$(($sum+$i)); done echo "$sum";
盖菡群2623linux shell脚本下使用for循环 输出等边三角形 过任务的 求大神指点
甫斌泻19274395915 ______ #!/bin/bash read -p "please input the longs:" long for((i=1;i<=$long;i++)) do for((j=$long;j>i;j--)) do echo -n " " done for m in `seq 1 $i` do echo -n "+" done for((n=1;n<i;n++)) do echo -n "+" done echo "" done long为你自己输入的边长,如果有规定长度,把$long改成数就行
盖菡群2623Linux中编写shell脚本,输出如下序列:1,3,2,4,3,5,4,6,···100 .[附图] -
甫斌泻19274395915 ______ 脚本至少有如下错误:1. {j}改为${j}或$j,是要取值的啊2. expr语句外面是反引号(键盘上ESC下面那个键)而不是单引号,表示执行命令而不是单纯一个字符串,expr后面的运算符左右两侧要有空格.3. if跟[之间是要有空格的,if判断表达式比较...
盖菡群2623编写一个shell脚本,利用数组形式存放10个的名字,然后利用for循环它们打印出来 -
甫斌泻19274395915 ______ #!/bin/bash name=(a b c d e f g h j i) for i in ${name[*]} do echo $i done
盖菡群2623shell脚本中使用for.do循环语句列出从1到100的数字中能够被3整除的数求出他们的和并输出文件命名为sum.sh -
甫斌泻19274395915 ______ #!/bin/bash sum=0 for i in {1..100} do if [ $(( $i % 3 )) -eq 0 ] then echo $i sum=$(( $sum + $i )) fi done echo "sum is: $sum"保存为sum.sh