Nacos快速安装部署(包含单机和集群)

文章正文
发布时间:2025-05-12 00:50

1、下载编译后压缩包

我们直接从上下载Nacos稳定版本即可,我这里下载的是2.0.3版本。

下载完直接解压即可: tar -xzf nacos-server-2.0.3.tar.gz 2、修改配置文件application.

进入到nacos-server-1.4.3/conf目录下,修改application.properties文件,这里我们主要修改MySQL的数据库相关配置。

### If use MySQL as datasource: spring.datasource.platform=mysql ### Count of DB: db.num=1 ### Connect URL of DB: db.url.0=jdbc:mysql://192.168.30.95:3306/nacos_config?characterEncoding=utf8&connectTimeout=1000&socketTimeout=3000&autoReconnect=true&useUnicode=true&useSSL=false&serverTimezone=UTC db.user.0=root db.password.0=zmitzmit ### Connection pool configuration: hikariCP db.pool.config.connectionTimeout=30000 db.pool.config.validationTimeout=10000 db.pool.config.maximumPoolSize=20 db.pool.config.minimumIdle=2

备注:如果不修改spring.datasource.platform配置,则Nacos会使用内置derby数据库。

3、执行数据库脚本

进入nacos-server-2.0.3/conf目录下,执行nacos-mysql.sql文件的数据库脚本。

集群环境搭建

将安装包复制多份

配置数据源、伪集群需要配置端口

将cluster.conf.example复制一份重命名cluster.conf(配置文件目录:nacos安装目录 -> conf)

打开配置文件cluster.conf

配置每个nacos服务的IP和端口

#2022-07-22T02:09:05.916574 192.168.30.95:8840 192.168.30.95:8850 192.168.30.95:8860 4、启动服务器

运行如下命令启动服务器即可:

nacos-server-2.0.3/bin/startup.sh;

单机启动命令

nacos-server-2.0.3/bin/startup.sh  -m standalone 

备注:nacos启动依赖jdk,默认使用jdk1.8启动,jdk11 修改nacos-server-2.0.3/bin/startup.sh文件内容如下:

#!/bin/bash # Copyright 1999-2018 Alibaba Group Holding Ltd. # Licensed under the Apache License, Version 2.0 (the "License"); # you may not use this file except in compliance with the License. # You may obtain a copy of the License at # # # Unless required by applicable law or agreed to in writing, software # distributed under the License is distributed on an "AS IS" BASIS, # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. # See the License for the specific language governing permissions and # limitations under the License. cygwin=false darwin=false os400=false case "`uname`" in CYGWIN*) cygwin=true;; Darwin*) darwin=true;; OS400*) os400=true;; esac error_exit () { echo "ERROR: $1 !!" exit 1 } [ ! -e "$JAVA_HOME/bin/java" ] && JAVA_HOME=$HOME/jdk/java [ ! -e "$JAVA_HOME/bin/java" ] && JAVA_HOME=/usr/java [ ! -e "$JAVA_HOME/bin/java" ] && JAVA_HOME=/opt/taobao/java [ ! -e "$JAVA_HOME/bin/java" ] && unset JAVA_HOME if [ -z "$JAVA_HOME" ]; then if $darwin; then if [ -x '/usr/libexec/java_home' ] ; then export JAVA_HOME=`/usr/libexec/java_home` elif [ -d "/System/Library/Frameworks/JavaVM.framework/Versions/CurrentJDK/Home" ]; then export JAVA_HOME="/System/Library/Frameworks/JavaVM.framework/Versions/CurrentJDK/Home" fi else JAVA_PATH=`dirname $(readlink -f $(which javac))` if [ "x$JAVA_PATH" != "x" ]; then export JAVA_HOME=`dirname $JAVA_PATH 2>/dev/null` fi fi if [ -z "$JAVA_HOME" ]; then error_exit "Please set the JAVA_HOME variable in your environment, We need java(x64)! jdk8 or later is better!" fi fi export SERVER="nacos-server" export MODE="cluster" export FUNCTION_MODE="all" export MEMBER_LIST="" export EMBEDDED_STORAGE="" while getopts ":m:f:s:c:p:" opt do case $opt in m) MODE=$OPTARG;; f) FUNCTION_MODE=$OPTARG;; s) SERVER=$OPTARG;; c) MEMBER_LIST=$OPTARG;; p) EMBEDDED_STORAGE=$OPTARG;; ?) echo "Unknown parameter" exit 1;; esac done export JAVA_HOME export JAVA="$JAVA_HOME/bin/java" export BASE_DIR=`cd $(dirname $0)/..; pwd` export CUSTOM_SEARCH_LOCATIONS=file:${BASE_DIR}/conf/ #=========================================================================================== # JVM Configuration #=========================================================================================== if [[ "${MODE}" == "standalone" ]]; then JAVA_OPT="${JAVA_OPT} -Xms512m -Xmx512m -Xmn256m" JAVA_OPT="${JAVA_OPT} -Dnacos.standalone=true" else if [[ "${EMBEDDED_STORAGE}" == "embedded" ]]; then JAVA_OPT="${JAVA_OPT} -DembeddedStorage=true" fi JAVA_OPT="${JAVA_OPT} -server -Xms2g -Xmx2g -Xmn1g -XX:MetaspaceSize=128m -XX:MaxMetaspaceSize=320m" JAVA_OPT="${JAVA_OPT} -XX:-OmitStackTraceInFastThrow -XX:+HeapDumpOnOutOfMemoryError -XX:HeapDumpPath=${BASE_DIR}/logs/java_heapdump.hprof" JAVA_OPT="${JAVA_OPT} -XX:-UseLargePages" fi if [[ "${FUNCTION_MODE}" == "config" ]]; then JAVA_OPT="${JAVA_OPT} -Dnacos.functionMode=config" elif [[ "${FUNCTION_MODE}" == "naming" ]]; then JAVA_OPT="${JAVA_OPT} -Dnacos.functionMode=naming" fi JAVA_OPT="${JAVA_OPT} -Dnacos.member.list=${MEMBER_LIST}" JAVA_MAJOR_VERSION=$($JAVA -version 2>&1 | sed -E -n 's/.* version "([0-9]*).*$/\1/p') if [[ "$JAVA_MAJOR_VERSION" -ge "9" ]] ; then JAVA_OPT="${JAVA_OPT} -Xlog:gc*:file=${BASE_DIR}/logs/nacos_gc.log:time,tags:filecount=10,filesize=102400" else #JAVA_OPT_EXT_FIX="-Djava.ext.dirs=${JAVA_HOME}/jre/lib/ext:${JAVA_HOME}/lib/ext" JAVA_OPT=JAVA_OPT="${JAVA_OPT} -Djava.ext.dirs=${JAVA_HOME}/jre/lib/ext:${JAVA_HOME}/lib/ext" fi JAVA_OPT="${JAVA_OPT} -Dloader.path=${BASE_DIR}/plugins/health,${BASE_DIR}/plugins/cmdb" JAVA_OPT="${JAVA_OPT} -Dnacos.home=${BASE_DIR}" JAVA_OPT="${JAVA_OPT} -jar ${BASE_DIR}/target/${SERVER}.jar" JAVA_OPT="${JAVA_OPT} ${JAVA_OPT_EXT}" JAVA_OPT="${JAVA_OPT} --spring.config.additional-location=${CUSTOM_SEARCH_LOCATIONS}" JAVA_OPT="${JAVA_OPT} --logging.config=${BASE_DIR}/conf/nacos-logback.xml" JAVA_OPT="${JAVA_OPT} --server.max-http-header-size=524288" if [ ! -d "${BASE_DIR}/logs" ]; then mkdir ${BASE_DIR}/logs fi echo "$JAVA $JAVA_OPT ${JAVA_OPT}" if [[ "${MODE}" == "standalone" ]]; then echo "nacos is starting with standalone" else echo "nacos is starting with cluster" fi # check the start.out log output file if [ ! -f "${BASE_DIR}/logs/start.out" ]; then touch "${BASE_DIR}/logs/start.out" fi # start echo "$JAVA ${JAVA_OPT}" > ${BASE_DIR}/logs/start.out 2>&1 & nohup $JAVA ${JAVA_OPT} nacos.nacos >> ${BASE_DIR}/logs/start.out 2>&1 & echo "nacos is starting,you can check the ${BASE_DIR}/logs/start.out" 5、查看启动日志

进入nacos-server-2.0.3/logs目录下,查看start.out文件。

1. 开启Nacos鉴权模式

找到Nacos配置文件‌:

首先需要找到Nacos文件下的conf/application.properties。

修改配置文件‌:

找到以下配置项并修改为以下内容:

textCopy Code

# If turn on auth system:(是否开启鉴权,这里选择开启)

nacos.core.auth.system.type=nacos nacos.core.auth.enabled=true

在2.2.0.1版本后,社区发布版本将移除以文档如下值作为默认值,需要自行填充,否则无法启动节点。

自定义密钥时,推荐将配置项设置为Base64编码的字符串,且原始密钥长度不得低于32字符: nacos.core.auth.server.identity.key=example nacos.core.auth.server.identity.value=example nacos.core.auth.plugin.nacos.token.secret.key=VGhpc0lzTXlDdXN0b21TZWNyZXRLZXkwMTIzNDU2Nzg=

重启Nacos‌:

修改后不需要重启,刷新即生效。如果觉得不够稳妥,也可以选择重启。

重启指令:在nacos的bin文件下打开cmd,执行startup.cmd -m standalone。

重启之后访问页面会新增一个鉴权访问页面,如果直接进去的也可以重新登录。输入密码,默认nacos/nacos即可进入配置界面。

2. 修改Java项目鉴权配置

在application.yml/bootstrap中添加访问Nacos的账户密码‌:

spring: cloud: nacos: config: password: nacos username: nacos server-addr: 127.0.0.1:8848 discovery: server-addr: 127.0.0.1:8848 password: nacos username: nacos group: DEFAULT_GROUP namespace: public

修改Jar包启动指令‌:

如果不使用网关,可以直接修改Jar包启动指令,添加VM配置项,例如:

textCopy Code

java -Dfile.encoding=utf-8 -Dspring.cloud.nacos.discovery.server-addr=127.0.0.1:8848 -Dspring.cloud.nacos.discovery.password=nacos -Dspring.cloud.nacos.discovery.username=nacos -Dspring.cloud.nacos.config.username=nacos -Dspring.cloud.nacos.config.password=nacos -jar xxx.jar

检查配置‌:

如果配置后仍无法启动,检查用户名/密码是否能在Nacos客户端登录,并拥有权限获取到对应的配置分组。

检查Nacos版本,尝试升级版本可能会解决问题。

请注意,以上配置步骤可能因Nacos版本的不同而有所差异。在实际操作中,请根据您使用的Nacos版本和具体需求进行调整。同时,确保在生产环境中使用复杂且安全的密码,以提高系统的安全性。

首页
评论
分享
Top