主頁 > 後端開發 > Kafka集群搭建

Kafka集群搭建

2021-04-12 06:07:08 後端開發

ZooKeeper 的作用

Kafka使用ZooKeeper管理集群,ZooKeeper用于協調服務器或集群拓撲,ZooKeeper是配置資訊的一致性檔案系統,你可以選擇Kafka自帶的Zookeeper,也可以選擇單獨部署,一臺Linux主機開放三個埠即可構建一個簡單的偽ZooKeeper集群,

ZooKeeper可以將拓撲更改發送到Kafka,如果集群中的某臺服務器宕機或者某個topic被添加、洗掉,集群中的每個節點都可以知道新服務器何時加入,ZooKeeper提供Kafka Cluster配置的同步視圖,

Zookeeper簡介

ZooKeeper 是一個開源的分布式框架,提供了協調分布式應用的基本服務,它向外部應用 暴露一組通用服務——分布式同步(Distributed Synchronization)、命名服務(Naming Service)、集群維護(group maintenance)等,簡化分布式應用協調及其管理的難度, 它是 google 的 chubby 一個開源的實作, 它本身可以搭建成一個集群,這個 zk 集群用來對應用程式集群進行管理,監視應用程式集群中各個節點的狀態,并根據應用程式集群中各個節點提交的反饋資訊決定下一步的合理操作, 做分布式鎖很有效 image

Zookeeper下載和安裝

實作的是Zookeeper集群的創建,注意要修改zoo.dfg檔案名稱

(base) root@top1server:~# wget https://archive.apache.org/dist/zookeeper/zookeeper-3.4.10/zookeeper-3.4.10.tar.gz
(base) root@top1server:~# tar -zvxf zookeeper-3.4.10.tar.gz
(base) root@top1server:~# cp -r zookeeper-3.4.10/ zookeeper1
(base) root@top1server:~# cp -r zookeeper-3.4.10/ zookeeper2
(base) root@top1server:~# cp -r zookeeper-3.4.10/ zookeeper3
(base) root@top1server:~/zookeeper/zookeeper1/conf# mv zoo_sample.cfg zoo.cfg
(base) root@top1server:~/zookeeper/zookeeper1/bin# ./zkServer.sh start
(base) root@top1server:~/zookeeper/zookeeper1/bin# ./zkServer.sh status

image

image

部署三個節點的Zookeeper偽分布集群

在同一臺服務器上,部署一個 3 個 ZooKeeper 節點組成的集群,這樣的集群叫偽分布式集群,而如果集群中的 3 個節點分別部署在 3 個服務器上,那么這種集群就叫真正的分布式集群,

(base) root@top1server:~/zookeeper# cd zookeeper1
(base) root@top1server:~/zookeeper/zookeeper1# mkdir data
(base) root@top1server:~/zookeeper/zookeeper1# mkdir logs
(base) root@top1server:~/zookeeper/zookeeper1# touch data/myid
(base) root@top1server:~/zookeeper/zookeeper1# cd data/
(base) root@top1server:~/zookeeper/zookeeper1/data# cat myid
1

設定組態檔 zoo.cfg 的內容如下:
image

組態檔中的配置項的含義參見下面的介紹,

  • 用同樣的方法,在 zookeeper2 和 zookeeper3 的相應位置創建 zoo.cfg,檔案內容復制zookeeper1 的 zoo.cfg,
  • 只不過需要改動 clientport、dataDir、dataLogDir 三個配置項,zookeeper2 的 clientport 改為 2182,zookeeper3 的 clientport 改為 2183,而 dataDir和 dataLogDir 都修改為相應的目錄,就好了,

啟動 zk 集群

接下來再分別啟動服務

(base) root@top1server:~/zookeeper/zookeeper1/bin# sh zkServer.sh start
(base) root@top1server:~/zookeeper/zookeeper2/bin# sh zkServer.sh start
(base) root@top1server:~/zookeeper/zookeeper3/bin# sh zkServer.sh start

這樣 zookeeper 集群的 3 個節點都啟動起來了,
image

image

image

image
一個leader多個server,也遵循2n+1的選舉策略,想保證高可用至少有三臺機器

客戶端接入集群

進入 zookeeper 集群中任意一個節點的 bin 目錄下,啟動一個客戶端,接入已經啟動好的zookeeper 集群,
這里的 server 可以填寫集群中的任何一個節點的 ip,埠號是對應 ip的節點的組態檔中 clientport 的值,

./zkCli.sh –server 127.0.0.1:2181

真實分布式集群需要注意的地方

真正的分布式集群和偽分布式集群不一樣的地方在于組態檔,

  1. clientport 埠各個節點一樣就行,
  2. server.1=127.0.0.1:8880:7770 中的 ip 要修改成對應的 server 的 ip,后邊的兩個埠號不需要不同,各個節點都一樣就可以了,
    其他地方偽分布式和真正分布式都是一樣的,

ZooKeeper 組態檔中的配置項的含義

組態檔中配置項的含義:

  • tickTime: zookeeper 中使用的基本時間單位,毫秒值,比如可以設為 1000,那么基本時間單位就是 1000ms,也就是 1s,
  • initLimit: zookeeper 集群中的包含多臺 server,其中一臺為 leader,集群中其余的 server 為 follower,initLimit 引數配置初始化連接時,follower 和 leader 之間的最長 心 跳 時 間 , 如 果 該 參 數 設 置 為 5 , 就 說 明 時 間 限 制 為 5 倍 tickTime , 即5*1000=5000ms=5s,
  • syncLimit: 該引數配置 leader 和 follower 之間發送訊息,請求和應答的最大時間長度,如果該引數設定為 2,說明時間限制為 2 倍 tickTime,即 2000ms,
  • dataDir: 資料目錄. 可以是任意目錄,一般是節點安裝目錄下 data 目錄,
  • dataLogDir: log目錄, 同樣可以是任意目錄,一般是節點安裝目錄下的logs目錄,如果沒有設定該引數,將使用和 dataDir 相同的設定,
  • clientPort: 監聽 client 連接的埠號,
  • server.X=A:B:C 其中 X 是一個數字, 表示這是第幾號 server,它的值和 myid 檔案中的值對應,A 是該 server 所在的 IP 地址,B 是配置該 server 和集群中的 leader 交換訊息所使用的埠,C 配置選舉 leader 時所使用的埠,由于配置的是偽集群模式,所以各個 server 的 B, C 引數必須不同,如果是真正分布式集群,那么 B 和 C 在各個節點上可以相同,因為即使相同由于節點處于不同的服務器也不會導致埠沖突

Zookeeper 常用命令

  1. 啟動 ZK 服務: bin/zkServer.sh start
  2. 查看 ZK 服務狀態: bin/zkServer.sh status
  3. 停止 ZK 服務: bin/zkServer.sh stop
  4. 重啟 ZK 服務: bin/zkServer.sh restart
  5. 連接服務器: zkCli.sh -server 127.0.0.1:2181

image

創建節點

使用 create 命令,可以創建一個 Zookeeper 節點, 如

create [-s] [-e] path data acl

其中,-s 或-e 分別指定節點特性,順序或臨時節點,若不指定,則表示持久節點;acl 用來進行權限控制,

image
順序節點可以看到創建的節點后面添加了一串數字以示區別,
image

image
臨時節點在退出會自動洗掉

使用 create /zk-permanent 123 命令創建 zk-permanent 永久節點
可以看到永久節點不同于順序節點,不會自動在后面添加一串數字,
image

讀取節點

與讀取相關的命令有 ls 命令和 get 命令,ls 命令可以列出 Zookeeper 指定節點下的所有子節點,只能查看指定節點下的第一級的所有子節點;
get 命令可以獲取 ZK 指定節點的資料內容和屬性資訊,其用法分別如下

ls path [watch]
get path [watch]
ls2 path [watch]

ls2可以查看所有內容
get可以獲取系欸但的資料內容和屬性

更新節點

使用 set 命令,可以更新指定節點的資料內容,用法如下

set path data [version]

其中,data 就是要更新的新內容,version 表示資料版本,如將/zk-permanent 節點的資料更新為 456,可以使用如下命令:set /zk-permanent 456
dataVersion 會變為 1 了,表示進行了更新,

洗掉節點

使用 delete 命令可以洗掉 Zookeeper 上的指定節點,用法如下

delete path [version]

其 中 version 也 是 表 示 數 據 版 本 , 使 用 delete /zk-permanent 命 令 即 可 刪 除/zk-permanent 節點

值得注意的是,若洗掉節點存在子節點,那么無法洗掉該節點,必須先洗掉子節點,再洗掉父節點

zk的使用都是靠這些節點使用

分布式鎖的生成是用臨時順序節點來實作的

Kafka概述

Kafka訊息佇列

image
(1)點對點模式(一對一,消費者主動拉取資料,訊息收到后訊息清除)
點對點模型通常是一個基于拉取或者輪詢的訊息傳送模型,這種模型從佇列中請求資訊,而不是將訊息推送到客戶端,這個模型的特點是發送到佇列的訊息被一個且只有一個接收者接收處理,即使有多個訊息監聽者也是如此,
(2)發布/訂閱模式(一對多,資料生產后,推送給所有訂閱者)
發布訂閱模型則是一個基于推送的訊息傳送模型,發布訂閱模型可以有多種不同的訂閱者,臨時訂閱者只在主動監聽主題時才接收訊息,而持久訂閱者則監聽主題的所有訊息,即使當前訂閱者不可用,處于離線狀態,

為什么需要訊息佇列

1)解耦:
允許你獨立的擴展或修改兩邊的處理程序,只要確保它們遵守同樣的介面約束,
2)冗余:
訊息佇列把資料進行持久化直到它們已經被完全處理,通過這一方式規避了資料丟失風險,許多訊息佇列所采用的"插入-獲取-洗掉"范式中,在把一個訊息從佇列中洗掉之前,需要你的處理系統明確的指出該訊息已經被處理完畢,從而確保你的資料被安全的保存直到你使用完畢,
3)擴展性:
因為訊息佇列解耦了你的處理程序,所以增大訊息入隊和處理的頻率是很容易的,只要另外增加處理程序即可,
4)靈活性 & 峰值處理能力:
在訪問量劇增的情況下,應用仍然需要繼續發揮作用,但是這樣的突發流量并不常見,如果為以能處理這類峰值訪問為標準來投入資源隨時待命無疑是巨大的浪費,使用訊息佇列能夠使關鍵組件頂住突發的訪問壓力,而不會因為突發的超負荷的請求而完全崩潰,
5)可恢復性:
系統的一部分組件失效時,不會影響到整個系統,訊息佇列降低了行程間的耦合度,所以即使一個處理訊息的行程掛掉,加入佇列中的訊息仍然可以在系統恢復后被處理,
6)順序保證:
在大多使用場景下,資料處理的順序都很重要,大部分訊息佇列本來就是排序的,并且能保證資料會按照特定的順序來處理,(Kafka 保證一個 Partition 內的訊息的有序性)
7)緩沖:
有助于控制和優化資料流經過系統的速度,解決生產訊息和消費訊息的處理速度不一致的情況,
8)異步通信:
很多時候,用戶不想也不需要立即處理訊息,訊息佇列提供了異步處理機制,允許用戶把一個訊息放入佇列,但并不立即處理它,想向佇列中放入多少訊息就放多少,然后在需要的時候再去處理它們,

什么是 Kafka

在流式計算中,Kafka 一般用來快取資料,Storm 通過消費 Kafka 的資料進行計算,
1)Apache Kafka 是一個開源訊息系統,由 Scala 寫成,是由 Apache 軟體基金會開發的一個開源訊息系統專案,
2)Kafka 最初是由 LinkedIn 公司開發,并于 2011 年初開源,2012 年 10 月從 Apache Incubator畢業,該專案的目標是為處理實時資料提供一個統一、高通量、低等待的平臺,
3)Kafka 是一個分布式訊息佇列,Kafka 對訊息保存時根據 Topic 進行歸類,發送訊息者稱為Producer,訊息接受者稱為 Consumer,此外 kafka 集群有多個 kafka 實體組成,每個實體(server)稱為broker,
4)無論是 kafka 集群,還是 consumer 都依賴于 zookeeper 集群保存一些 meta 資訊,來保證系統可用性,
image
1)Producer :訊息生產者,就是向 kafka broker 發訊息的客戶端;
2)Consumer :訊息消費者,向 kafka broker 取訊息的客戶端;
3)Topic :可以理解為一個佇列;
4) Consumer Group (CG):這是 kafka 用來實作一個 topic 訊息的廣播(發給所有的 consumer)和單播(發給任意一個 consumer)的手段,一個 topic 可以有多個 CG,topic 的訊息會復制(不是真的復制,是概念上的)到所有的 CG,但每個 partion 只會把訊息發給該 CG 中的一個 consumer,如果需要實作廣播,只要每個 consumer 有一個獨立的 CG 就可以了,要實作單播只要所有的consumer 在同一個 CG,用 CG 還可以將 consumer 進行自由的分組而不需要多次發送訊息到不同的 topic;
5)Broker :一臺 kafka 服務器就是一個 broker,一個集群由多個 broker 組成,一個 broker 可以容納多個 topic;
6)Partition:為了實作擴展性,一個非常大的 topic 可以分布到多個 broker(即服務器)上,一個 topic可以分為多個 partition,每個 partition 是一個有序的佇列,partition 中的每條訊息都會被分配一個有序的 id(offset),kafka 只保證按一個 partition 中的順序將訊息發給 consumer,不保證一個 topic 的整體(多個 partition 間)的順序;
7)Offset:kafka 的存盤檔案都是按照 offset.kafka 來命名,用 offset 做名字的好處是方便查找,例如你 想 找 位 于 2049 的 位 置 , 只 要 找 到 2048.kafka 的 文 件 即 可 , 當 然 the first offset 就 是
00000000000.kafka,

Kafka 單節點運行方式

https://kafka.apache.org/

下載代碼

下載 kafka_2.13-2.7.0 版本并且解壓,
https://downloads.apache.org/kafka/2.7.0/kafka_2.13-2.7.0.tgz

wget https://downloads.apache.org/kafka/2.7.0/kafka_2.13-2.7.0.tgz
tar -zvxf kafka_2.13-2.7.0.tgz
cd kafka_2.13-2.7.0/

首先為每個 broker 創建一個組態檔,直接復制多個server.properties,并且修改他們的log日志和id

Kafka 集群部署方式

配置broker的id
image
設定log檔案地址
image
關聯zookeeper
image

啟動服務

現在啟動 Kafka 服務器:

bin/kafka-server-start.sh config/server.properties

創建topic

創建一個名為“test”的 topic,它有一個磁區和一個副本:

bin/kafka-topics.sh --create --zookeeper localhost:2181 --replication-factor 1 --partitions 1 --topic test

運行 list(串列)命令來查看這個 topic:

bin/kafka-topics.sh --list --zookeeper localhost:2181 test

除了手工創建 topic 外,你也可以配置你的 broker,當發布一個不存在的 topic 時自動創建 topic,

轉載請註明出處,本文鏈接:https://www.uj5u.com/houduan/274972.html

標籤:Java

上一篇:Java中的equals()和hashCode() - 超詳細篇

下一篇:[SpringCloud教程]4. Zookeeper服務注冊中心集成

標籤雲
其他(157675) Python(38076) JavaScript(25376) Java(17977) C(15215) 區塊鏈(8255) C#(7972) AI(7469) 爪哇(7425) MySQL(7132) html(6777) 基礎類(6313) sql(6102) 熊猫(6058) PHP(5869) 数组(5741) R(5409) Linux(5327) 反应(5209) 腳本語言(PerlPython)(5129) 非技術區(4971) Android(4554) 数据框(4311) css(4259) 节点.js(4032) C語言(3288) json(3245) 列表(3129) 扑(3119) C++語言(3117) 安卓(2998) 打字稿(2995) VBA(2789) Java相關(2746) 疑難問題(2699) 细绳(2522) 單片機工控(2479) iOS(2429) ASP.NET(2402) MongoDB(2323) 麻木的(2285) 正则表达式(2254) 字典(2211) 循环(2198) 迅速(2185) 擅长(2169) 镖(2155) 功能(1967) .NET技术(1958) Web開發(1951) python-3.x(1918) HtmlCss(1915) 弹簧靴(1913) C++(1909) xml(1889) PostgreSQL(1872) .NETCore(1853) 谷歌表格(1846) Unity3D(1843) for循环(1842)

熱門瀏覽
  • 【C++】Microsoft C++、C 和匯編程式檔案

    ......

    uj5u.com 2020-09-10 00:57:23 more
  • 例外宣告

    相比于斷言適用于排除邏輯上不可能存在的狀態,例外通常是用于邏輯上可能發生的錯誤。 例外宣告 Item 1:當函式不可能拋出例外或不能接受拋出例外時,使用noexcept 理由 如果不打算拋出例外的話,程式就會認為無法處理這種錯誤,并且應當盡早終止,如此可以有效地阻止例外的傳播與擴散。 示例 //不可 ......

    uj5u.com 2020-09-10 00:57:27 more
  • Codeforces 1400E Clear the Multiset(貪心 + 分治)

    鏈接:https://codeforces.com/problemset/problem/1400/E 來源:Codeforces 思路:給你一個陣列,現在你可以進行兩種操作,操作1:將一段沒有 0 的區間進行減一的操作,操作2:將 i 位置上的元素歸零。最終問:將這個陣列的全部元素歸零后操作的最少 ......

    uj5u.com 2020-09-10 00:57:30 more
  • UVA11610 【Reverse Prime】

    本人看到此題沒有翻譯,就附帶了一個自己的翻譯版本 思考 這一題,它的第一個要求是找出所有 $7$ 位反向質數及其質因數的個數。 我們應該需要質數篩篩選1~$10^{7}$的所有數,這里就不慢慢介紹了。但是,重讀題,我們突然發現反向質數都是 $7$ 位,而將它反過來后的數字卻是 $6$ 位數,這就說明 ......

    uj5u.com 2020-09-10 00:57:36 more
  • 統計區間素數數量

    1 #pragma GCC optimize(2) 2 #include <bits/stdc++.h> 3 using namespace std; 4 bool isprime[1000000010]; 5 vector<int> prime; 6 inline int getlist(int ......

    uj5u.com 2020-09-10 00:57:47 more
  • C/C++編程筆記:C++中的 const 變數詳解,教你正確認識const用法

    1、C中的const 1、區域const變數存放在堆疊區中,會分配記憶體(也就是說可以通過地址間接修改變數的值)。測驗代碼如下: 運行結果: 2、全域const變數存放在只讀資料段(不能通過地址修改,會發生寫入錯誤), 默認為外部聯編,可以給其他源檔案使用(需要用extern關鍵字修飾) 運行結果: ......

    uj5u.com 2020-09-10 00:58:04 more
  • 【C++犯錯記錄】VS2019 MFC添加資源不懂如何修改資源宏ID

    1. 首先在資源視圖中,添加資源 2. 點擊新添加的資源,復制自動生成的ID 3. 在解決方案資源管理器中找到Resource.h檔案,編輯,使用整個專案搜索和替換的方式快速替換 宏宣告 4. Ctrl+Shift+F 全域搜索,點擊查找全部,然后逐個替換 5. 為什么使用搜索替換而不使用屬性視窗直 ......

    uj5u.com 2020-09-10 00:59:11 more
  • 【C++犯錯記錄】VS2019 MFC不懂的批量添加資源

    1. 打開資源頭檔案Resource.h,在其中預先定義好宏 ID(不清楚其實ID值應該設定多少,可以先新建一個相同的資源項,再在這個資源的ID值的基礎上遞增即可) 2. 在資源視圖中選中專案資源,按F7編輯資源檔案,按 ID 型別 相對路徑的形式添加 資源。(別忘了先把檔案拷貝到專案中的res檔案 ......

    uj5u.com 2020-09-10 01:00:19 more
  • C/C++編程筆記:關于C++的參考型別,專供新手入門使用

    今天要講的是C++中我最喜歡的一個用法——參考,也叫別名。 參考就是給一個變數名取一個變數名,方便我們間接地使用這個變數。我們可以給一個變數創建N個參考,這N + 1個變數共享了同一塊記憶體區域。(參考型別的變數會占用記憶體空間,占用的記憶體空間的大小和指標型別的大小是相同的。雖然參考是一個物件的別名,但 ......

    uj5u.com 2020-09-10 01:00:22 more
  • 【C/C++編程筆記】從頭開始學習C ++:初學者完整指南

    眾所周知,C ++的學習曲線陡峭,但是花時間學習這種語言將為您的職業帶來奇跡,并使您與其他開發人員區分開。您會更輕松地學習新語言,形成真正的解決問題的技能,并在編程的基礎上打下堅實的基礎。 C ++將幫助您養成良好的編程習慣(即清晰一致的編碼風格,在撰寫代碼時注釋代碼,并限制類內部的可見性),并且由 ......

    uj5u.com 2020-09-10 01:00:41 more
最新发布
  • Rust中的智能指標:Box<T> Rc<T> Arc<T> Cell<T> RefCell<T> Weak

    Rust中的智能指標是什么 智能指標(smart pointers)是一類資料結構,是擁有資料所有權和額外功能的指標。是指標的進一步發展 指標(pointer)是一個包含記憶體地址的變數的通用概念。這個地址參考,或 ” 指向”(points at)一些其 他資料 。參考以 & 符號為標志并借用了他們所 ......

    uj5u.com 2023-04-20 07:24:10 more
  • Java的值傳遞和參考傳遞

    值傳遞不會改變本身,參考傳遞(如果傳遞的值需要實體化到堆里)如果發生修改了會改變本身。 1.基本資料型別都是值傳遞 package com.example.basic; public class Test { public static void main(String[] args) { int ......

    uj5u.com 2023-04-20 07:24:04 more
  • [2]SpinalHDL教程——Scala簡單入門

    第一個 Scala 程式 shell里面輸入 $ scala scala> 1 + 1 res0: Int = 2 scala> println("Hello World!") Hello World! 檔案形式 object HelloWorld { /* 這是我的第一個 Scala 程式 * 以 ......

    uj5u.com 2023-04-20 07:23:58 more
  • 理解函式指標和回呼函式

    理解 函式指標 指向函式的指標。比如: 理解函式指標的偽代碼 void (*p)(int type, char *data); // 定義一個函式指標p void func(int type, char *data); // 宣告一個函式func p = func; // 將指標p指向函式func ......

    uj5u.com 2023-04-20 07:23:52 more
  • Django筆記二十五之資料庫函式之日期函式

    本文首發于公眾號:Hunter后端 原文鏈接:Django筆記二十五之資料庫函式之日期函式 日期函式主要介紹兩個大類,Extract() 和 Trunc() Extract() 函式作用是提取日期,比如我們可以提取一個日期欄位的年份,月份,日等資料 Trunc() 的作用則是截取,比如 2022-0 ......

    uj5u.com 2023-04-20 07:23:45 more
  • 一天吃透JVM面試八股文

    什么是JVM? JVM,全稱Java Virtual Machine(Java虛擬機),是通過在實際的計算機上仿真模擬各種計算機功能來實作的。由一套位元組碼指令集、一組暫存器、一個堆疊、一個垃圾回收堆和一個存盤方法域等組成。JVM屏蔽了與作業系統平臺相關的資訊,使得Java程式只需要生成在Java虛擬機 ......

    uj5u.com 2023-04-20 07:23:31 more
  • 使用Java接入小程式訂閱訊息!

    更新完微信服務號的模板訊息之后,我又趕緊把微信小程式的訂閱訊息給實作了!之前我一直以為微信小程式也是要企業才能申請,沒想到小程式個人就能申請。 訊息推送平臺🔥推送下發【郵件】【短信】【微信服務號】【微信小程式】【企業微信】【釘釘】等訊息型別。 https://gitee.com/zhongfuch ......

    uj5u.com 2023-04-20 07:22:59 more
  • java -- 緩沖流、轉換流、序列化流

    緩沖流 緩沖流, 也叫高效流, 按照資料型別分類: 位元組緩沖流:BufferedInputStream,BufferedOutputStream 字符緩沖流:BufferedReader,BufferedWriter 緩沖流的基本原理,是在創建流物件時,會創建一個內置的默認大小的緩沖區陣列,通過緩沖 ......

    uj5u.com 2023-04-20 07:22:49 more
  • Java-SpringBoot-Range請求頭設定實作視頻分段傳輸

    老實說,人太懶了,現在基本都不喜歡寫筆記了,但是網上有關Range請求頭的文章都太水了 下面是抄的一段StackOverflow的代碼...自己大修改過的,寫的注釋挺全的,應該直接看得懂,就不解釋了 寫的不好...只是希望能給視頻網站開發的新手一點點幫助吧. 業務場景:視頻分段傳輸、視頻多段傳輸(理 ......

    uj5u.com 2023-04-20 07:22:42 more
  • Windows 10開發教程_編程入門自學教程_菜鳥教程-免費教程分享

    教程簡介 Windows 10開發入門教程 - 從簡單的步驟了解Windows 10開發,從基本到高級概念,包括簡介,UWP,第一個應用程式,商店,XAML控制元件,資料系結,XAML性能,自適應設計,自適應UI,自適應代碼,檔案管理,SQLite資料庫,應用程式到應用程式通信,應用程式本地化,應用程式 ......

    uj5u.com 2023-04-20 07:22:35 more