nacos集群部署和VIP部署

1. 准备工作

nacos版本2.2.1
nginx版本1.24.0

2. nacos集群部署

2.1 下载nacos版本后,解压,然后复制三份nacos
在这里插入图片描述
2.2 分别修改三个nacos文件下config目录下的application.properties文件,三个nacos的端口修改为8846,8848,8850
在这里插入图片描述
2.3 修改conf文件夹下的cluster.conf.example文件的后缀,去掉.example(变成cluster.conf文件),并在里面添加内容,将这个文件分别复制到3个nacos下的conf目录下;
在这里插入图片描述
2.4 在启动三个nacos前需要进行的修改操作
由于nacos2.0之后需要配置密钥,分别修改三个nacos文件下config目录下的application.properties文件,添加密钥。
在这里插入图片描述
完整的文件内容(只有生效的部分):


server.servlet.contextPath=/nacos
server.error.include-message=ALWAYS
server.port=8848

#注意这里我是本地指定唯一网卡地址,如果是远程的话,该地址填写远程地址
nacos.inetutils.ip-address=127.0.0.1

spring.datasource.platform=mysql
spring.sql.init.platform=mysql

### Count of DB:
db.num=1

### Connect URL of DB:
db.url.0=jdbc:mysql://127.0.0.1:3306/nacos?useUnicode=true&characterEncoding=utf8&zeroDateTimeBehavior=convertToNull&useSSL=true&serverTimezone=GMT%2B8
db.user.0=root
db.password.0=123456

### Connection pool configuration: hikariCP
db.pool.config.connectionTimeout=30000
db.pool.config.validationTimeout=10000
db.pool.config.maximumPoolSize=20
db.pool.config.minimumIdle=2


management.metrics.export.elastic.enabled=false

management.metrics.export.influx.enabled=false

server.tomcat.accesslog.enabled=true


server.tomcat.accesslog.pattern=%h %l %u %t "%r" %s %b %D %{User-Agent}i %{Request-Source}i


server.tomcat.basedir=file:.
nacos.security.ignore.urls=/,/error,/**/*.css,/**/*.js,/**/*.html,/**/*.map,/**/*.svg,/**/*.png,/**/*.ico,/console-ui/public/**,/v1/auth/**,/v1/console/health/**,/actuator/**,/v1/console/server/**

nacos.core.auth.system.type=nacos


nacos.core.auth.enabled=false

nacos.core.auth.caching.enabled=true
nacos.core.auth.enable.userAgentAuthWhite=false
nacos.core.auth.server.identity.key=serverIdentity
nacos.core.auth.server.identity.value=security

nacos.core.auth.plugin.nacos.token.cache.enable=false
nacos.core.auth.plugin.nacos.token.expire.seconds=18000
nacos.core.auth.plugin.nacos.token.secret.key=SecretKey012345678901234567890123456789012345678901234567890123456789
nacos.istio.mcp.server.enabled=false

2.5 在nacos的bin目录下使用集群启动命令(3个nacos都需要执行启动命令);

#集群启动nacos(请确保先切换到nacos的bin目录)
startup.cmd -m cluster

启动结果:
在这里插入图片描述
2.6 点击集群管理>>节点管理,如果显示3个nacos记录,即为集群启动成功;
在这里插入图片描述

3. 微服务中如何配置多个nacos地址

在微服务的配置文件里需要配置多个nacos地址,以逗号分割。这种配置多个nacos地址的方式,显然很难实现nacos集群的扩缩容,nacos一旦增加或者减少,就需要在每个微服务里进行修改,很繁琐。

spring:
  cloud:
    nacos:
      discovery:
        server-addr: 127.0.0.1:8846,127.0.0.1:8848,127.0.0.1:8850

如果有有一个代理地址可以代替这三个地址,通过代理负载分发到nacos集群中,而微服务只需要配置代理的地址即可,也就是下面的 nginx+nacos集群(VIP模式)
在这里插入图片描述

4. nginx+nacos集群(VIP模式)

4.1 安装nginx1.24.0并进行解压缩
4.2 配置nginx转发,并修改nginx.conf文件
在这里插入图片描述
在这里插入图片描述


#user  nobody;
worker_processes  1;

#error_log  logs/error.log;
#error_log  logs/error.log  notice;
#error_log  logs/error.log  info;

#pid        logs/nginx.pid;


events {
    worker_connections  1024;
}


http {
    include       mime.types;
    default_type  application/octet-stream;

    #log_format  main  '$remote_addr - $remote_user [$time_local] "$request" '
    #                  '$status $body_bytes_sent "$http_referer" '
    #                  '"$http_user_agent" "$http_x_forwarded_for"';

    #access_log  logs/access.log  main;

    sendfile        on;
    #tcp_nopush     on;

    #keepalive_timeout  0;
    keepalive_timeout  65;

    #gzip  on;
	
	upstream nacos{
   
	#weight表示权重,默认是轮循,此处表示8848访问一次,8849访问1,8850访问1,按照这个方式循环调用
		server 127.0.0.1:8848 weight=1;
		server 127.0.0.1:8846 weight=1;
		server 127.0.0.1:8850 weight=1;
	}

    server {
	
		listen       18888;
        server_name  localhost;
        #listen       80;
        #server_name  localhost;

        #charset koi8-r;

        #access_log  logs/host.access.log  main;

        location / {
            root   html;
            index  index.html index.htm;
			proxy_pass http://nacos;
        }

        #error_page  404              /404.html;

        # redirect server error pages to the static page /50x.html
        #
        error_page   500 502 503 504  /50x.html;
        location = /50x.html {
            root   html;
        }

        # proxy the PHP scripts to Apache listening on 127.0.0.1:80
        #
        #location ~ \.php$ {
        #    proxy_pass   http://127.0.0.1;
        #}

        # pass the PHP scripts to FastCGI server listening on 127.0.0.1:9000
        #
        #location ~ \.php$ {
        #    root           html;
        #    fastcgi_pass   127.0.0.1:9000;
        #    fastcgi_index  index.php;
        #    fastcgi_param  SCRIPT_FILENAME  /scripts$fastcgi_script_name;
        #    include        fastcgi_params;
        #}

        # deny access to .htaccess files, if Apache's document root
        # concurs with nginx's one
        #
        #location ~ /\.ht {
        #    deny  all;
        #}
    }


    # another virtual host using mix of IP-, name-, and port-based configuration
    #
    #server {
    #    listen       8000;
    #    listen       somename:8080;
    #    server_name  somename  alias  another.alias;

    #    location / {
    #        root   html;
    #        index  index.html index.htm;
    #    }
    #}


    # HTTPS server
    #
    #server {
    #    listen       443 ssl;
    #    server_name  localhost;

    #    ssl_certificate      cert.pem;
    #    ssl_certificate_key  cert.key;

    #    ssl_session_cache    shared:SSL:1m;
    #    ssl_session_timeout  5m;

    #    ssl_ciphers  HIGH:!aNULL:!MD5;
    #    ssl_prefer_server_ciphers  on;

    #    location / {
    #        root   html;
    #        index  index.html index.htm;
    #    }
    #}

}

4.3 1、 启动nginx,并访问nacos,http://localhost:18888/nacos/,默认账号名和密码都是nacos;
在这里插入图片描述

5. 微服务中配置nginx

通过nginx+nacos集群,我们只需要在微服务中配置nginx的转发地址即可,不需要填写具体的nacos地址

spring:
  cloud:
    nacos:
      discovery:
        server-addr: 127.0.0.1:18888

6. 数据库主备高可用的配置

除了配置多节点外,高可用还需要配置多数据源。
配置两个数据源,在conf目录下的application.properties添加配置数据源(数据库主备高可用)
在这里插入图片描述
7. 问题点
问题1:节点显示多了
如果用户是多网卡,则会出现下面的问题,8848端口只有1个nacos,但是显示两行记录。
在这里插入图片描述
解决办法:
打开对应出错的nacos的conf目录下application.properties文件,指定ip;

#要指定你网卡里有的ip,不要瞎设置
nacos.inetutils.ip-address=127.0.0.1

问题2:
在这里插入图片描述
如果出现这样的问题,检查一下三个nocos下的application.properties的数据源问题
在这里插入图片描述
问题3:Error occurred during initialization of VM
堆内存不足
解决办法:
关掉一些应用,或者增加内存。

问题4:如果三个nacos集群在同一台机器部署,建议使用nacos的端口号不要连续,如本文设计的8846,8848,8850

  • 16
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要使用Docker Compose部署Nacos集群,你可以按照以下步骤进行操作: 1. 首先,确保你已经安装了Docker和Nacos的数据库。 2. 创建一个目录来存放Nacos相关文件。 3. 在该目录下创建并编写一个名为`nginx.conf`的配置文件,用于配置Nginx。 4. 创建并编写一个名为`docker-compose.yaml`的配置文件,用于编排Nacos集群的容器。 5. 使用以下命令来编排和启动Nacos集群的容器: ``` docker-compose -f docker-compose.yaml up -d ``` 6. 等待一段时间,直到所有容器都成功启动。你可以使用以下命令来查看容器的运行情况: ``` docker ps -n 5 ``` 7. 最后,你可以通过访问`http://{ip}:8845/nacos`来访问Nacos的管理界面,账号和密码都是`nacos`。 请注意,上述步骤中的具体配置文件和命令可以根据你的实际情况进行调整。 #### 引用[.reference_title] - *1* *2* [docker-compose部署Nacos集群](https://blog.csdn.net/weixin_44842613/article/details/124629239)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] - *3* [使用Docker Compose快速部署整套Nacos集群](https://blog.csdn.net/m0_37924754/article/details/131241702)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值