Spring Cloud Alibaba要用到的组件很多,注册中心nacos, 限流sentinel, 数据库,网关等等。由于用到的组件相对较多,部署会很繁琐,最关键的是没有资源服务器,所以在开发过程中我会逐渐将一些组件使用docker-compose部署。

01

环境准备

我手上有一台macbook,这次先用mac部署,有机会再写一个ubuntu的,基本差不多。

先晒出mackbook信息,不是高配,硬件配置和这差不多的应该都没问题。

第一部安装docker-toolbox, 阿里云上有个镜像。

http://mirrors.aliyun.com/docker-toolbox/mac/docker-for-mac/stable/

下载,安装。

安装好以后配置一下硬件信息:

这个时候可以试一下,是否安装好了,terminal试一下docker version:

➜  ~ docker version

Client: Docker Engine - Community

Cloud integration  0.1.18

Version:           19.03.13

API version:       1.40

Go version:        go1.13.15

Git commit:        4484c46d9d

Built:             Wed Sep 16 16:58:31 2020

OS/Arch:           darwin/amd64

Experimental:      false

Server: Docker Engine - Community

Engine:

Version:          19.03.13

API version:      1.40 (minimum version 1.12)

Go version:       go1.13.15

Git commit:       4484c46d9d

Built:            Wed Sep 16 17:07:04 2020

OS/Arch:          linux/amd64

Experimental:     false

containerd:

Version:          v1.3.7

GitCommit:        8fba4e9a7d01810a393d5d25a3621dc101981175

runc:

Version:          1.0.0-rc10

GitCommit:        dc9208a3303feef5b3839f4323d9beb36df0a9dd

docker-init:

Version:          0.18.0

GitCommit:        fec3683

docker-compose version:

➜  ~    docker-compose -version

docker-compose version 1.27.4, build 40524192

正常情况下,我们的环境就全部准备好了,是不是很简单。

当然我们国内的环境(肉身翻墙或者有高速梯子跳过这步)是需要配置一个国内的docker加速器,国内的网速去docker hub下载镜像那得凉凉了。

配置阿里云加速方法如下:

首先申请自己的阿里云私有镜像:

1.登陆阿里云:https://cr.console.aliyun.com/cn-hangzhou/instances/mirrors

2.进入【控制台】-【镜像仓库】-【镜像中心】-【镜像加速器】

如果找不到菜单就直接搜【镜像仓库】会要求输入密码,输入即可,然后进入【镜像中心】-【镜像加速器】

获得自己的加速地址后:

{

"features": {

"buildkit": true

},

"experimental": false,

"registry-mirrors": [

"https://xxxxxx.mirror.aliyuncs.com"

]

}

重启服务。

用docker info命令查看是否配置成功,看下你的加速地址表示成功:

Registry Mirrors:

https://xxx.mirror.aliyuncs.com/

Live Restore Enabled: false

Docker toolbox安装成功!!

02

docker-compse部署Mysql

创建docker文件夹,用于存放相应文件信息,创建docker-compose.yml文件。文件目录如下:

-rw-r--r--  1 xx  staff   1.1K 10 27 22:00 docker-compose.yml

drwxr-xr-x  3 xx  staff    96B 10 20 15:22 mysql

编写docker-compose.yml文件如下:

version: "3"

services:

mysql:

container_name: mysql

image: mysql:5.7

environment:

- MYSQL_ROOT_PASSWORD=123456

volumes:

- /Users/xxxx/docker/mysql/data:/var/lib/mysql

ports:

- "3306:3306"

restart: always

启动mysql镜像,输入命令:docker-compose up -d mysql, 运行如下:

➜  docker docker-compose up -d mysql

Creating network "docker_default" with the default driver

Pulling mysql (mysql:5.7)...

5.7: Pulling from library/mysql

bb79b6b2107f: Pull complete

49e22f6fb9f7: Pull complete

842b1255668c: Pull complete

9f48d1f43000: Pull complete

c693f0615bce: Pull complete

8a621b9dbed2: Pull complete

0807d32aef13: Pull complete

6d2fc69dfa35: Pull complete

56153548dd2c: Extracting [=======================================>           ]  84.67MB/108.3MB

用docker-compose ps -a 命令查看是否启动成功,看到如下信息说明成功:

➜  docker docker-compose ps -a

Name                      Command                State                   Ports

----------------------------------------------------------------------------------------------------

mysql                  docker-entrypoint.sh mysqld      Up

0.0.0.0:3306->3306/tcp, 33060/tcp

Mysql安装成功!!

03

docker-compse部署Nacos

去github把nacos  的SQL文件下载下来,导入数据库中。

https://raw.githubusercontent.com/alibaba/nacos/develop/distribution/conf/nacos-mysql.sql

用工具导到我们刚搭建好的mysql中:(用本机ip, root/123456, 端口3306)

在docker-compse.yml的后面中加入以下配置:

nacos:

image: nacos/nacos-server:1.1.4

container_name: nacos

environment:

- PREFER_HOST_MODE=hostname

- MODE=standalone

- MYSQL_DATABASE_NUM=1

- SPRING_DATASOURCE_PLATFORM=mysql

- MYSQL_MASTER_SERVICE_HOST=mysql

- MYSQL_MASTER_SERVICE_DB_NAME=nacos

- MYSQL_MASTER_SERVICE_PORT=3306

- MYSQL_MASTER_SERVICE_USER=root

- MYSQL_MASTER_SERVICE_PASSWORD=123456

volumes:

- /Users/xxx/docker/nacos/logs:/home/nacos/logs

ports:

- "8848:8848"

depends_on:

- mysql

restart: always

写好了注意在相应的volumes创建好相应的文件夹

docker-compose up -d nacos

启动nacos

启动完成后通过 http://yourip:8848/nacos/#/login 用nacos/nacos登陆

Nacos安装成功!!

04

docker-compse部署sentinel

在docker-compse.yml的后面中加入以下配置:

sentinel:

image: bladex/sentinel-dashboard:latest

container_name: sentinel

ports:

- "8858:8858"

restart: always

运行命令:

➜  docker docker-compose up -d sentinel

启动成功后,http://yourip:8858/  用户名密码sentinel/sentinel登陆

Sentinel安装成功, 至此前期所需要的组件都安装成功, 万里长征迈出第一步,下期我们继续。

Docker composer搭建Spring Cloud Alibaba 运行环境(二)的更多相关文章

  1. Spring Cloud Alibaba 实战(十二) - Nacos配置管理

    本章主要内容是:使用Nacos管理配置以及实现配置管理的原因,配置如何管理以及动态刷新和最佳实现总结,最后是Nacos配置刷新原理解读 该技术类似于Spring Cloud Config 1 配置管理 ...

  2. Spring Cloud Alibaba系列(二)nacos作为服务配置中心

    Nacos 提供用于存储配置和其他元数据的 key/value 存储,为分布式系统中的外部化配置提供服务器端和客户端支持.使用 Spring Cloud Alibaba Nacos Config,您可 ...

  3. Spring Cloud Alibaba 初体验(二) Nacos 服务注册与发现 + 集成 Spring Cloud Gateway

    一.服务注册 添加依赖: <dependency> <groupId>com.alibaba.cloud</groupId> <artifactId>s ...

  4. 从零搭建Spring Cloud Gateway网关(二)—— 打印请求响应日志

    作为网关,日志记录是必不可少的功能,可以在网关出增加requestId来查询整个请求链的调用执行情况等等. 打印请求日志 打印请求日志最重要的就是打印请求参数这些东西,不过RequestBody通常情 ...

  5. Spring Cloud Alibaba环境搭建

    前言:Spring Cloud Alibaba是目前主流的分布式微服务架构,本文主要讲解了在IDEA中如何搭建Spring Cloud Alibaba环境,以及介绍Spring Cloud Aliba ...

  6. Spring Cloud Alibaba学习笔记

    引自B站楠哥:https://space.bilibili.com/434617924 一.创建父工程 创建父工程hello-spring-cloud-alibaba Spring Cloud Ali ...

  7. Spring Cloud 网关服务 zuul 二

    有一点上篇文章忘了 讲述,nacos的加载优先级别最高.服务启动优先拉去配置信息.所以上一篇服务搭建我没有讲述在nacos 中心创建的配置文件 可以看到服务端口和注册中心都在配置文件中配置化 属性信息 ...

  8. Spring Cloud gateway 网关服务二 断言、过滤器

    微服务当前这么火爆的程度,如果不能学会一种微服务框架技术.怎么能升职加薪,增加简历的筹码?spring cloud 和 Dubbo 需要单独学习.说没有时间?没有精力?要学俩个框架?而Spring C ...

  9. Spring Cloud Alibaba(7)---docker-compose搭建nacos1.4.0集群

    docker-compose搭建nacos1.4.0集群 有关Nacos之前写过四篇文章. Spring Cloud Alibaba(3)---Nacos概述 Spring Cloud Alibaba ...

随机推荐

  1. Laravel驱动管理类Manager的分析和使用

    Laravel驱动管理类Manager的分析和使用 第一部分 概念说明 第二部分 Illuminate\Support\Manager源码 第三部分 Manager类的使用 第一部分:概念解释 结合实 ...

  2. Java Comparable 和 Comparator 接口详解

    本文基于 JDK8 分析 Comparable Comparable 接口位于 java.lang 包下,Comparable 接口下有一个 compareTo 方法,称为自然比较方法.一个类只要实现 ...

  3. 关于JAVA的垃圾回收机制

    使用JAVA编程时,几乎不需要考虑"内存泄漏"的问题,这也是JAVA相较于C++的一个优点. 最近在看<Java编程思想>(第四版,听说第五版有点牛逼....),里面讲 ...

  4. 极简 Node.js 入门 - 4.3 可读流

    极简 Node.js 入门系列教程:https://www.yuque.com/sunluyong/node 本文更佳阅读体验:https://www.yuque.com/sunluyong/node ...

  5. 大数据平台Hadoop集群搭建

    一.概念 Hadoop是由java语言编写的,在分布式服务器集群上存储海量数据并运行分布式分析应用的开源框架,其核心部件是HDFS与MapReduce.HDFS是一个分布式文件系统,类似mogilef ...

  6. 线上Redis高并发性能调优实践

    项目背景 最近,做一个按优先级和时间先后排队的需求.用 Redis 的 sorted set 做排队队列. 主要使用的 Redis 命令有, zadd, zcount, zscore, zrange ...

  7. Centos-删除文件或目录-rm

    rm 删除目录或者文件,如果是链接文件,则只删除这个链接文件而不是链接指向的文件 相关选项 -r 递归删除目录 -f 忽略不存在提示和确认提示,本身确认提示系统默认添加-i参数 -i 删除文件前提示, ...

  8. Regression trees树回归 以及其他

    https://www.cnblogs.com/wuliytTaotao/p/10724118.html 选 weighted variance 最小的 但是weighted variance是怎么计 ...

  9. 软件定义网络实验记录②--Mininet 实验——拓扑的命令脚本生成

    一.实验目的 掌握 Mininet 的自定义拓扑生成方法:命令行创建.Python 脚本编写 二.实验任务 通过使用命令行创建.Python 脚本编写生成拓扑,熟悉 Mininet 的基本功能. 三. ...

  10. 使用模拟退火算法优化 Hash 函数

    背景 现有个处理股票行情消息的系统,其架构如下: 由于数据量巨大,系统中启动了 15 个线程来消费行情消息.消息分配的策略较为简单:对 symbol 的 hashCode 取模,将消息分配给其中一个线 ...