精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

分布式ID生成的常見方案~都在這里啦!

云計算 分布式
我們日常開發中,經常需要使用到分布式ID。我們系統一般都是分布式部署的,一些分布式鎖、冪等、數據庫的唯一鍵,都需要分布式ID。

前言

大家好,我是田螺。

我們日常開發中,經常需要使用到分布式ID。我們系統一般都是分布式部署的,一些分布式鎖、冪等、數據庫的唯一鍵,都需要分布式ID。

今天田螺哥盤點一些常見的分布式唯一ID生成方案。

1. 數據庫自增ID

原理:利用數據庫自增字段(如MySQL的AUTO_INCREMENT)生成唯一ID

圖片圖片

優點:簡單易用、ID有序、索引效率高缺點:單點故障、擴展性差(分庫分表困難)
適用場景:單機或簡單主從架構系統

代碼示例

CREATE TABLE orders (
    id INT AUTO_INCREMENT PRIMARY KEY,
    order_data VARCHAR(255)
);

2. UUID

  • 原理:基于MAC地址、時間戳、隨機數生成128位字符串
  • 優點:全局唯一、無需中心化服務
  • 缺點:無序導致索引效率低、存儲空間大(36字符)
  • 適用場景:日志跟蹤、非核心業務(如臨時會話)

我們的項目中,有些伙伴為了簡單方便,有時候會直接用它,如果業務性比較強的,就在它后綴拼接寫個性化標記(業務標記)進來~

代碼示例

import java.util.UUID;
String uuid = UUID.randomUUID().toString();

3. 雪花算法(Snowflake)

  • 原理:64位結構 = 時間戳(41位) + 機器ID(10位) + 序列號(12位)

    圖片圖片

  • 優點:高性能(單機每秒4萬+)、趨勢遞增29
  • 缺點:依賴時鐘同步(時鐘回撥會導致重復)
  • 適用場景:分布式高并發系統(如電商訂單)

其實,我們現在的系統,很多場景就是用雪花算法生成的,如流水號等等~

代碼示例

public class Snowflake {
    private long machineId;
    private long sequence = 0L;
    private long lastTimestamp = -1L;

    public synchronized long nextId() {
        long timestamp = System.currentTimeMillis();
        if (timestamp < lastTimestamp) {
            throw new RuntimeException("時鐘回撥!");
        }
        if (timestamp == lastTimestamp) {
            sequence = (sequence + 1) & 4095; // 12位序列號
            if (sequence == 0) timestamp = tilNextMillis(lastTimestamp);
        } else {
            sequence = 0L;
        }
        lastTimestamp = timestamp;
        return (timestamp << 22) | (machineId << 12) | sequence;
    }
}

4. 數據庫號段模式

  • 原理:批量獲取ID段(如一次取1000個),減少數據庫訪問
  • 優點:降低數據庫壓力、可用性高(緩存號段)、速度快
  • 缺點:在服務器重啟或故障轉移等情況下,可能會導致ID的生成出現不連續的情況。
  • 適用場景:中等并發業務(如用戶ID生成)

我們的一些客戶號,當前是用號段模式生成的,然后拼一些業務標記

表結構:

CREATE TABLE id_segment (
    biz_tag VARCHAR(50) PRIMARY KEY,
    max_id BIGINT NOT NULL,
    step INT NOT NULL,
    version INT NOT NULL
);

5. Redis分布式ID

  • 原理:利用INCR原子操作生成遞增ID

    圖片圖片

  • 優點:性能優于數據庫、天然有序、高性能、可擴展性強
  • 缺點:依賴Redis可用性
  • 適用場景:按日生成的流水號(如訂單號=日期+自增)

代碼示例:

Jedis jedis = new Jedis("redis-host");
Long orderId = jedis.incr("order:20240526");

6.百度的uid-generator

優點:避免頻繁生成、吞吐量提升至600萬/秒
適用場景:超大規模分布式系統

基于Twitter的Snowflake算法進行改進,增加了更多的配置和靈活性。

與原始的snowflake算法不同在于,uid-generator支持自定義時間戳、工作機器ID和 序列號 等各部分的位數,而且uid-generator中采用用戶自定義workId的生成策略。

代碼示例:

import com.baidu.fsg.uid.UidGenerator;  
import com.baidu.fsg.uid.impl.CachedUidGenerator;  
  
public class UidGeneratorDemo {  
  
    public static void main(String[] args) {  
        // 創建一個UidGenerator實例  
        UidGenerator uidGenerator = new CachedUidGenerator();  
  
        // 初始化,這里只是一個簡單的示例,實際使用時你可能需要根據你的業務場景進行更復雜的配置  
        // 例如,設置workerId、epoch等  
        // 注意:在多實例部署時,每個實例的workerId必須唯一  
        long workerId = 1L; // 示例ID,實際使用時需要保證每個實例的唯一性  
        long datacenterId = 1L; // 數據中心ID,示例  
        uidGenerator.init(workerId, datacenterId, null);  
  
        // 生成一個UID  
        long uid = uidGenerator.getUID();  
        System.out.println("Generated UID: " + uid);  
    }  
}


7. 基于Zookeeper的順序節點

利用Zookeeper的順序節點特性來生成全局唯一ID。

圖片圖片

優點:

  • 利用Zookeeper的集群特性保證高可用。
  • ID全局唯一。

缺點:

  • 需要依賴Zookeeper集群。
  • 可能會受到Zookeeper性能的限制。
  • 并發競爭較大不適合用Zookeeper

8. 數據庫集群模式

單庫的數據庫自增ID會存在單點問題,所以可以用數據庫集群模式,去解決這個問題。數據庫集群模式:通過多個數據庫實例設置不同的起始值和步長來生成全局唯一的ID。

圖片圖片


數據庫集群模式優點

  • 可以有效生成集群中的唯一ID。解決了單點的問題。
  • 降低ID生成數據庫操作的負載。

數據庫集群模式缺點

  • 需要獨立部署多個數據庫實例,成本高。
  • 后期不方便擴展

9. 美團(Leaf)

Leaf是美團點評開源的分布式ID生成系統,包含基于數據庫和基于Zookeeper的兩種實現方式。

以基于數據庫的自增ID生成策略為例(數據庫表結構):

CREATE TABLE leaf_alloc (  
    biz_tag VARCHAR(128) NOT NULL COMMENT '業務key',  
    max_id BIGINT(20) NOT NULL COMMENT '當前已分配的最大id',  
    step INT(11) NOT NULL COMMENT '每次id的增長步長',  
    PRIMARY KEY (biz_tag)  
) ENGINE=INNODB DEFAULT CHARSET=utf8mb4;

Java 實現:

import java.sql.*;  
  
public class LeafIdGenerator {  
  
    private static final String JDBC_URL = "jdbc:mysql://localhost:3306/your_database?useSSL=false&serverTimeznotallow=UTC";  
    private static final String USERNAME = "your_username";  
    private static final String PASSWORD = "your_password";  
  
    private static final String UPDATE_SQL = "UPDATE leaf_alloc SET max_id = max_id + ? WHERE biz_tag = ?";  
    private static final String SELECT_SQL = "SELECT max_id FROM leaf_alloc WHERE biz_tag = ? FOR UPDATE";  
  
    public synchronized long getId(String bizTag) throws SQLException {  
        Connection conn = null;  
        PreparedStatement updateStmt = null;  
        PreparedStatement selectStmt = null;  
        ResultSet rs = null;  
  
        try {  
            conn = DriverManager.getConnection(JDBC_URL, USERNAME, PASSWORD);  
            selectStmt = conn.prepareStatement(SELECT_SQL);  
            selectStmt.setString(1, bizTag);  
            rs = selectStmt.executeQuery();  
  
            if (rs.next()) {  
                long maxId = rs.getLong("max_id");  
                int step = 1000; // 假設步長為1000,你可以從數據庫中讀取這個值  
  
                // 假設這里只是簡單演示,不檢查是否超過max_id + step是否溢出  
                updateStmt = conn.prepareStatement(UPDATE_SQL);  
                updateStmt.setInt(1, step);  
                updateStmt.setString(2, bizTag);  
                updateStmt.executeUpdate();  
  
                // 返回ID區間中的一個ID,這里簡單返回maxId(實際應用中可能需要更復雜的策略)  
                return maxId;  
            } else {  
                // 如果沒有找到對應的bizTag,則需要初始化  
                // ... 初始化代碼省略 ...  
                throw new RuntimeException("BizTag not found: " + bizTag);  
            }  
        } finally {  
            // 關閉資源,省略了異常處理  
            if (rs != null) rs.close();  
            if (selectStmt != null) selectStmt.close();  
            if (updateStmt != null) updateStmt.close();  
            if (conn != null) conn.close();  
        }  
    }  
  
    public static void main(String[] args) {  
        LeafIdGenerator generator = new LeafIdGenerator();  
        try {  
            long id = generator.getId("test-biz-tag");  
            System.out.println("Generated ID: " + id);  
        } catch (SQLException e) {  
            e.printStackTrace();  
        }  
    }  
}

優點

  • 結合了數據庫和Zookeeper的優點,提供了高可用和高性能的ID生成服務。缺點:
  • 就是時鐘回撥問題、復雜性高。

10. 滴滴(Tinyid)

Tinyid是滴滴開源的輕量級分布式ID生成系統,它是基于號段模式原理實現的與Leaf如出一轍,每個服務獲取一個號段(1000,2000]、(2000,3000]、(3000,4000]

圖片圖片

以下是一個簡化的Tinyid,服務端的偽代碼:

// 假設我們有一個ID生成器,這里用AtomicLong模擬  
import java.util.concurrent.atomic.AtomicLong;  
  
public class TinyidService {  
    private AtomicLong idGenerator = new AtomicLong(0);  
  
    // 模擬的ID生成方法  
    public synchronized long generateId() {  
        return idGenerator.incrementAndGet();  
    }  
  
    // 這里應該是RESTful API的實現,但為簡化起見,我們省略了HTTP部分  
    // 客戶端應該通過HTTP請求調用此方法  
    public long getIdOverHttp() {  
        return generateId();  
    }  
}

客戶端(Java示例)

import okhttp3.*;  
  
public class TinyidClient {  
    private static final String TINYID_SERVICE_URL = "http://localhost:8080/tinyid/generate";  
  
    public static void main(String[] args) {  
        OkHttpClient client = new OkHttpClient();  
  
        Request request = new Request.Builder()  
                .url(TINYID_SERVICE_URL)  
                .build();  
  
        client.newCall(request).enqueue(new Callback() {  
            @Override  
            public void onFailure(Call call, IOException e) {  
                e.printStackTrace();  
            }  
  
            @Override  
            public void onResponse(Call call, Response response) throws IOException {  
                if (!response.isSuccessful()) {  
                    throw new IOException("Unexpected code " + response);  
                } else {  
                    // 假設服務端返回的是純文本格式的ID  
                    String responseBody = response.body().string();  
                    long id = Long.parseLong(responseBody);  
                    System.out.println("Generated ID: " + id);  
                }  
            }  
        });  
    }  
}
  • 優缺點:簡單、輕量級,但性能可能不如其他方案。
責任編輯:武曉燕 來源: 撿田螺的小男孩
相關推薦

2019-04-24 08:31:43

分布式限流kafka

2025-05-16 09:34:10

2024-07-02 11:16:21

2017-10-24 14:57:58

AI人工智能機器學習

2018-03-19 14:43:28

2018-04-26 16:15:02

數據庫MySQLMySQL 8.0

2021-07-01 09:00:00

安全數字化轉型滲透

2019-06-18 09:10:01

工具策略系統

2019-11-14 08:44:11

分布式系統策略

2021-12-09 08:16:40

JVM參數系統

2019-11-04 09:07:48

DevOps互聯網IT

2023-09-11 08:51:23

LinkedList雙向鏈表線程

2021-06-17 13:40:47

區塊鏈比特幣公有鏈

2021-10-06 16:21:32

類型對象Typescript

2023-12-11 21:59:01

時序分析深度學習自回歸模型

2009-06-24 14:10:22

2017-12-23 14:55:14

Java語言編程

2020-03-18 18:20:19

區塊鏈數字貨幣比特幣

2019-12-04 07:57:22

6G5G網絡

2022-06-16 07:31:15

MySQL服務器服務
點贊
收藏

51CTO技術棧公眾號

精品亚洲国产成人av制服丝袜| 精品视频二区| 色婷婷久久久| 欧美日韩国产中文精品字幕自在自线 | 糖心vlog精品一区二区| 精品视频免费| 欧美一区二区黄| 中文字幕成人一区| 国产熟女精品视频| 伊人久久大香线蕉综合热线| 亚洲第五色综合网| 国语对白做受xxxxx在线中国 | 亚洲精品91美女久久久久久久| 国产一区二区三区在线免费观看 | 欧美一级性视频| 亚洲视频www| 亚洲天堂av在线免费| 午夜免费看毛片| 青草青在线视频| 久久综合九色综合欧美98| 国产精品久久久久av免费| 国产传媒视频在线| 国产日韩一区| 青青草国产成人99久久| 国产91色综合久久免费分享| 久久天天躁夜夜躁狠狠躁2022| 日本77777| 黄页网站大全在线免费观看| 99久久精品国产导航| 懂色av噜噜一区二区三区av| 久久五月天综合| 欧美xxxx×黑人性爽| 美女视频在线免费| 中文字幕日本不卡| 久久久久se| 国产污视频网站| 日韩精品一区二区亚洲av| 全球成人免费直播| 白嫩亚洲一区二区三区| 韩国精品一区二区| 78色国产精品| 久久久精品视频免费观看| 日韩超碰人人爽人人做人人添| 在线免费亚洲电影| 国精产品一区一区三区视频| 免费在线看黄色| 91农村精品一区二区在线| 成人妇女淫片aaaa视频| 日韩欧美中文字幕一区二区| 国产精品久久久乱弄| 亚洲视频欧洲视频| 国产精品无码在线| 你懂得影院夜精品a| 一区二区免费看| 一区二区视频在线观看| 国产资源在线观看| www欧美成人18+| 国产一区二区精品在线| 国产又粗又猛又爽又黄的视频一| 欧美一级播放| 欧美激情一级精品国产| 亚洲一级生活片| 久久福利影院| 在线播放国产一区中文字幕剧情欧美| 亚洲免费电影在线观看| 波多野结衣 作品| 99青草视频在线播放视| 成人激情校园春色| 国产欧美日韩一区| 亚洲av无码国产精品永久一区| 免费成人在线视频观看| 日韩av手机在线看| 在线观看日韩中文字幕| 国产精品日本| 26uuu久久噜噜噜噜| 日本在线视频中文字幕| 99香蕉国产精品偷在线观看| 欧美激情综合色综合啪啪五月| 久久精品亚洲a| 国产精品久久久久蜜臀| www.日韩av.com| 无码人中文字幕| 亚洲精品小说| 欧美精品免费播放| 北条麻妃在线观看视频| 99久久视频| 欧美高跟鞋交xxxxhd| 精品处破女学生| 一本久道久久综合婷婷鲸鱼| 91成人在线播放| 久久久久久少妇| 日韩不卡免费视频| 91精品国产综合久久男男| 国产三级伦理片| 国产精品一品二品| 亚洲xxxxx| 好吊色在线观看| 久久亚洲一区二区三区四区| 欧洲精品码一区二区三区免费看| 天天摸天天碰天天爽天天弄| 91麻豆国产香蕉久久精品| 青青影院一区二区三区四区| 在线免费看a| 亚洲精选一二三| 激情深爱综合网| 美女色狠狠久久| 日韩午夜激情视频| 国产ts丝袜人妖系列视频| 教室别恋欧美无删减版| 国产亚洲a∨片在线观看| 国产成人一区二区在线观看| 国产精品成人av| 国内揄拍国内精品少妇国语| 日本黄色中文字幕| 国产一区999| 久久精品丝袜高跟鞋| 国产二区视频在线观看| 亚洲欧美欧美一区二区三区| 黄色免费福利视频| 日韩黄色在线| 亚洲精品美女在线观看播放| 手机av在线不卡| 日韩视频二区| 成人黄色av播放免费| 国内精品久久久久久久久久| 成人黄色a**站在线观看| 色一情一乱一伦一区二区三欧美| 91香蕉在线观看| 色菇凉天天综合网| 国产91在线免费观看| 亚洲婷婷影院| 欧美黑人极品猛少妇色xxxxx| 亚洲欧美偷拍一区| 国产成人h网站| 亚洲国产精品一区在线观看不卡| 欧美xxxx少妇| 欧美少妇性性性| 狠狠人妻久久久久久综合蜜桃| 色婷婷一区二区三区| 久久免费视频观看| 一区二区 亚洲| 久久一留热品黄| 日韩欧美不卡在线| 国产精品欧美一区二区三区不卡| 亚洲视频免费一区| 国产 欧美 日韩 在线| 国产一区二区三区在线观看精品| 欧洲av一区| 在线毛片观看| 亚洲国产欧美一区| 久草免费新视频| 国产一区二区不卡在线| 亚洲一区二区三区加勒比| 女人让男人操自己视频在线观看 | 在线电影一区| 97视频中文字幕| 黄在线免费看| 欧美日韩精品欧美日韩精品一| 久久久久国产精品区片区无码| 欧美日韩精选| 99久久精品久久久久久ai换脸| 午夜激情视频在线观看| 欧美专区日韩专区| 极品人妻videosss人妻| 三级在线观看一区二区| 久久久人人爽| 91禁在线看| 精品国产精品网麻豆系列| av激情在线观看| 国产乱码精品一品二品| 大地资源第二页在线观看高清版| 四虎精品一区二区免费| 日韩在线观看免费| 国产在成人精品线拍偷自揄拍| 国产精品美女久久久久久久久久久 | 久久天天躁狠狠躁夜夜躁2014| 依依成人在线视频| 中文字幕日本乱码精品影院| 日本在线播放一区二区| 久久久久国产精品| 2014亚洲精品| 污视频网站在线免费| 日韩女优av电影| 国产一级视频在线| 91亚洲午夜精品久久久久久| 国产一区二区网| 狼人精品一区二区三区在线| 91国在线精品国内播放| 精品一二三区视频| 欧美日产国产精品| 欧美成人黄色网| 97久久精品人人爽人人爽蜜臀| 日本xxxxxxx免费视频| 日韩理论电影院| 91精品久久久久久蜜桃| 波多一区二区| 亚洲欧美精品suv| 亚洲一区二区激情| 亚洲一区二区不卡免费| 97人妻天天摸天天爽天天| 青青草国产成人99久久| 国产免费内射又粗又爽密桃视频| 久久男人av| 国产精品入口尤物| 欧美巨大xxxx做受沙滩| 日韩成人在线免费观看| 瑟瑟视频在线免费观看| 亚洲日本在线天堂| 久久无码人妻精品一区二区三区| 久久精品一区二区国产| 欧美三级午夜理伦三级老人| 福利片一区二区| 国产精品露脸自拍| 草美女在线观看| 日韩在线视频中文字幕| 97人妻精品一区二区三区视频| 天天色天天操综合| 俄罗斯毛片基地| 粉嫩aⅴ一区二区三区四区| 国产性生交xxxxx免费| 午夜精品偷拍| 亚洲成人自拍| 亚洲网一区二区三区| 国产激情久久久| 91亚洲天堂| 最近2019中文字幕mv免费看 | 国产一二区在线观看| 日韩av在线网站| 99久久精品国产色欲| 一本大道av伊人久久综合| 91杏吧porn蝌蚪| 国产精品亲子伦对白| 中文字幕在线播放一区| 韩国一区二区在线观看| 欧美视频免费播放| 亚洲国产专区校园欧美| 一区不卡视频| 亚州精品视频| 97国产超碰| 99久久精品一区二区成人| 韩日精品中文字幕| 午夜伦理在线视频| 精品国产依人香蕉在线精品| 国产在线视频网站| 亚洲国产精品字幕| 肥臀熟女一区二区三区| 7777精品伊人久久久大香线蕉经典版下载 | 成人性生交大片免费看视频在线| 成人日韩在线视频| 日本在线观看不卡视频| 男人的天堂99| 亚洲综合精品四区| 色综合久久久久无码专区| 国自产拍偷拍福利精品免费一| 中文字幕99| 99久久亚洲精品蜜臀| 亚欧精品在线| 欧洲毛片在线视频免费观看| 欧美成人免费在线| 亚洲福利天堂| 免费日韩av电影| 伊人久久大香线蕉av不卡| 精品国产一区二区三区四区精华 | 成人在线观看黄| 暖暖视频在线免费观看| 欧美日韩不卡视频| 中文字幕 亚洲视频| 一本色道久久综合狠狠躁的推荐| 精品91久久久| 午夜视黄欧洲亚洲| 日本在线视频免费| 亚洲在线免费播放| 久久久久无码精品国产| 亚洲中国最大av网站| xxxx日本少妇| 亚洲一区二区欧美| 国偷自拍第113页| 欧美性xxxxxx| 亚洲免费在线观看av| 精品露脸国产偷人在视频| 青青国产在线观看| 色婷婷综合中文久久一本| 欧美日韩在线视频播放| 欧美色网一区二区| 国产欧美综合视频| 日韩精品专区在线影院观看| 欧美特黄一级视频| 亚洲第一综合天堂另类专| 狠狠躁夜夜躁av无码中文幕| 亚洲国产天堂网精品网站| 青青操在线视频| 在线亚洲国产精品网| 黄色网在线播放| 午夜精品视频在线| 日韩不卡视频在线观看| 91精品视频免费观看| 91麻豆精品激情在线观看最新 | 亚洲图片小说在线| 亚洲视频电影在线| 久久久久久人妻一区二区三区| 亚洲精品字幕| 日韩大片一区二区| 欧美性一级生活| 日韩在线视频观看| 青青国产在线视频| 欧美日韩一区二区三区高清| 亚洲精品无码久久久久| 欧美一区二区福利在线| 亚洲 美腿 欧美 偷拍| 亚洲人成电影在线播放| 日韩在线免费电影| 久久久伊人欧美| 成人黄色在线| 成人av免费看| 毛片在线不卡| 国产偷自视频区视频一区二区| 大片在线观看网站免费收看| 在线成人亚洲| www.com久久久| 91麻豆免费在线观看| 色偷偷www8888| 亚洲欧美福利一区二区| yjizz国产| 日韩一区二区三区免费看| 青青久在线视频| 欧美乱大交xxxxx| 日本一道高清亚洲日美韩| 国产男女猛烈无遮挡91| 欧美成人基地| 国产午夜精品视频一区二区三区| 日本在线不卡视频一二三区| 亚洲第九十七页| 亚洲电影一区二区| 成人免费公开视频| 欧美激情久久久久久| 国产va免费精品观看精品| 亚洲高清在线观看一区| 日日噜噜夜夜狠狠视频欧美人| 中文字幕无码人妻少妇免费| 一区二区免费在线| 国产高清在线观看视频| 久热在线中文字幕色999舞| 黄瓜视频成人app免费| 欧美亚洲另类久久综合| 老鸭窝91久久精品色噜噜导演| 中文在线观看免费视频| 亚洲国产精品尤物yw在线观看| 99久久精品免费看国产交换| 日韩性xxxx爱| 二区三区精品| 无码人妻精品一区二区三区99v| 久久精品免费观看| 男人av资源站| 在线观看污视频| 日韩在线电影| 日韩伦理一区二区三区av在线| 亚洲一区日本| 魔女鞋交玉足榨精调教| 欧美性猛交xxxx久久久| 欧洲视频在线免费观看| 91影院在线观看| 九九精品在线观看视频 | 日韩在线中文视频| 51漫画成人app入口| 国产精品一区二区三区免费| 亚洲美女黄网| 91网站免费视频| 欧美日韩精品高清| av大全在线| 精品不卡一区二区三区| 爽好多水快深点欧美视频| 国产aaaaaaaaa| 91精品国产日韩91久久久久久| 欧美videos另类精品| 国产乱码精品一区二区三区日韩精品 | 久久91超碰青草在哪里看| 视频一区二区视频| 成人免费看黄yyy456| 蜜臀精品一区二区三区| 久久精品电影网站| 红杏视频成人| 午夜激情av在线| 亚洲在线中文字幕| 国产精品免费播放| 99久久综合狠狠综合久久止 | 2018国产精品视频| 日韩av密桃| a天堂视频在线观看| 欧美亚洲精品一区| 欧美另类tv| 亚洲成人18| 成人手机在线视频| 黄色一区二区视频| 久久久久久久国产| 日韩免费特黄一二三区| 国模无码视频一区| 欧美美女黄视频| 无遮挡在线观看| 中文字幕乱码免费| 国产欧美精品日韩区二区麻豆天美|