下解解壓後,bin 下有開啟和關閉nacos的程式,副檔名cmd用在windows;sh用在linux
有兩種模式,cluster 和 standalone,預設使用cluster,如果什麼都不做直接啟動會失敗(需要有conf/cluster.conf),改成 standalone才可以啟動,以 windows當例子,打開start.cmd,如下修改即可:
紅框是nacos的判斷,只有兩種,copy到綠框改一下即可啟動後,開啟 localhost:8848/nacos,預設的帳號密碼都是 nacos,想改密碼如下操作:
點擊權限控制的用戶列表,然後對使用者按修改可改密碼
綠框是改界面的語言
主pom下有兩個module
兩個子pom內容一樣
<modules>
<module>DiscoveryConsumer</module>
<module>DiscoveryProvider</module>
</modules>
<parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>2.3.5.RELEASE</version>
<relativePath/> <!-- lookup parent from repository -->
</parent>
<groupId>bruce.home</groupId>
<artifactId>SpringCloudPractice</artifactId>
<version>0.0.1-SNAPSHOT</version>
<packaging>pom</packaging>
<name>SpringCloudPractice</name>
<description>Demo project for Spring Boot</description>
<properties>
<java.version>11</java.version>
<spring-cloud.version>Hoxton.SR4</spring-cloud.version>
<nacos.version>2.2.3.RELEASE</nacos.version>
</properties>
<dependencyManagement>
<dependencies>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-dependencies</artifactId>
<version>${spring-cloud.version}</version>
<type>pom</type>
<scope>import</scope>
</dependency>
<dependency>
<groupId>com.alibaba.cloud</groupId>
<artifactId>spring-cloud-starter-alibaba-nacos-config</artifactId>
<version>${nacos.version}</version>
</dependency>
<dependency>
<groupId>com.alibaba.cloud</groupId>
<artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
<version>${nacos.version}</version>
</dependency>
<dependency>
<groupId>org.projectlombok</groupId>
<artifactId>lombok</artifactId>
<version>1.18.16</version>
<scope>provided</scope>
</dependency>
</dependencies>
</dependencyManagement>
主pom下有兩個module
<properties> <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding> <maven.compiler.source>11</maven.compiler.source> <maven.compiler.target>11</maven.compiler.target> </properties> <dependencies> <!--<dependency>--> <!-- <groupId>com.alibaba.cloud</groupId>--> <!-- <artifactId>spring-cloud-starter-alibaba-nacos-config</artifactId>--> <!--</dependency>--> <dependency> <groupId>com.alibaba.cloud</groupId> <artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId> </dependency> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-web</artifactId> </dependency> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-test</artifactId> <scope>test</scope> </dependency> </dependencies>
兩個子pom內容一樣
子專按的 spring-boot-start-web 一定要有,否則不會註冊到 nacos,如果註冊成功會在控制台顯示
當然yml也要設定
也可以在nacos控制台看
服務名是 spring.application.name
※改變資料庫
內鍵的資料庫是derby,可以換成 mysql,打開 conf/application.properties,將底下的五行註解打開,帳密資料庫名稱修改一下即可!然後將conf/nacos-mysql.sql 執行到自己的資料庫,結果如下兩張圖,控制台可看到差異
※集群設定
集群至少要三個以上(含)才可以,且一定不能是內鍵資料庫,不然就不能共享了
conf/cluster.conf.example 修改或新增一個檔案成為 cluster.conf,內容如下:
127.0.0.1:9000
127.0.0.1:9001
127.0.0.1:9002
然後將整個 nacos 複製成三份,然後改變 application.properties 的 port 成為以上三個 port
最後用類似 nginx 這種負載均衡的軟體來轉發,nginx.conf 如下,只貼最重要的部分:
http {
upstream clusterNacos {
server 127.0.0.1:9000;
server 127.0.0.1:9001;
server 127.0.0.1:9002;
}
server {
listen 9003;
server_name localhost;
location / {
proxy_pass http://clusterNacos;
}
}
}
使用 localhost:9003/nacos 就會轉發三台了,「集群管理/節點列表」可看到結果
源碼請看github





