快速搭建Nginx + Nacos*3 集群

Nacos 集群模式

1. Nacos支持三种部署模式

  • 单机模式 - 用于测试和单机试用。

  • 集群模式 - 用于生产环境,确保高可用。

  • 多集群模式 - 用于多数据中心场景。

1.2 集群模式配置方案

https://nacos.io/zh-cn/docs/cluster-mode-quick-start.html

快速搭建Nginx + Nacos*3 集群_第1张图片

2. Nginx + Nacos + Mysql 集群搭建步骤

  1. 导入初始化脚本

     * 找到 conf/nacos-mysql.sql ,将其导入到数据库中。
    
     * 或者从网上下载: https://github.com/alibaba/nacos/blob/master/distribution/conf/nacos-mysql.sql
    
  2. 配置数据库连接

    找到 conf/application.properties ,添加如下内容:

    # 表明用MySQL作为后端存储
    spring.datasource.platform=mysql
    
    # 有几个数据库实例
    db.num=1
    
    # 第1个实例的地址
    db.url.0=jdbc:mysql://11.162.196.16:3306/nacos_devtest?characterEncoding=utf8&connectTimeout=1000&socketTimeout=3000&autoReconnect=true
    ## 第2个实例的地址
    #db.url.1=jdbc:mysql://11.163.152.9:3306/nacos_devtest?characterEncoding=utf8&connectTimeout=1000&socketTimeout=3000&autoReconnect=true
    db.user=nacos_devtest
    db.password=nacos
    
  3. 配置集群配置文件

    • 在nacos的解压目录 nacos/的conf目录下,有配置文件 cluster.conf,请每行配置成ip:port。(请配置3个或3个以上节点)

      # ip:port
      200.8.9.16:8848
      200.8.9.17:8848
      200.8.9.18:8848
      
  4. 启动集群

    • 集群模式

      • 使用内置数据源

        sh startup.sh -p embedded

      • 使用外置数据源

        sh startup.sh

    • JVM 参数配置

      默认配置为: JAVA_OPT="${JAVA_OPT} -server -Xms2g -Xmx2g -Xmn1g -XX:MetaspaceSize=128m -XX:MaxMetaspaceSize=320m"

    • Tips: 集群模式中至少三台启动成功了,整个集群才能真正启动成功

      
      2020-09-08 18:54:54,532 INFO Nacos is starting...
      
      2020-09-08 18:54:54,778 INFO Nacos Log files: /home/jump/softWare/nacos/logs
      
      2020-09-08 18:54:54,778 INFO Nacos Log files: /home/jump/softWare/nacos/conf
      
      2020-09-08 18:54:54,778 INFO Nacos Log files: /home/jump/softWare/nacos/data
      
      2020-09-08 18:54:54,779 INFO Nacos started successfully in cluster mode. use embedded storage
      
  5. Nginx 配置

    upstream nacos-server {
      # 下面是三台nacos服务的地址。(且这三台必须互相能连通)
      server 192.168.0.1:8849;
      server 192.168.0.2:8850;
      server 192.168.0.3:8851;
    }
    
    server {
      listen 80;
      server_name  localhost;
      location /nacos/ {
        proxy_pass http://nacos-server/nacos/;
      }
    }
    
  6. 控制台访问

    http://your-nginx-server-host:80/nacos 可看到Nacos的登录页,登录后即可正常使用Nacos。

  • 客户端访问集群与访问单点的 Nacos server 无异
  1. 微服务访问

    spring:
      application:
        name: demo-test
      cloud:
        nacos:
          discovery:
            server-addr: your-nginx-server-host
          config:
            server-addr: your-nginx-server-host
            prefix: ${
           spring.application.name}
            file-extension: yml
    
    • 启动成功

      2020-09-08 19:52:29.529 INFO 13595 — [ main] c.a.c.n.registry.NacosServiceRegistry : nacos registry, DEFAULT_GROUP demo-test 10.210.1.1:7001 register finished

3. 注意事项

  1. 上文只是完成了 Nacos 的简单集群搭建以及结合Nginx完成了负载均衡,方便在开发测试环境使用,如果需要部署在生产环境,那么建议使用 Nginx + keepalivad + Nacos + Mysql 这种模式来搭建Nacos集群

    快速搭建Nginx + Nacos*3 集群_第2张图片

  • 详情请查看这篇文章:

    Nginx + Keepalived + Nacos + Mysql(HA) 搭建生产环境可用的Nacos集群

你可能感兴趣的:(Alibaba,Nacos,注册&配置中心)