SpringCloudAlibaba ----- Nacos注册+配置中心 单机模式启动Server端(一)

Bertha 。 2022-12-26 08:17 253阅读 0赞

nacos是Spring Cloud Alibaba开源项目,可用于作为Spring Cloud的注册中心和配置中心。

先要详细了解可以查看nacos官方说明文档

为什么需要配置中心

当然是为了便于对配置文件进行统一管理。springcloud是以springboot为基础,springboot最终的几乎都是打包成一个可执行的jar包(当然也可以打包成war包)。所有的配置文件是打包在jar包中,当工程的配置文件需要修改,就需要修改配置文件,然后重新打包部署,非常麻烦。当我们只有少量工程以及修改频率很低,上面的操作还可以接受,但是当数量很多时,显然上面的方法弊端明显。

假如此时我们的工程采用配置中心统一管理配置文件,我们只需要在配置中心修改配置内容,正在运行的项目就可以自动更新配置,大大降低了配置文件修改的成本和代价。

Spring Cloud 也为我们提供的配置中心解决方案:Spring Cloud Config

但是该方案似乎目前还是不太完善,例如:

  • 需要结合Spring Cloud Bus 使用,才能实现自动更新。当Server端的配置文件更新后,客户端并不能发现配置文件发生了修改,并实现自动更新。而是依靠Spring Cloud Bus 通知相关的客户端更新配置文件。显然这对于需要我们在项目中添加Spring Cloud Bus,增加了我们工程的复杂度。
  • 配置文件的存储依赖SVN或者git。Spring Cloud Config只是接受客户端的请求,然后从svn和git服务器上读取配置文件,然后发送给客户端。

watermark_type_ZmFuZ3poZW5naGVpdGk_shadow_10_text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L3FxXzI2OTMyMjI1_size_16_color_FFFFFF_t_70

官方给出的介绍

Nacos 提供用于存储配置和其他元数据的 key/value 存储,为分布式系统中的外部化配置提供服务器端和客户端支持。使用 Spring Cloud Alibaba Nacos Config,您可以在 Nacos Server 集中管理你 Spring Cloud 应用的外部属性配置。

Spring Cloud Alibaba Nacos Config 是 Config Server 和 Client 的替代方案,客户端和服务器上的概念与 Spring Environment 和 PropertySource 有着一致的抽象,在特殊的 bootstrap 阶段,配置被加载到 Spring 环境中。当应用程序通过部署管道从开发到测试再到生产时,您可以管理这些环境之间的配置,并确保应用程序具有迁移时需要运行的所有内容。

说了那么多废话,下面开始Nacos

下载Nacos Server端

https://github.com/alibaba/nacos/releases

20190118201352769.png

我下载的是当前的最新稳定版本0.7.0,当前nacos的更新也十分的活跃也已经发布了0.8.0-SNAPSHOT版本。有兴趣的小伙伴也可以下载源码自己打包。

解压

  1. tar -zxvf nacos-server-0.7.0.tar.gz

解压后目录如下:

20190118202726358.png

bin文件夹下存放的启动和停止命令,windows和linux下的启动和关闭命令分别对应cmd和sh文件

20190118202746357.png

conf文件夹下存放配置文件,

20190118202808473.png

启动Nacos Server(官方给出的启动方法如下)

  1. Linux/Unix/Mac
  2. 启动命令(standalone代表着单机模式运行,非集群模式):
  3. sh startup.sh -m standalone
  4. Windows
  5. 启动命令:
  6. cmd startup.cmd
  7. 或者双击startup.cmd运行文件。

windows下双击startup.cmd后出现如下界面

watermark_type_ZmFuZ3poZW5naGVpdGk_shadow_10_text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L3FxXzI2OTMyMjI1_size_16_color_FFFFFF_t_70 1

Linux下启动界面

watermark_type_ZmFuZ3poZW5naGVpdGk_shadow_10_text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L3FxXzI2OTMyMjI1_size_16_color_FFFFFF_t_70 2

控制台打印出现其他情况则可能是出现启动失败 ,可以通过查看启动日志(启动后会在根目录下创建logs文件夹,里面存放了日志),可以查看start.out文件,查看启动日志。

watermark_type_ZmFuZ3poZW5naGVpdGk_shadow_10_text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L3FxXzI2OTMyMjI1_size_16_color_FFFFFF_t_70 3

2019011820432257.png

踩坑

按照官方文档的启动方式,windows系统下可以实现正常启动,但是在linux下出现了上述的情况,启动失败,抛出的异常如下:

  1. startup.sh: 49: startup.sh: [[: not found
  2. startup.sh: 60: startup.sh: [[: not found
  3. /usr/local/jdk1.8.0_192/bin/java -server -Xms2g -Xmx2g -Xmn1g -XX:MetaspaceSize=128m -XX:MaxMetaspaceSize=320m -XX:-OmitStackTraceInFastThrow -XX:+HeapDumpOnOutOfMemoryError -XX:HeapDumpPath=/home/test/nacos/logs/java_heapdump.hprof -XX:-UseLargePages -Xloggc:/home/test/nacos/logs/nacos_gc.log -verbose:gc -XX:+PrintGCDetails -XX:+PrintGCDateStamps -XX:+PrintGCTimeStamps -XX:+UseGCLogFileRotation -XX:NumberOfGCLogFiles=10 -XX:GCLogFileSize=100M -Djava.ext.dirs=/home/test/nacos/plugins/cmdb -Dnacos.home=/home/test/nacos -jar /home/test/nacos/target/nacos-server.jar --spring.config.location=classpath:/,classpath:/config/,file:./,file:./config/,file:/home/test/nacos/conf/ --logging.config=/home/test/nacos/conf/nacos-logback.xml
  4. startup.sh: 79: startup.sh: [[: not found
  5. nacos is startingyou can check the /home/test/nacos/logs/start.out

查看start.out日志文件,如下:

  1. /usr/local/jdk1.8.0_192/bin/java -server -Xms2g -Xmx2g -Xmn1g -XX:MetaspaceSize=128m -XX:MaxMetaspaceSize=320m -XX:-OmitStackTraceInFastThrow -XX:+HeapDumpOnOutOfMemoryError -XX:HeapDumpPath=/home/test/nacos/logs/java_heapdump.hprof -XX:-UseLargePages -Xloggc:/home/test/nacos/logs/nacos_gc.log -verbose:gc -XX:+PrintGCDetails -XX:+PrintGCDateStamps -XX:+PrintGCTimeStamps -XX:+UseGCLogFileRotation -XX:NumberOfGCLogFiles=10 -XX:GCLogFileSize=100M -Djava.ext.dirs=/home/test/nacos/plugins/cmdb -Dnacos.home=/home/test/nacos -jar /home/test/nacos/target/nacos-server.jar --spring.config.location=classpath:/,classpath:/config/,file:./,file:./config/,file:/home/test/nacos/conf/ --logging.config=/home/test/nacos/conf/nacos-logback.xml
  2. ,--.
  3. ,--.'|
  4. ,--,: : | Nacos 0.7.0
  5. ,`--.'`| ' : ,---. Running in cluster mode
  6. | : : | | ' ,'\ .--.--. Port: 8848
  7. : | \ | : ,--.--. ,---. / / | / / ' Pid: 20200
  8. | : ' '; | / \ / \. ; ,. :| : /`./ Console: http://172.17.0.1:8848/nacos/index.html
  9. ' ' ;. ;.--. .-. | / / '' | |: :| : ;_
  10. | | | \ | \__\/: . .. ' / ' | .; : \ \ `. https://nacos.io
  11. ' : | ; .' ," .--.; |' ; :__| : | `----. \
  12. | | '`--' / / ,. |' | '.'|\ \ / / /`--' /
  13. ' : | ; : .' \ : : `----' '--'. /
  14. ; |.' | , .-./\ \ / `--'---'
  15. '---' `--`---' `----'
  16. 2019-01-18 20:39:21,965 ERROR read cluster conf fail
  17. java.io.FileNotFoundException: /home/test/nacos/conf/cluster.conf (No such file or directory)
  18. at java.io.FileInputStream.open0(Native Method)
  19. at java.io.FileInputStream.open(FileInputStream.java:195)
  20. at java.io.FileInputStream.<init>(FileInputStream.java:138)
  21. at com.alibaba.nacos.common.util.SystemUtils.readClusterConf(SystemUtils.java:157)
  22. at com.alibaba.nacos.core.listener.StartingSpringApplicationRunListener.logClusterConf(StartingSpringApplicationRunListener.java:129)
  23. at com.alibaba.nacos.core.listener.StartingSpringApplicationRunListener.contextPrepared(StartingSpringApplicationRunListener.java:79)
  24. at org.springframework.boot.SpringApplicationRunListeners.contextPrepared(SpringApplicationRunListeners.java:60)
  25. at org.springframework.boot.SpringApplication.prepareContext(SpringApplication.java:391)
  26. at org.springframework.boot.SpringApplication.run(SpringApplication.java:331)
  27. at org.springframework.boot.SpringApplication.run(SpringApplication.java:1277)
  28. at org.springframework.boot.SpringApplication.run(SpringApplication.java:1265)
  29. at com.alibaba.nacos.Nacos.main(Nacos.java:31)
  30. at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
  31. at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)
  32. at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
  33. at java.lang.reflect.Method.invoke(Method.java:498)
  34. at org.springframework.boot.loader.MainMethodRunner.run(MainMethodRunner.java:48)
  35. at org.springframework.boot.loader.Launcher.launch(Launcher.java:87)
  36. at org.springframework.boot.loader.Launcher.launch(Launcher.java:50)
  37. at org.springframework.boot.loader.JarLauncher.main(JarLauncher.java:51)
  38. 2019-01-18 20:39:22,980 INFO Nacos is starting...
  39. 2019-01-18 20:39:23,980 INFO Nacos is starting...
  40. 2019-01-18 20:39:24,999 INFO Nacos is starting...
  41. 2019-01-18 20:39:26,000 INFO Nacos is starting...

当时就很疑惑为什么我明明用的单机模式启动,但是日志里面打印的却是以集群模式启动,还以为是启动参数没有传入进去,所以就查看了startup.sh文件

  1. #!/bin/sh
  2. # Copyright 1999-2018 Alibaba Group Holding Ltd.
  3. # Licensed under the Apache License, Version 2.0 (the "License");
  4. # you may not use this file except in compliance with the License.
  5. # You may obtain a copy of the License at
  6. # http://www.apache.org/licenses/LICENSE-2.0
  7. #
  8. # Unless required by applicable law or agreed to in writing, software
  9. # distributed under the License is distributed on an "AS IS" BASIS,
  10. # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  11. # See the License for the specific language governing permissions and
  12. # limitations under the License.
  13. error_exit ()
  14. {
  15. echo "ERROR: $1 !!"
  16. exit 1
  17. }
  18. [ ! -e "$JAVA_HOME/bin/java" ] && JAVA_HOME=$HOME/jdk/java
  19. [ ! -e "$JAVA_HOME/bin/java" ] && JAVA_HOME=/usr/java
  20. [ ! -e "$JAVA_HOME/bin/java" ] && JAVA_HOME=/opt/taobao/java
  21. [ ! -e "$JAVA_HOME/bin/java" ] && error_exit "Please set the JAVA_HOME variable in your environment, We need java(x64)! jdk8 or later is better!"
  22. !!!注,此处设置了默认值是以及群模式启动,所以我就把此处改成了standalone
  23. export MODE="cluster"
  24. while getopts ":m:" opt
  25. do
  26. case $opt in
  27. m)
  28. MODE=$OPTARG
  29. ;;
  30. ?)
  31. echo "Unknown parameter"
  32. exit 1;;
  33. esac
  34. done
  35. export JAVA_HOME
  36. export JAVA="$JAVA_HOME/bin/java"
  37. export BASE_DIR=`cd $(dirname $0)/..; pwd`
  38. export DEFAULT_SEARCH_LOCATIONS="classpath:/,classpath:/config/,file:./,file:./config/"
  39. export CUSTOM_SEARCH_LOCATIONS=${DEFAULT_SEARCH_LOCATIONS},file:${BASE_DIR}/conf/
  40. #===========================================================================================
  41. # JVM Configuration
  42. #===========================================================================================
  43. if [[ "${MODE}" == "standalone" ]]; then
  44. JAVA_OPT="${JAVA_OPT} -Xms512m -Xmx512m -Xmn256m"
  45. JAVA_OPT="${JAVA_OPT} -Dnacos.standalone=true"
  46. else
  47. JAVA_OPT="${JAVA_OPT} -server -Xms2g -Xmx2g -Xmn1g -XX:MetaspaceSize=128m -XX:MaxMetaspaceSize=320m"
  48. JAVA_OPT="${JAVA_OPT} -XX:-OmitStackTraceInFastThrow -XX:+HeapDumpOnOutOfMemoryError -XX:HeapDumpPath=${BASE_DIR}/logs/java_heapdump.hprof"
  49. JAVA_OPT="${JAVA_OPT} -XX:-UseLargePages"
  50. fi
  51. JAVA_MAJOR_VERSION=$($JAVA -version 2>&1 | sed -E -n 's/.* version "([0-9]*).*$/\1/p')
  52. if [[ "$JAVA_MAJOR_VERSION" -ge "9" ]] ; then
  53. JAVA_OPT="${JAVA_OPT} -Xlog:gc*:file=${BASE_DIR}/logs/nacos_gc.log:time,tags:filecount=10,filesize=102400"
  54. else
  55. JAVA_OPT="${JAVA_OPT} -Xloggc:${BASE_DIR}/logs/nacos_gc.log -verbose:gc -XX:+PrintGCDetails -XX:+PrintGCDateStamps -XX:+PrintGCTimeStamps -XX:+UseGCLogFileRotation -XX:NumberOfGCLogFiles=10 -XX:GCLogFileSize=100M"
  56. fi
  57. JAVA_OPT="${JAVA_OPT} -Djava.ext.dirs=${BASE_DIR}/plugins/cmdb"
  58. JAVA_OPT="${JAVA_OPT} -Dnacos.home=${BASE_DIR}"
  59. JAVA_OPT="${JAVA_OPT} -jar ${BASE_DIR}/target/nacos-server.jar"
  60. JAVA_OPT="${JAVA_OPT} ${JAVA_OPT_EXT}"
  61. JAVA_OPT="${JAVA_OPT} --spring.config.location=${CUSTOM_SEARCH_LOCATIONS}"
  62. JAVA_OPT="${JAVA_OPT} --logging.config=${BASE_DIR}/conf/nacos-logback.xml"
  63. if [ ! -d "${BASE_DIR}/logs" ]; then
  64. mkdir ${BASE_DIR}/logs
  65. fi
  66. echo "$JAVA ${JAVA_OPT}"
  67. if [[ "${MODE}" == "standalone" ]]; then
  68. echo "nacos is starting"
  69. $JAVA ${JAVA_OPT}
  70. else
  71. if [ ! -f "${BASE_DIR}/logs/start.out" ]; then
  72. touch "${BASE_DIR}/logs/start.out"
  73. fi
  74. echo "$JAVA ${JAVA_OPT}" > ${BASE_DIR}/logs/start.out 2>&1 &
  75. nohup $JAVA ${JAVA_OPT} >> ${BASE_DIR}/logs/start.out 2>&1 &
  76. echo "nacos is starting锛寉ou can check the ${BASE_DIR}/logs/start.out"
  77. fi

我把启动的默认由cluster改成了standalone单机启动模式,但是启动仍然是集群模式启动,并且抛出上述找不到cluster.conf文件

解决方法:

将官方的启动命令

  1. sh startup.sh -m standalone

替换为

  1. bash startup.sh -m standalone

然后就启动成功了,网上说的原因是:bash与sh是有区别的,两者是不同的命令,且bash是sh的增强版,而”[[]]“是bash脚本中的命令,因此在执行时,使用sh命令会报错。因而是因为startup.sh文件中的[[ ]] 的问题,sh命令并不能识别,只有bash才行。

启动成功后

访问http://localhost:8848/nacos/index.html即可看到如下管理界面

watermark_type_ZmFuZ3poZW5naGVpdGk_shadow_10_text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L3FxXzI2OTMyMjI1_size_16_color_FFFFFF_t_70 4

  1. # nacos/config/application.propertices
  2. server.contextPath=/nacos
  3. server.servlet.contextPath=/nacos
  4. server.port=8848
  5. nacos.cmdb.dumpTaskInterval=3600
  6. nacos.cmdb.eventTaskInterval=10
  7. nacos.cmdb.labelTaskInterval=300
  8. nacos.cmdb.loadDataAtStart=false
  9. #db.num=2
  10. #db.url.0=jdbc:mysql://11.162.196.16:3306/nacos_devtest?characterEncoding=utf8&connectTimeout=1000&socketTimeout=3000&autoReconnect=true
  11. #db.url.1=jdbc:mysql://11.163.152.9:3306/nacos_devtest?characterEncoding=utf8&connectTimeout=1000&socketTimeout=3000&autoReconnect=true
  12. #db.user=nacos_devtest
  13. #db.password=youdontknow

启动成功后默认端口是8848,可以在application.properties 文件中修改server.port,相信用过springboot的同学都不会陌生

原文地址:https://blog.csdn.net/qq_26932225/article/details/86536837

发表评论

表情:
评论列表 (有 0 条评论,253人围观)

还没有评论,来说两句吧...

相关阅读