当前位置: 首页 > news >正文

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.1spring.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=2management.metrics.export.elastic.enabled=falsemanagement.metrics.export.influx.enabled=falseserver.tomcat.accesslog.enabled=trueserver.tomcat.accesslog.pattern=%h %l %u %t "%r" %s %b %D %{User-Agent}i %{Request-Source}iserver.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=nacosnacos.core.auth.enabled=falsenacos.core.auth.caching.enabled=true
nacos.core.auth.enable.userAgentAuthWhite=false
nacos.core.auth.server.identity.key=serverIdentity
nacos.core.auth.server.identity.value=securitynacos.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


http://www.mrgr.cn/news/16217.html

相关文章:

  • 2024最新最全:网络安全人士【必备的30个安全工具】
  • Linux文件和目录常用命令
  • Tomcat与Servlet加载问题
  • shell脚本编写注意事项
  • YOLOv9改进策略【模型轻量化】| 利用PP-LCnet改进RepNCSPELAN4
  • shell脚本--正则表达式
  • 量化投资策略与技术学习PART1.1:量化选股之再谈多因子模型(二)
  • JDBC的使用及案例
  • 全国设计院排名 工程项目管理营业额二〇二三年排名
  • 基于STM32的RFID高速收费系统(论文+源码+实物)
  • Java 虚方法表(虚函数)
  • JS设计模式之“名片设计师” - 工厂方法模式
  • APP 数据抓取 - Charles 抓包工具的使用(Charles 端口配置、CA 证书配置、Charles Android 模拟器配置)
  • 又一个免费代码生成工具
  • gpt开发
  • JavaScript的对象详解
  • C--四种排序方法的补充
  • 足底筋膜炎怎么治疗效果好
  • 掌握AIGC的魔法:编写高质量提示词的艺术与科学
  • 【C++11及其特性】左值和右值