2020年11月13日 星期五

Nacos ( SpringCloud 2.x 八)

下載nacos
下解解壓後,bin 下有開啟和關閉nacos的程式,副檔名cmd用在windows;sh用在linux
有兩種模式,cluster 和 standalone,預設使用cluster,如果什麼都不做直接啟動會失敗(需要有conf/cluster.conf),改成 standalone才可以啟動,以 windows當例子,打開start.cmd,如下修改即可:
紅框是nacos的判斷,只有兩種,copy到綠框改一下即可
啟動後,開啟 localhost:8848/nacos,預設的帳號密碼都是 nacos,想改密碼如下操作:

點擊權限控制的用戶列表,然後對使用者按修改可改密碼
綠框是改界面的語言



<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

Lombok 的 builder 繼承

@Data
@EqualsAndHashCode(callSuper = true)
@SuperBuilder
@AllArgsConstructor
@NoArgsConstructor
@ToString(callSuper = true)
public class Me extends Father {
    private String color;
}

@Data
@EqualsAndHashCode(callSuper = true)
@SuperBuilder
@AllArgsConstructor
@NoArgsConstructor
@ToString(callSuper = true)
public class Father extends GrandFather {
    private int id;
}

@Data
@SuperBuilder
@AllArgsConstructor
@NoArgsConstructor
public class GrandFather {
    private int age;
}

// test
Me me = Me.builder()
			.color("red")
			.id(555)
			.age(78)
			.build();
	System.out.println(me);
	System.out.println(me.getColor());
	System.out.println(me.getAge());

※必需使用 @SuperBuilder 註解,父子類都要,使用 1.18.16 版本測試的