Docker 学习笔记:Centos7 中 Docker 部署 Redis 集群,打包 SpringBoot 微服务
由于原代码中存在的问题较多,以下是一个简化版的示例,展示如何在CentOS 7上使用Docker部署Redis集群,以及如何使用Docker打包Spring Boot微服务。
# 安装Docker
sudo yum install -y yum-utils device-mapper-persistent-data lvm2
sudo yum-config-manager --add-repo https://download.docker.com/linux/centos/docker-ce.repo
sudo yum install -y docker-ce
sudo systemctl start docker && sudo systemctl enable docker
# 部署Redis集群
# 创建Redis配置文件目录
mkdir -p /etc/redis
# 创建Redis集群配置文件
for port in `seq 7000 7005`; do
cat << EOF > /etc/redis/${port}.conf
port ${port}
cluster-enabled yes
cluster-config-file nodes.conf
cluster-node-timeout 5000
appendonly yes
appendfilename "appendonly.aof"
dbfilename dump.rdb
dir /data
EOF
done
# 创建并启动Redis容器
for port in `seq 7000 7005`; do
docker run -d --name redis-${port} \
-v /etc/redis/${port}.conf:/usr/local/etc/redis/redis.conf \
-v /var/redis/${port}:/data \
-p ${port}:${port} \
redis redis-server /usr/local/etc/redis/redis.conf
done
# 使用Redis Cluster命令创建集群
docker run -it --rm --net=host redis redis-cli --cluster create \
$(for port in `seq 7000 7005`; do echo -n "127.0.0.1:${port} "; done) \
--cluster-replicas 1
# 打包Spring Boot微服务
# 假设你的Spring Boot项目名为myapp
cd /path/to/myapp
./mvnw clean package -Dmaven.test.skip=true
# 创建Dockerfile
echo "FROM openjdk:8-jdk-alpine
ADD target/myapp.jar /app.jar
CMD ["java", "-jar", "/app.jar"]
EXPOSE 8080" > Dockerfile
# 构建Docker镜像
docker build -t myapp .
# 运行微服务容器
docker run -d -p 8080:8080 --name myapp-instance myapp
这个示例展示了如何简洁地使用Docker命令在CentOS 7上部署Redis集群和打包Spring Boot微服务。注意,这里的Redis Cluster创建命令需要根据实际的IP地址和端口进行调整。
评论已关闭