下解解壓後,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